/* ===================== Warm Charcoal & Gold theme (site-wide chrome) ===================== */
:root{
    --ink-950:#0f0d0a;
    --ink-900:#15130f;
    --umber-900:#2a2015;
    --umber-700:#3d2f1a;
    --gold-700:#a8791c;
    --gold-600:#d4a017;
    --gold-500:#e8b93a;
    --gold-400:#f5c451;
    --cream:#f4f1ea;

    /* Override app.css's indigo design tokens site-wide (buttons, focus rings,
       hover states, etc. that reference var(--primary) anywhere on the site) */
    --primary: var(--gold-600);
    --primary-hover: var(--gold-700);
    --primary-dark: #8a6116;
    --primary-light: var(--gold-400);
    --primary-subtle: rgba(212,160,23,0.08);
    --primary-glow: rgba(212,160,23,0.25);
}

/* ---------- Sidebar / shared partials (Popular Apps, Editor's Choice, Categories & Platforms, search box) ---------- */
.top-apps {
    background: #ffffff !important;
    border: 1px solid rgba(212,160,23,0.15);
    border-radius: 16px;
}
.top-apps .section-title {
    font-family: 'Space Grotesk', sans-serif;
    color: #241a08;
}
.top-apps .section-title + a,
.top-apps > .m-1 > a.float-end {
    color: var(--gold-700) !important;
    font-weight: 600;
}
.top-apps .app-title,
.top-apps .developer {
    color: #77694f;
}
.right-column a {
    color: #241a08;
}
.section-icon {
    background-color: var(--gold-700) !important;
}
.search-form {
    color: #241a08;
}
.search-btn {
    background-color: var(--gold-600) !important;
}
.recommended-terms a {
    color: #fff !important;
}
.recommended-terms a:hover {
    color: #fff !important;
}

h1, h2, h3, h4, .brand-font, .brand-name {
    font-family: 'Space Grotesk', sans-serif;
}

/* ---------- Header / Navbar ---------- */
.navbar.site-navbar {
    background:
        radial-gradient(ellipse 700px 400px at 10% 0%, rgba(212,160,23,0.28) 0%, transparent 60%),
        radial-gradient(ellipse 800px 500px at 95% 30%, rgba(232,185,58,0.20) 0%, transparent 55%),
        linear-gradient(160deg, var(--ink-950) 0%, var(--ink-900) 35%, var(--umber-900) 65%, var(--umber-700) 100%) !important;
    border-bottom: 1px solid rgba(245,196,81,0.15);
}

.site-navbar .navbar-collapse {
    background: transparent !important;
}

/* Mobile off-canvas menu: on screens <992px, .navbar-collapse becomes a fixed
   slide-in drawer (see app.css .offcanvas-collapse) instead of an inline flex
   row — it needs its own solid background, "transparent" above only makes
   sense for the desktop inline case and left the mobile drawer see-through. */
@media (max-width: 991px) {
    .site-navbar .navbar-collapse.offcanvas-collapse {
        background:
            radial-gradient(ellipse 500px 400px at 100% 0%, rgba(212,160,23,0.22) 0%, transparent 60%),
            linear-gradient(160deg, var(--ink-950) 0%, var(--ink-900) 35%, var(--umber-900) 65%, var(--umber-700) 100%) !important;
        box-shadow: -10px 0 40px rgba(0,0,0,0.5) !important;
    }
    .site-navbar .offcanvas-header {
        border-bottom: 1px solid rgba(245,196,81,0.15);
        margin-bottom: 0.75rem;
    }
}

