/* Dark Navbar — luxury storefront */
.cute-text,
.lux-nav-label {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-weight: 500 !important;
    letter-spacing: 0.14em !important;
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
}

.nav-link-dark {
    display: flex !important;
    align-items: center !important;
    padding: 0.5rem 1rem !important;
    border-radius: 0.75rem !important;
    color: rgba(255, 255, 255, 0.9) !important;
    transition: all 0.3s ease !important;
    position: relative !important;
}

.nav-link-dark:hover {
    color: white !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.nav-link-dark i {
    color: #ffffff !important;
    margin-right: 0.5rem !important;
}

.nav-link-dark:hover i {
    color: rgba(255, 255, 255, 0.9) !important;
}

.nav-link-dark span {
    color: inherit !important;
}

.nav-link-indicator-dark {
    position: absolute !important;
    bottom: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 0 !important;
    height: 1px !important;
    background-color: rgba(255, 255, 255, 0.85) !important;
    transition: width 0.3s ease !important;
}

.nav-link-dark:hover .nav-link-indicator-dark {
    width: 75% !important;
}

.mobile-link-dark {
    display: flex !important;
    align-items: center !important;
    padding: 0.75rem 1rem !important;
    border-radius: 0.5rem !important;
    transition: all 0.3s !important;
    color: white !important;
    background: transparent !important;
    width: 100% !important;
}

.mobile-link-dark:hover {
    background: rgba(255, 255, 255, 0.1) !important;
}

.mobile-link-dark i {
    color: #ffffff !important;
    margin-right: 0.75rem !important;
}

.mobile-link-dark:hover i {
    color: rgba(255, 255, 255, 0.9) !important;
}

.mobile-link-dark span {
    color: white !important;
}

/* Left drawer: lock page scroll when open */
body.mobile-nav-open {
    overflow: hidden !important;
}

.mobile-nav-backdrop {
    -webkit-tap-highlight-color: transparent;
}

#mobileMenu.mobile-nav-drawer {
    will-change: transform;
}

/* Pro row: left-aligned (icon tile + label + chevron). Icons centered only inside the tile. */
.mobile-link-dark--pro {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.75rem !important;
    padding: 0.65rem 0.75rem !important;
    border-radius: 0.75rem !important;
    border: 1px solid transparent !important;
    transition: background 0.2s ease, border-color 0.2s ease !important;
}

.mobile-link-dark--pro:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.mobile-link-dark__icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 2.5rem !important;
    height: 2.5rem !important;
    flex-shrink: 0 !important;
    border-radius: 0.65rem !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    line-height: 0 !important;
}

/* FA glyph: strip legacy .mobile-link-dark i margin so icons sit dead-center in the tile */
.mobile-link-dark--pro .mobile-link-dark__icon > i {
    margin: 0 !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1.125rem !important;
    height: 1.125rem !important;
}

.mobile-link-dark--pro .mobile-nav-label {
    flex: 1 1 auto !important;
    text-align: left !important;
}

.mobile-link-dark__chev {
    flex-shrink: 0 !important;
    font-size: 0.65rem !important;
    color: rgba(255, 255, 255, 0.35) !important;
    margin: 0 0 0 auto !important;
}

.mobile-link-dark--pro:hover .mobile-link-dark__chev {
    opacity: 0.55 !important;
}

#mobileMenuNav {
    padding-bottom: max(1.25rem, env(safe-area-inset-bottom, 0px)) !important;
    -webkit-overflow-scrolling: touch;
}

/* Mobile drawer: one type size + weight for every label (matches desktop nav rhythm) */
#mobileMenu .mobile-nav-label {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    line-height: 1.25 !important;
}

/* Logged-in display name: same metrics, natural casing */
#mobileMenu .mobile-nav-label--name {
    letter-spacing: 0.02em !important;
    text-transform: none !important;
}

/* Force all mobile menu text to be white */
#mobileMenu a,
#mobileMenu button {
    color: white !important;
}

#mobileMenu i {
    color: #ffffff !important;
}

#mobileMenu a.mobile-nav-danger,
#mobileMenu a.mobile-nav-danger span.mobile-nav-label {
    color: #fca5a5 !important;
}

#mobileMenu a.mobile-nav-danger i {
    color: #fca5a5 !important;
}

/* Forced Style Overrides */
html,
body {
    overflow-x: hidden;
}

/* Ensure header allows dropdowns to overflow */
header#mainHeader {
    overflow: visible !important;
}

header#mainHeader>div {
    overflow: visible !important;
}

/* Cart count badge: theme.css sets .flex { overflow-x: hidden } which clips
   absolutely positioned badges (weird arc / rotated-looking digits). */
header#mainHeader a[href="/cart"] {
    overflow: visible !important;
}

header#mainHeader .flex.items-center.gap-4 {
    overflow: visible !important;
}

/* Closed search modal must not paint (avoids stray controls / inputs flashing at odd positions) */
#searchModal.hidden {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* Number inputs site-wide: hide native spin buttons (they can look like stray UI next to logos if mis-styled) */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

/* Force dropdown to be on top of everything */
#userProfileDropdown {
    position: absolute !important;
    z-index: 9999 !important;
}

/* CRITICAL: Force mobile menu text to be white */
#mobileMenu a,
#mobileMenu a *,
#mobileMenu button,
#mobileMenu button *,
#mobileMenu span,
div#mobileMenu a,
div#mobileMenu button {
    color: white !important;
}

#mobileMenu i,
#mobileMenu .fas,
#mobileMenu .far,
#mobileMenu .fab {
    color: var(--color-accent) !important;
}

/* Drawer: icon tiles + chevrons (override accent for clearer hierarchy) */
#mobileMenu .mobile-link-dark__icon i {
    color: #9ec5e8 !important;
}
#mobileMenu .mobile-link-dark__chev {
    color: rgba(255, 255, 255, 0.35) !important;
}
#mobileMenu button#mobileMenuCloseBtn i {
    color: #ffffff !important;
}
#mobileMenu a.mobile-nav-danger .mobile-link-dark__icon i {
    color: #fca5a5 !important;
}

/* Override any Tailwind text color classes in mobile menu */
#mobileMenu .text-gray-900,
#mobileMenu .text-gray-800,
#mobileMenu .text-gray-700,
#mobileMenu .text-gray-600 {
    color: white !important;
}

@media (max-width: 768px) {
    #authContainer {
        align-items: flex-start !important;
        padding-top: 120px !important;
        padding-bottom: 20px !important;
    }

    #authDialog {
        width: 95% !important;
        margin: 0 auto !important;
    }
}