/**
 * Sunrise Amber — loaded AFTER Vite so production hosts still show the new theme
 * if public/build was not re-uploaded after npm run build.
 * Keep in sync with resources/css/app.css tokens and component colors.
 */
:root {
    --fc-mint: #fbbf24;
    --fc-mint-soft: #fffbeb;
    --fc-blue: #ea580c;
    --fc-blue-soft: #ffedd5;
    --fc-peach: #fb923c;
    --fc-peach-soft: #fff7ed;
    --fc-text-strong: #7c2d12;
    --fc-text-body: #c2410c;
    /* Keep in lockstep with resources/css/app.css (smaller header pills) */
    --header-nav-tab-pad-y: clamp(0.3rem, 0.25rem + 0.2vw, 0.6rem);
    --header-nav-tab-pad-x: clamp(0.4rem, 0.3rem + 0.4vw, 0.75rem);
    --header-nav-tab-font: clamp(0.75rem, 0.68rem + 0.12vw, 0.9rem);
    --header-nav-tab-line: 1.35;
    --header-nav-tab-shadow: 0 0.2rem 0.6rem rgba(234, 88, 12, 0.22);
    --header-nav-tab-radius: clamp(0.4rem, 0.32rem + 0.2vw, 0.6rem);
    --hero-cta-pad-y: clamp(0.55rem, 0.45rem + 0.25vw, 0.85rem);
    --hero-cta-pad-x: clamp(0.75rem, 0.55rem + 0.55vw, 1.35rem);
    --hero-cta-font: clamp(0.875rem, 0.78rem + 0.15vw, 1.05rem);
    --hero-cta-shadow: 0 clamp(0.35rem, 0.2rem + 0.4vw, 0.65rem) clamp(0.85rem, 0.35rem + 0.9vw, 1.5rem) rgba(234, 88, 12, 0.28);
}

html body {
    background: #fffbeb !important;
}

/*
 * Header shell: gradient + border (Tailwind arbitrary classes are absent if utilities fail to load).
 */
#siteHeader.site-header-shell {
    background: linear-gradient(90deg, #fff7ed 0%, #fffbeb 45%, #fef3c7 100%) !important;
    border-bottom: 1px solid #fdba74 !important;
    box-shadow: 0 6px 18px rgba(234, 88, 12, 0.14) !important;
}

/*
 * Mimic Tailwind `hidden` + `lg:block` + mobile `flex` toggle on #navMenu when utilities are missing.
 */
#siteHeader #navMenu.hidden {
    display: none !important;
}

#siteHeader #navMenu.flex {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    min-width: 0 !important;
}

@media (min-width: 1024px) {
    /* Guest: #navMenu spans cols 2–4 (see app.css); authed: middle column only */
    #siteHeader[data-header-state='guest'] #navMenu {
        display: grid !important;
    }

    /* Desktop always shows the bar; `hidden` is a mobile toggle (see original #navMenu.hidden → block hack) */
    #siteHeader[data-header-state='guest'] #navMenu.header-nav-rail.hidden {
        display: grid !important;
        grid-column: 2 / 4 !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
    }

    #siteHeader[data-header-state='guest'] #navMenu.header-nav-rail.flex {
        display: grid !important;
        grid-column: 2 / 4 !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
    }

    #siteHeader[data-header-state='authed'] #navMenu {
        display: block !important;
    }

    #siteHeader[data-header-state='authed'] #navMenu.hidden {
        display: block !important;
    }

    #siteHeader[data-header-state='authed'] #navMenu.flex {
        display: block !important;
    }
}

/*
 * Header + main nav row (fallback when Tailwind / app-tailwind.css is missing or stale).
 * Live site was still loading broken /build/assets/*.css only; menu collapsed to one line.
 */
#siteHeader .site-header-inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
    gap: 0.65rem;
    /* Local stacking: logo (blur/shadow) must not paint over main nav on desktop */
    position: relative;
    isolation: isolate;
}

#siteHeader .site-logo-chip {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}

#siteHeader .site-header-nav#navMenu {
    min-width: 0;
}

/* Mobile / stacked: vertical menu with clear spacing */
#siteHeader .site-header-nav#navMenu > ul,
#siteHeader ul.site-header-menu-list {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.35rem !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0.35rem 0 !important;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

#siteHeader .site-header-nav#navMenu > ul > li,
#siteHeader ul.site-header-menu-list > li {
    flex-shrink: 0;
    margin: 0;
    list-style: none;
}