.site-navbar .brand-mark {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 6px 18px rgba(0,0,0,0.35);
    display: inline-flex;
}
.site-navbar .brand-mark img { width: 100%; height: 100%; object-fit: cover; display: block; }
.site-navbar .brand-name { color: #fdf8ee !important; font-weight: 700; font-size: 1.05rem; margin-left: .1rem; }
.site-navbar a.navbar-brand-link { display: flex; align-items: center; gap: .6rem; text-decoration: none; }

.site-navbar .nav-link,
.site-navbar .navbar-nav a {
    color: #fdf8ee !important;
    font-weight: 600;
    font-size: .88rem;
    border-radius: 10px;
    padding: .55rem .8rem !important;
}
.site-navbar .nav-link:hover,
.site-navbar .navbar-nav a:hover {
    color: var(--gold-400) !important;
    background: rgba(245,196,81,0.1);
}
.site-navbar .navbar-toggler svg,
.site-navbar .navbar-toggler { fill: var(--gold-400) !important; color: var(--gold-400) !important; }

.site-navbar .navbar-collapse .navbar-nav .dropdown-menu,
.site-navbar .dropdown-menu {
    background-color: #1c1710 !important;
    border: 1px solid rgba(245,196,81,0.2) !important;
    border-radius: 14px !important;
    padding: .5rem !important;
    box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.site-navbar .dropdown-item {
    color: #fdf8ee !important;
    border-radius: 9px;
    font-size: .85rem;
    padding: .55rem .7rem !important;
}
.site-navbar .dropdown-item:active,
.site-navbar .dropdown-item:hover {
    background-color: rgba(245,196,81,0.1) !important;
    color: var(--gold-400) !important;
}
.site-navbar .dropdown-toggle::after { color: var(--gold-400) !important; }
.site-navbar .dropdown-divider { border-color: rgba(245,196,81,0.12); }
.site-navbar .dropdown-header { color: rgba(253,248,238,0.6) !important; }
.site-navbar .offcanvas-title { color: #fdf8ee !important; }
.site-navbar .btn-close { filter: invert(1) grayscale(1) brightness(2); }

.site-navbar .search-form {
    align-items: center !important;
    gap: .6rem;
    background: #1c1710;
    border: 1.5px solid rgba(245,196,81,0.4);
    border-radius: 999px;
    padding: 0 .5rem 0 1.1rem;
    height: 42px;
    min-width: 260px;
    max-width: 340px;
    flex: 0 1 auto;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.3);
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.site-navbar .search-form:hover {
    border-color: rgba(245,196,81,0.6);
}
.site-navbar .search-form:focus-within {
    background: #241d13;
    border-color: var(--gold-400);
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.3), 0 0 0 3px rgba(245,196,81,0.18);
}
.site-navbar .search-form input {
    background: none;
    border: none;
    outline: none;
    box-shadow: none;
    color: var(--gold-400);
    font-weight: 600;
    font-size: .88rem;
    line-height: 1;
    padding: 0;
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
}
.site-navbar .search-form input::placeholder { color: rgba(245,196,81,0.4); font-weight: 500; }
.site-navbar .search-form button {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    padding: 0;
    margin: 0;
    background: var(--gold-400);
    border: none;
    border-radius: 50%;
    color: #241a08;
    font-size: .8rem;
    cursor: pointer;
    transition: background .15s ease, transform .15s ease;
}
.site-navbar .search-form button:hover {
    background: var(--gold-500);
    transform: scale(1.06);
}

.site-navbar .plans-pill {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .5rem .9rem !important;
    border-radius: 10px;
    font-weight: 700 !important;
    color: var(--gold-400) !important;
    border: 1px solid rgba(245,196,81,0.3);
}
.site-navbar .plans-pill:hover { background: rgba(245,196,81,0.1) !important; }

.site-navbar .bell-toggle {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(245,196,81,0.08);
    border: 1px solid rgba(245,196,81,0.16);
    padding: 0 !important;
}
.site-navbar .bell-toggle i { color: var(--gold-400) !important; font-size: 1rem; }

.site-navbar .avatar-chip {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .3rem .7rem .3rem .3rem !important;
    border-radius: 999px;
    border: 1px solid rgba(245,196,81,0.18);
}
.site-navbar .avatar-chip .avatar-dot {
    width: 28px; height: 28px; border-radius: 50%;
    background: linear-gradient(135deg, var(--gold-400), var(--gold-700));
    display: inline-flex; align-items: center; justify-content: center;
    font-size: .75rem; font-weight: 700; color: #241a08;
}
.site-navbar .avatar-chip .avatar-img {
    object-fit: cover;
    background: none;
}

.site-navbar .login-pill {
    background: #1c1710 !important;
    color: var(--gold-400) !important;
    font-weight: 700 !important;
    border-radius: 10px !important;
    padding: .55rem 1.1rem !important;
    box-shadow: 0 6px 16px rgba(0,0,0,0.3);
    transition: transform .15s ease, box-shadow .15s ease;
}
.site-navbar .login-pill:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(168,121,28,0.35);
    color: var(--gold-400) !important;
}

/* ---------- Footer ---------- */
footer.page-footer.site-footer-dark {
    background:
        radial-gradient(ellipse 700px 400px at 10% 0%, rgba(212,160,23,0.22) 0%, transparent 60%),
        radial-gradient(ellipse 800px 500px at 95% 20%, rgba(232,185,58,0.16) 0%, transparent 55%),
        linear-gradient(160deg, var(--ink-950) 0%, var(--ink-900) 35%, var(--umber-900) 65%, var(--umber-700) 100%);
    color: #fdf8ee;
    padding-top: 3rem;
}
.site-footer-dark .section-head {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .8px;
    text-transform: uppercase;
    color: var(--gold-400);
}
.site-footer-dark a { color: #fdf8ee; opacity: .85; }
.site-footer-dark a:hover { opacity: 1; color: var(--gold-400); }
.site-footer-dark .text-logo { color: #fdf8ee !important; font-weight: 700; }
.site-footer-dark .footer-brand-mark {
    width: 38px; height: 38px; border-radius: 10px; overflow: hidden;
    display: inline-block; vertical-align: middle; margin-right: .5rem;
    box-shadow: 0 6px 18px rgba(0,0,0,0.35);
}
.site-footer-dark .footer-brand-mark img { width: 100%; height: 100%; object-fit: cover; display: block; }
.site-footer-dark .footer-desc { opacity: .75; font-size: .85rem; line-height: 1.6; }
.site-footer-dark .submit-app,
.site-footer-dark .footer-links-inline a {
    color: var(--gold-400);
    font-weight: 600;
    font-size: .85rem;
}
.site-footer-dark .social-row a {
    width: 36px; height: 36px; border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(245,196,81,0.08); border: 1px solid rgba(245,196,81,0.18);
    margin-right: .5rem; opacity: 1;
}
.site-footer-dark .social-row a:hover { background: rgba(245,196,81,0.16); }
.site-footer-dark .footer-copyright {
    border-top: 1px solid rgba(245,196,81,0.14);
    opacity: .65;
    font-size: .8rem;
}

/* App rating button styles */
.rate_app {
    transition: all 0.3s ease;
}

.rate_app.voted {
    background-color: #007bff !important;
    border-color: #007bff !important;
    color: white !important;
    transform: scale(1.05);
}

.rate_app.voted .up-button svg,
.rate_app.voted .down-button svg {
    fill: white !important;
}

.rate_app.voted small {
    color: white !important;
    font-weight: bold;
}

/* Smaller stars inside the user dashboard list cards */
.user-dashboard .app-item .rating-icons i,
.user-dashboard .app-rating i {
    font-size: 0.85rem;
}