@media (min-width: 1024px) {
    /*
     * Grid (not flex row) so the logo column and nav column never share the same X band.
     * Fixes live-site overlap where the white logo card sat on top of “About Us”.
     */
    #siteHeader .site-header-inner {
        /* Must win over any .flex from Tailwind so logo + nav use separate columns */
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) auto !important;
        align-items: center !important;
        column-gap: clamp(0.4rem, 0.2rem + 0.5vw, 0.75rem) !important;
        row-gap: 0 !important;
        flex-direction: unset !important;
        flex-wrap: unset !important;
        justify-content: unset !important;
    }

    #siteHeader .site-header-inner:has(> .site-header-userbar) {
        grid-template-columns: auto minmax(0, 1fr) auto !important;
    }

    #siteHeader .site-header-inner.site-header-inner--authed {
        grid-template-columns: auto minmax(0, 1fr) auto !important;
    }

    #siteHeader .site-header-logo-col {
        grid-column: 1;
        min-width: 0;
        max-width: 100%;
        position: relative;
        z-index: 1;
    }

    #siteHeader .site-logo-chip {
        width: fit-content;
        max-width: min(16rem, 40vw) !important;
    }

    #siteHeader .site-header-menu-col {
        grid-column: 2;
        min-width: 0 !important;
        max-width: 100%;
        width: 100%;
        overflow: hidden;
        position: relative;
        z-index: 2;
    }

    /* Desktop: #navMenu is display:contents (see app.css); scrollbar + container live on .header-nav-cqi <ul> */
    #siteHeader .header-nav-cqi {
        position: relative;
        z-index: 2;
        min-width: 0 !important;
        width: 100%;
        max-width: 100%;
        overflow-x: hidden;
        overflow-y: visible;
        container-type: inline-size;
        container-name: header-nav;
    }

    #siteHeader[data-header-state='guest'] #navMenu.header-nav-rail {
        display: grid !important;
        grid-column: 2 / 4 !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
    }

    #siteHeader[data-header-state='authed'] #navMenu.header-nav-rail {
        display: block !important;
        grid-column: 2 !important;
    }

    #siteHeader .site-header-userbar {
        grid-column: 3;
        min-width: 0;
    }

    #siteHeader #navMenu.header-nav-rail .site-header-menu-list,
    #siteHeader #navMenu.header-nav-rail > ul {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        row-gap: 0.35rem !important;
        padding: 0.1rem 0 !important;
    }

    #siteHeader[data-header-state='guest'] #navMenu.header-nav-rail .site-header-menu-list {
        justify-content: center !important;
        column-gap: clamp(0.35rem, 0.35cqi + 0.2rem, 0.85rem) !important;
    }

    #siteHeader[data-header-state='authed'] #navMenu.header-nav-rail .site-header-menu-list {
        justify-content: flex-start !important;
        column-gap: clamp(0.12rem, 0.2cqi + 0.1rem, 0.5rem) !important;
    }

    #siteHeader #navMenu.header-nav-rail .site-header-menu-list > li {
        flex: 0 0 auto !important;
        min-width: min-content !important;
        margin: 0;
    }
}

@media (min-width: 1280px) {
    #siteHeader[data-header-state='guest'] #navMenu.header-nav-rail .site-header-menu-list {
        column-gap: clamp(0.4rem, 0.4cqi + 0.2rem, 0.9rem) !important;
    }
    #siteHeader[data-header-state='authed'] #navMenu.header-nav-rail .site-header-menu-list {
        column-gap: clamp(0.2rem, 0.25cqi + 0.12rem, 0.65rem) !important;
    }
}

.site-nav-link {
    color: #7c2d12 !important;
    --tw-ring-color: rgb(234 88 12 / 0.3) !important;
}

.site-nav-link:hover {
    color: #ea580c !important;
}

.site-nav-link.active-link {
    color: #7c2d12 !important;
}

.site-nav-link--cta {
    color: #ea580c !important;
}

.site-nav-link--cta:hover {
    color: #c2410c !important;
}

#siteHeader .site-header-menu-list a.site-nav-link--cta,
#siteHeader .site-header-menu-list a.site-nav-link--cta:hover {
    color: #ffffff !important;
}

.site-nav-dropdown-link:hover {
    background: linear-gradient(90deg, #ea580c, #f59e0b) !important;
}

.premium-title,
.premium-section-title {
    color: #7c2d12 !important;
}

.premium-title {
    font-size: clamp(1.85rem, 4.2vw, 3.15rem) !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.08 !important;
}

.premium-section-title {
    font-size: clamp(1.35rem, 3vw, 1.875rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em !important;
    line-height: 1.15 !important;
}

.premium-subtitle {
    color: #c2410c !important;
    font-size: clamp(1rem, 2.4vw, 1.125rem) !important;
    line-height: 1.65 !important;
}

.premium-card {
    border-color: #fdba74 !important;
}

.premium-card:hover {
    box-shadow: 0 16px 36px rgba(194, 65, 12, 0.14) !important;
}

.premium-btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--hero-cta-pad-y) var(--hero-cta-pad-x) !important;
    border-radius: var(--header-nav-tab-radius) !important;
    font-size: var(--hero-cta-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #fff !important;
    background: linear-gradient(135deg, #ea580c, #f59e0b) !important;
    box-shadow: var(--hero-cta-shadow) !important;
    transition:
        opacity 0.15s ease,
        transform 0.15s ease;
}

.premium-btn-primary:hover {
    opacity: 0.95 !important;
    transform: translateY(-1px) !important;
}

.premium-btn-secondary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--hero-cta-pad-y) var(--hero-cta-pad-x) !important;
    border-radius: var(--header-nav-tab-radius) !important;
    font-size: var(--hero-cta-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    border: 2px solid #fdba74 !important;
    background: rgba(255, 255, 255, 0.95) !important;
    color: #c2410c !important;
    box-sizing: border-box !important;
    transition:
        background 0.15s ease,
        transform 0.15s ease;
}

.premium-btn-secondary:hover {
    background: #fff !important;
    transform: translateY(-1px) !important;
}

.premium-divider {
    background: linear-gradient(
        90deg,
        rgba(234, 88, 12, 0),
        rgba(234, 88, 12, 0.34),
        rgba(251, 191, 36, 0.34),
        rgba(255, 247, 237, 0.3)
    ) !important;
}

.flash-ticker-wrap {
    border-color: #fdba74 !important;
    background: linear-gradient(90deg, #fff7ed, #fffbeb, #ffedd5) !important;
}

.flash-ticker-track {
    display: flex !important;
    align-items: center !important;
    white-space: nowrap !important;
}

.flash-ticker-item {
    color: #9a3412 !important;
}

/* Home hero + trust badges: layout when Tailwind gap/grid utilities are missing */
.home-hero-section {
    background: linear-gradient(to bottom right, #fff7ed, #fffbeb, #fef3c7) !important;
}

.home-hero-inner {
    padding-top: calc(var(--site-header-offset, 128px) + 1rem) !important;
}

@media (max-width: 640px) {
    .home-hero-inner {
        padding-top: calc(var(--site-header-offset, 128px) + 0.75rem) !important;
    }
}

.home-hero-grid {
    display: grid !important;
    gap: 1.5rem !important;
    align-items: center !important;
    box-sizing: border-box !important;
}

@media (min-width: 1024px) {
    .home-hero-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 2.5rem !important;
    }
}

.home-hero-cta-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.75rem !important;
    align-items: center !important;
}

.trust-badges-strip {
    background: linear-gradient(90deg, #fff7ed, #ffedd5, #fffbeb) !important;
}

.trust-badges-row {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0.85rem !important;
    box-sizing: border-box !important;
}

.trust-badges-row > div {
    border-radius: 9999px !important;
    padding: 0.5rem 1.1rem !important;
    border: 1px solid rgba(234, 88, 12, 0.38) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    color: #7c2d12 !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    box-shadow: 0 6px 18px rgba(234, 88, 12, 0.12) !important;
}

.site-header-shell.is-scrolled {
    box-shadow: 0 10px 24px rgba(194, 65, 12, 0.18) !important;
}

.btn-brand {
    background: linear-gradient(135deg, #ea580c, #f59e0b) !important;
    box-shadow: 0 8px 18px rgba(234, 88, 12, 0.28) !important;
}

.btn-brand-outline {
    border-color: #ea580c !important;
    color: #ea580c !important;
}

.btn-brand-outline:hover {
    background: rgba(234, 88, 12, 0.1) !important;
}

.text-brand-primary {
    color: #ea580c !important;
}

.text-brand-strong {
    color: #7c2d12 !important;
}

.ring-brand {
    --tw-ring-color: rgba(234, 88, 12, 0.35) !important;
}

.theme-bubble {
    box-shadow:
        inset 0 10px 18px rgba(255, 255, 255, 0.46),
        0 10px 24px rgba(234, 88, 12, 0.22) !important;
}

.theme-bubble--1 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.94), rgba(254, 243, 199, 0.92) 47%, rgba(251, 191, 36, 0.58)) !important;
}
.theme-bubble--2 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.92), rgba(254, 240, 138, 0.9) 47%, rgba(245, 158, 11, 0.62)) !important;
}
.theme-bubble--3 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.95), rgba(255, 237, 213, 0.92) 45%, rgba(251, 146, 60, 0.55)) !important;
}
.theme-bubble--4 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.92), rgba(254, 215, 170, 0.88) 45%, rgba(234, 88, 12, 0.48)) !important;
}
.theme-bubble--5 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.93), rgba(255, 247, 237, 0.95) 47%, rgba(249, 115, 22, 0.45)) !important;
}
.theme-bubble--6 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.97), rgba(255, 235, 200, 0.92) 43%, rgba(245, 158, 11, 0.55)) !important;
}
.theme-bubble--7 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.92), rgba(255, 228, 200, 0.9) 46%, rgba(234, 88, 12, 0.42)) !important;
}
.theme-bubble--8 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.94), rgba(254, 215, 170, 0.9) 45%, rgba(249, 115, 22, 0.62)) !important;
}
.theme-bubble--9 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.94), rgba(255, 228, 230, 0.92) 46%, rgba(248, 113, 113, 0.48)) !important;
}
.theme-bubble--10 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.98), rgba(254, 243, 199, 0.94) 43%, rgba(251, 191, 36, 0.58)) !important;
}
.theme-bubble--11 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.95), rgba(254, 240, 138, 0.92) 45%, rgba(234, 179, 8, 0.64)) !important;
}
.theme-bubble--12 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.94), rgba(255, 237, 213, 0.92) 46%, rgba(251, 146, 60, 0.52)) !important;
}
.theme-bubble--13 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.92), rgba(254, 202, 202, 0.88) 47%, rgba(220, 38, 38, 0.42)) !important;
}
.theme-bubble--14 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.98), rgba(255, 237, 200, 0.92) 44%, rgba(251, 191, 36, 0.55)) !important;
}
.theme-bubble--15 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.95), rgba(253, 186, 116, 0.88) 45%, rgba(234, 88, 12, 0.52)) !important;
}
.theme-bubble--16 {
    background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.92), rgba(254, 215, 170, 0.9) 46%, rgba(234, 88, 12, 0.55)) !important;
}

.swal2-container .swal2-popup button.swal2-confirm {
    background-color: #ea580c !important;
    border-color: #c2410c !important;
}

.swal2-container .swal2-popup button.swal2-confirm:hover {
    background-color: #c2410c !important;
}

.swal2-container .swal2-popup button.swal2-deny {
    background-color: #ea580c !important;
    color: #ffffff !important;
    border-color: #c2410c !important;
}

.swal2-container .swal2-popup button.swal2-deny:hover {
    background-color: #c2410c !important;
    color: #ffffff !important;
}

/*
 * Main header nav (must be last in this file): every top-level link = Join-style pill.
 * Beats .site-nav-link { color: !important } above via #id + #id specificity.
 * Upload this file after any edit — prod often relies on it without npm build.
 */
/*
 * .header-nav-rail: one scalable row; cqi = nav column, rem = user zoom. Mirror app.css.
 */
#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.25em !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    letter-spacing: 0.015em !important;
    line-height: var(--header-nav-tab-line) !important;
    color: #ffffff !important;
    background: linear-gradient(90deg, #ea580c 0%, #f59e0b 100%) !important;
    border: 0 !important;
    box-shadow: var(--header-nav-tab-shadow) !important;
    border-radius: var(--header-nav-tab-radius) !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    white-space: nowrap !important;
    transition:
        filter 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.15s ease !important;
}

@media (min-width: 1024px) {
    #siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a {
        width: auto !important;
        max-width: none !important;
    }
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a:hover {
    color: #ffffff !important;
    filter: brightness(1.08) !important;
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.95) !important;
    outline-offset: 2px !important;
}

@media (max-width: 1023px) {
    #siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li,
    #siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Same tap target as hero primary CTA (variables in :root) */
#siteHeader .site-nav-link.header-main-nav-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.25rem !important;
    color: #ffffff !important;
    background: linear-gradient(90deg, #ea580c 0%, #f59e0b 100%) !important;
    border: none !important;
    border-radius: var(--header-nav-tab-radius) !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    font-weight: 600 !important;
    box-shadow: var(--header-nav-tab-shadow) !important;
    white-space: nowrap !important;
}

#siteHeader .site-nav-link.header-main-nav-pill:hover,
#siteHeader .site-nav-link.header-main-nav-pill.site-nav-link--cta,
#siteHeader .site-nav-link.header-main-nav-pill.site-nav-link--cta:hover {
    color: #ffffff !important;
    filter: brightness(1.08);
}

/* Guest: full-width bar (no Tailwind .container on inner); .header-nav-rail handles tab scaling */
@media (min-width: 1024px) {
    #siteHeader[data-header-state='guest'] .site-header-inner--guest {
        max-width: none !important;
        width: 100% !important;
    }
}

/*
 * Pills use display:inline-flex !important above — that overrides Tailwind’s lg:hidden on <a>.
 * Hide these links on large screens as intended.
 */
@media (min-width: 1024px) {
    #siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.lg\:hidden,
    #siteHeader .site-header-menu-list > li > a.lg\:hidden {
        display: none !important;
    }
}

/* Nav hierarchy (home / guest): muted links vs. sign-in CTA vs. join outline — must load after pill block above. */
#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.header-nav-link--secondary {
    border-radius: var(--header-nav-tab-radius) !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    background: rgba(255, 255, 255, 0.75) !important;
    color: #57534e !important;
    background-image: none !important;
    border: 1px solid rgba(253, 186, 116, 0.45) !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05) !important;
    font-weight: 500 !important;
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.header-nav-link--secondary:hover {
    color: #b45309 !important;
    background: rgba(255, 255, 255, 0.95) !important;
    border-color: rgba(251, 191, 36, 0.7) !important;
    filter: none !important;
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.header-nav-link--join {
    border-radius: var(--header-nav-tab-radius) !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    background: #fffef9 !important;
    color: #9a3412 !important;
    background-image: none !important;
    border: 2px solid #ea580c !important;
    box-shadow: 0 2px 10px rgba(234, 88, 12, 0.1) !important;
    font-weight: 600 !important;
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.header-nav-link--join:hover {
    color: #7c2d12 !important;
    background: #fff7ed !important;
    border-color: #c2410c !important;
    filter: none !important;
}

#siteHeader #navMenu.header-nav-rail ul.site-header-menu-list > li > a.header-nav-link--signin {
    box-shadow: var(--header-nav-tab-shadow) !important;
}

/* Guest column: Sign in + Join (same as app.css when Vite build is stale) */
#siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.25em !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    letter-spacing: 0.015em !important;
    line-height: var(--header-nav-tab-line) !important;
    color: #ffffff !important;
    background: linear-gradient(90deg, #ea580c 0%, #f59e0b 100%) !important;
    border: 0 !important;
    box-shadow: var(--header-nav-tab-shadow) !important;
    border-radius: var(--header-nav-tab-radius) !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    white-space: nowrap !important;
}

@media (min-width: 1024px) {
    #siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a {
        width: auto !important;
        max-width: none !important;
    }
}

#siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a:hover {
    color: #ffffff !important;
    filter: brightness(1.08) !important;
}

#siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a.header-nav-link--join {
    border-radius: var(--header-nav-tab-radius) !important;
    padding: var(--header-nav-tab-pad-y) var(--header-nav-tab-pad-x) !important;
    font-size: var(--header-nav-tab-font) !important;
    line-height: var(--header-nav-tab-line) !important;
    background: #fffef9 !important;
    color: #9a3412 !important;
    background-image: none !important;
    border: 2px solid #ea580c !important;
    box-shadow: 0 2px 10px rgba(234, 88, 12, 0.1) !important;
    font-weight: 600 !important;
}

#siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a.header-nav-link--join:hover {
    color: #7c2d12 !important;
    background: #fff7ed !important;
    border-color: #c2410c !important;
    filter: none !important;
}

#siteHeader #navMenu.header-nav-rail .site-header-guest-cta > a.header-nav-link--signin {
    box-shadow: var(--header-nav-tab-shadow) !important;
}
