/* ==========================================================
   DOMIINIQUE v9 — FINAL DEFINITIVE CSS
   Key fixes:
   - SVG icons use explicit color via forced currentColor on all children
   - Light mode sets vars on :root via html[data-theme="light"] selector
   - Canvas is z-index:-1 with pointer-events:none, body bg shows through
   - Hero image uses object-fit:cover + proper z-index layering
   - Smooth page and element transitions
   ========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Luxurious+Script&display=swap');

@font-face {
    font-family: 'OldLondon';
    src: url('../assets/old_london/OldLondon.ttf') format('truetype');
    font-weight: 400; font-display: swap;
}
@font-face {
    font-family: 'OldLondon';
    src: url('../assets/old_london/OldLondonAlternate.ttf') format('truetype');
    font-weight: 700; font-display: swap;
}
@font-face {
    font-family: 'Germanica';
    src: url('../assets/fonts/Plain Germanica.ttf') format('truetype');
    font-weight: 400; font-display: swap;
}
@font-face {
    font-family: 'Bickham Script Pro';
    src: url('../assets/bickham-script-pro/Bickham Script Pro Regular.ttf') format('truetype');
    font-weight: 400; font-display: swap;
}
@font-face {
    font-family: 'Bickham Script Pro';
    src: url('../assets/bickham-script-pro/Bickham Script Pro Semibold.ttf') format('truetype');
    font-weight: 600; font-display: swap;
}
@font-face {
    font-family: 'Bickham Script Pro';
    src: url('../assets/bickham-script-pro/Bickham Script Pro Bold.ttf') format('truetype');
    font-weight: 700; font-display: swap;
}

/* ────────────────────────────────────────────────────────
   DARK TOKENS (default)
   ──────────────────────────────────────────────────────── */
:root {
    --bg          : #0f0d0b;
    --bg2         : #1a1510;
    --bg-card     : rgba(255,255,255,0.05);
    --accent      : #800020;
    --accent2     : #c9a84c;
    --accent-soft : rgba(128,0,32,0.28);
    --fg          : #f0ebe3;
    --fg-sub      : rgba(240,235,227,0.55);
    --glass       : rgba(255,255,255,0.05);
    --glass-hi    : rgba(128,0,32,0.12);
    --border      : rgba(255,255,255,0.1);
    --border-soft : rgba(255,255,255,0.065);
    --nav-bg      : rgba(15,13,11,0.82);
    --nav-solid   : rgba(10,8,6,0.97);
    --mob-menu-bg : rgba(8,6,4,0.98);
    --fade        : #0f0d0b;
    --shadow      : 0 20px 70px rgba(0,0,0,0.65);
    --r           : 6px;
    /* Aliases for legacy pages */
    --fg-dim           : rgba(240,235,227,0.55);
    --clr-gold         : #c9a84c;
    --clr-void         : #0f0d0b;
    --clr-warm-beige   : rgba(240,235,227,0.55);
    --clr-text         : #f0ebe3;
    --clr-border-soft  : rgba(255,255,255,0.065);
    --clr-border       : rgba(255,255,255,0.1);
    --clr-nav-bg       : rgba(15,13,11,0.82);
    --bg-card-alt      : rgba(255,255,255,0.05);

    --f-serif  : 'Playfair Display', Georgia, serif;
    --f-sans   : 'Inter', system-ui, sans-serif;
    --f-script : 'Bickham Script Pro', 'Germanica', 'OldLondon', 'Luxurious Script', cursive;
    --f-mono   : 'Courier New', monospace;

    /* Reality Design aliases */
    --rd-gold  : #c9a84c;

    --gap  : clamp(1.5rem, 5vw, 4rem);
    --ease : cubic-bezier(0.23, 1, 0.32, 1);
}

/* ────────────────────────────────────────────────────────
   LIGHT TOKENS
   ──────────────────────────────────────────────────────── */
html[data-theme="light"] {
    --bg          : #f2ece0;
    --bg2         : #e8dfc9;
    --bg-card     : rgba(0,0,0,0.04);
    --fg          : #1a100a;
    --fg-sub      : rgba(26,16,10,0.55);
    --glass       : rgba(255,255,255,0.55);
    --glass-hi    : rgba(128,0,32,0.08);
    --border      : rgba(26,16,10,0.14);
    --border-soft : rgba(26,16,10,0.08);
    --nav-bg      : rgba(242,236,224,0.88);
    --nav-solid   : rgba(242,236,224,0.99);
    --mob-menu-bg : rgba(242,236,224,0.99);
    --fade        : #f2ece0;
    --shadow      : 0 16px 50px rgba(0,0,0,0.12);
    /* Aliases */
    --fg-dim           : rgba(26,16,10,0.55);
    --clr-warm-beige   : rgba(26,16,10,0.55);
    --clr-text         : #1a100a;
    --clr-void         : #f2ece0;
    --clr-nav-bg       : rgba(242,236,224,0.88);
}

/* ────────────────────────────────────────────────────────
   RESET
   ──────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html { overflow-x:hidden; }

body {
    background-color: var(--bg);
    color: var(--fg);
    font-family: var(--f-sans);
    line-height: 1.65;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    transition: background-color 0.5s var(--ease), color 0.4s var(--ease);
}

/* Scroll lock — no scroll-to-top bug */
body.menu-open {
    position: fixed;
    left: 0; right: 0;
    overflow-y: scroll;
}

/* 3D canvas — transparent, always behind */
canvas#hero-canvas {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    pointer-events: none;
    z-index: -1;
    transition: opacity 0.6s var(--ease), filter 0.6s var(--ease);
}
html[data-theme="light"] canvas#hero-canvas {
    opacity: 0.35;
    filter: contrast(1.3) saturate(1.4);
}

/* ────────────────────────────────────────────────────────
   TYPOGRAPHY
   ──────────────────────────────────────────────────────── */
.t-h1     { font-family:var(--f-serif); font-size:clamp(2.5rem,8vw,7rem);   font-weight:400; line-height:1.05; }
.t-h2     { font-family:var(--f-serif); font-size:clamp(1.7rem,4vw,3.5rem); font-weight:400; }
.t-h3     { font-family:var(--f-serif); font-size:1.3rem; letter-spacing:.1em; color:var(--accent); text-transform:uppercase; }
.t-serif  { font-family:var(--f-script); font-size:1.2em; color:var(--accent); font-style:italic; }
.t-brand  { font-family:var(--f-script); }
.t-eyebrow{ font-size:.62rem; letter-spacing:.42em; text-transform:uppercase; color:var(--accent); margin-bottom:1.4rem; display:block; }
.t-body   { font-size:.93rem; color:var(--fg-sub); font-weight:300; }
.t-center, .text-center { text-align:center; }
.reveal, .reveal-scroll { opacity:0; }

/* ════════════════════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════════════════════ */
nav#nav {
    position:fixed; top:0; width:100%;
    height:88px;
    display:flex; align-items:center; justify-content:space-between;
    padding:0 var(--gap);
    z-index:8000;
    background:var(--nav-bg);
    backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
    border-bottom:1px solid transparent;
    transition:height .4s var(--ease), background .45s var(--ease),
               box-shadow .4s, border-color .4s;
}
nav#nav.scrolled {
    height:66px;
    background:var(--nav-solid);
    box-shadow:0 2px 30px rgba(0,0,0,.18);
    border-bottom-color:var(--border-soft);
}

/* Logo */
.nav__logo { text-decoration:none; display:flex; flex-direction:column; flex-shrink:0; }
.nav__logo-text  { font-family:var(--f-script); font-size:clamp(1.8rem,3.5vw,2.7rem); color:var(--fg); line-height:.85; transition:color .4s; }
.nav__logo-motto { font-size:.54rem; letter-spacing:.3em; text-transform:uppercase; color:var(--fg); opacity:.38; margin-top:5px; transition:color .4s; }

/* Desktop nav links */
.nav__links { display:flex; gap:.8rem; list-style:none; }
.nav__links a {
    text-decoration:none; color:var(--fg); font-size:.52rem;
    text-transform:uppercase; letter-spacing:.15em; opacity:.42; white-space:nowrap;
    transition:opacity .25s, color .25s;
}
.nav__links a:hover, .nav__links a.active { opacity:1; color:var(--accent); }

/* Utilities bar */
.nav__utilities { 
    display:flex; align-items:center; 
    gap: clamp(0.35rem, 1.8vw, 0.75rem); 
    flex-shrink:0; 
}

@media (max-width: 480px) {
    .nav__utilities { gap: clamp(0.18rem, 1.2vw, 0.4rem); }
    .nav-icon-btn, .music-btn, .theme-toggle, .dom-search-btn, .nav__profile-btn { 
        width: clamp(26px, 7.5vw, 34px); 
        height: clamp(26px, 7.5vw, 34px); 
    }
    .nav-icon-btn svg, .music-btn svg, .dom-search-btn svg, .nav__profile-btn svg { 
        width: clamp(12px, 3.5vw, 15px); 
        height: clamp(12px, 3.5vw, 15px); 
    }
}

/* ── Profile avatar ── */
.nav__profile-btn {
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    border-radius:50%; overflow:hidden;
    border:1.5px solid var(--border);
    background:var(--glass);
    flex-shrink:0;
    transition:all .3s var(--ease);
}
.nav__profile-btn:hover { border-color:var(--accent); background:var(--glass-hi); transform:scale(1.1); }
.nav__profile-img { width:100%; height:100%; object-fit:cover; display:block; }

/* ── Icon circle buttons (books + cart) ── */
.nav-icon-btn {
    position:relative;
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    border-radius:50%;
    border:1.5px solid var(--border);
    background:var(--glass);
    color:var(--fg);
    text-decoration:none;
    cursor:pointer;
    flex-shrink:0;
    transition:background .3s var(--ease), border-color .3s, transform .25s;
}
.nav-icon-btn:hover {
    background:var(--glass-hi);
    border-color:var(--accent);
    transform:scale(1.1);
}
/* Force SVG to render correctly regardless of inheritance */
.nav-icon-btn svg {
    display:block;
    width:15px; height:15px;
    stroke:var(--fg);           /* explicit colour — no inheritance issues */
    fill:none;
    stroke-width:1.6;
    stroke-linecap:round;
    stroke-linejoin:round;
    overflow:visible;
    flex-shrink:0;
    transition:stroke .3s;
}
.nav-icon-btn:hover svg { stroke:var(--accent); }

/* Cart badge */
.nav-cart-badge {
    position:absolute; top:-5px; right:-5px;
    background:var(--accent); color:#fff;
    font-size:.44rem; font-weight:700;
    min-width:16px; height:16px;
    border-radius:50%; padding:0 3px;
    display:none; align-items:center; justify-content:center;
    line-height:1;
}
.nav-cart-badge.on { display:flex; }
/* Legacy cart-count inside text nav buttons */
.cart-count { display:none; }
.cart-count.on { display:inline; }

/* ── Music note button ── */
.music-btn {
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    border-radius:50%;
    border:1.5px solid var(--border);
    background:var(--glass);
    color:var(--fg);
    cursor:pointer;
    flex-shrink:0;
    user-select:none;
    transition:background .3s var(--ease), border-color .3s, transform .25s;
}
.music-btn:hover {
    background:var(--glass-hi);
    border-color:var(--accent);
    transform:scale(1.1);
}
/* Music note SVG — fill-based */
.music-btn svg {
    display:block;
    width:15px; height:15px;
    fill:var(--fg);             /* explicit colour */
    stroke:none;
    flex-shrink:0;
    transition:fill .3s;
}
.music-btn:hover svg { fill:var(--accent); }
.music-btn.playing { border-color:var(--accent); background:var(--glass-hi); }
.music-btn.playing svg { fill:var(--accent); animation:musicPulse 1.3s ease-in-out infinite; }
@keyframes musicPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.22)} }

/* ── Theme toggle ── */
.theme-toggle {
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    border-radius:50%;
    border:1.5px solid var(--border);
    background:var(--glass);
    color:var(--fg);
    cursor:pointer;
    flex-shrink:0;
    font-size:.95rem; line-height:1;
    user-select:none;
    transition:all .3s var(--ease);
}
.theme-toggle:hover { background:var(--glass-hi); border-color:var(--accent); transform:scale(1.1) rotate(15deg); }

/* ── Hamburger ── */
.nav__hamburger {
    display:none;
    flex-direction:column; justify-content:space-between;
    width:26px; height:17px;
    cursor:pointer; z-index:1100; flex-shrink:0;
}
.nav__hamburger span {
    display:block; width:100%; height:2px;
    background:var(--accent); border-radius:2px;
    transform-origin:center;
    transition:all .32s var(--ease);
}
nav#nav.mobile-open .nav__hamburger span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
nav#nav.mobile-open .nav__hamburger span:nth-child(2) { opacity:0; transform:scaleX(0); }
nav#nav.mobile-open .nav__hamburger span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

/* ════════════════════════════════════════════════════════
   MOBILE NAV
   ════════════════════════════════════════════════════════ */
@media (max-width:1060px) {
    nav#nav      { height:72px; padding:0 1.4rem; }
    .nav__hamburger { display:flex !important; }
    /* Mobile nav — SOLID panel, absolutely no transparency */
    .nav__links {
        display:flex !important;
        position:fixed !important;
        top:72px; left:0; width:100vw; 
        max-height: calc(100dvh - 72px);
        overflow-y: auto;
        background: var(--nav-solid) !important;
        backdrop-filter: blur(40px) !important;
        -webkit-backdrop-filter: blur(40px) !important;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6);
        flex-direction:column; align-items:center; justify-content:flex-start;
        gap:1.4rem; z-index:9000 !important;
        visibility:hidden; opacity:0; pointer-events:none;
        transition:opacity .4s var(--ease), visibility .4s;
        border-right: none;
        padding: 2.5rem 0 5rem;
    }
    nav#nav.mobile-open .nav__links {
        visibility:visible !important;
        opacity:1 !important;
        pointer-events:all !important;
    }
    .nav__links a {
        color: var(--fg);
        font-weight: 500;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        transition: all 0.35s var(--ease);
        padding: 0.6rem 1.6rem;
        border-radius: 4px;
        font-size: 1.05rem;
        width: 100%;
        text-align: center;
        background: transparent;
    }
    .nav__links a:hover {
        background: var(--glass-hi);
        color: var(--accent);
        transform: scale(1.02);
    }
    nav#nav.mobile-open .nav__links { visibility:visible; opacity:1; pointer-events:all; }
    .nav__links a { font-size:.95rem; letter-spacing:.15em; opacity:.85; padding:.5rem 1.2rem; }
    .nav__links a:hover { opacity:1; color:var(--accent); }
    .nav__links { list-style:none; }
    /* Icons slightly smaller on small mobile */
    .nav-icon-btn, .music-btn, .theme-toggle { width:32px; height:32px; }
    .nav-icon-btn svg, .music-btn svg { width:13px; height:13px; }
}
@media (max-width:520px) {
    .nav__logo-text { font-size:clamp(1.5rem, 6vw, 2.2rem); }
    .nav__logo-motto { font-size: 0.45rem; letter-spacing: 0.2em; }
    .nav__utilities  { gap: clamp(0.15rem, 1.1vw, 0.4rem); }
    .nav__links a { font-size:.8rem; letter-spacing:.1em; padding:.4rem .8rem; }
}
@media (max-width: 360px) {
    nav#nav { padding: 0 0.8rem; }
    .nav__logo-text { font-size: 1.4rem; }
    .nav__utilities { gap: 0.15rem; }
}

/* ════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════ */
.hero {
    position:relative; overflow:hidden;
    min-height:100dvh;
    display:flex; align-items:center; justify-content:center;
    text-align:center;
}

/* Background image — fills hero, blends with theme */
.hero__bg-image {
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;           /* fills + crops, no scaling issues */
    object-position:center center;
    z-index:1;
    pointer-events:none;
    opacity:0.1;
    mix-blend-mode:screen;
    transition:opacity .5s var(--ease);
}
html[data-theme="light"] .hero__bg-image {
    opacity:0.15;
    mix-blend-mode:multiply;
    filter:sepia(30%) contrast(1.1);
}

/* Gradient at bottom of hero to blend into next section */
.hero::after {
    content:'';
    position:absolute; bottom:0; left:0; right:0;
    height:35%; z-index:3; pointer-events:none;
    background:linear-gradient(to bottom, transparent 0%, var(--bg) 100%);
    transition:background .5s var(--ease);
}

.hero__content {
    position:relative; z-index:5;
    padding:0 var(--gap); margin-top:5rem; width:100%;
}
.hero__logo-center { display:flex; flex-direction:column; align-items:center; margin-bottom:2rem; }
.hero__logo-text {
    font-family:var(--f-script);
    color:var(--fg);
    font-size:clamp(3rem,12vw,9rem);
    line-height:1.15; font-weight:400; padding-top:.15em;
    transition:color .4s var(--ease);
}
.hero__actions {
    display:flex; justify-content:center; align-items:center;
    gap:2rem; margin-top:2.5rem; flex-wrap:wrap;
}

.hero--sub {
    min-height:50vh; display:flex; align-items:flex-end;
    padding:120px var(--gap) 4rem;
}
.hero--sub .hero__content { text-align:left; margin-top:0; }

@media (max-width:768px) {
    .hero__content { margin-top:2rem; padding:1.2rem 1.2rem 0; }
    .hero__actions { flex-direction:column; gap:1rem; }
}
@media (max-width:480px) {
    .hero__logo-text { font-size:clamp(2.8rem,17vw,5rem); }
}

/* ════════════════════════════════════════════════════════
   SENSORY
   ════════════════════════════════════════════════════════ */
.sensory-section { position:relative; padding:7rem var(--gap); background:var(--bg2); overflow:hidden; }
.sensory-section::before,.sensory-section::after { content:''; position:absolute; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--accent-soft),transparent); }
.sensory-section::before{top:0} .sensory-section::after{bottom:0}
.sensory-header { text-align:center; margin-bottom:4.5rem; }
.sensory-header h2 { font-family:var(--f-serif); font-size:clamp(1.8rem,4vw,3rem); font-weight:400; color:var(--fg); margin-bottom:1.2rem; }
.sensory-header p { color:var(--fg-sub); font-size:1rem; max-width:520px; margin:0 auto; font-weight:300; }
.sensory-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; max-width:1200px; margin:0 auto; }
.sensory-card { position:relative; padding:2.5rem 1.8rem; background:var(--bg-card); border:1px solid var(--border-soft); border-radius:var(--r); text-align:center; transition:all .45s var(--ease); overflow:hidden; }
.sensory-card::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 50% 0%,var(--accent-soft) 0%,transparent 65%); opacity:0; transition:opacity .45s; }
.sensory-card:hover  { border-color:var(--accent-soft); transform:translateY(-7px); box-shadow:var(--shadow); }
.sensory-card:hover::before { opacity:.4; }
.sensory-icon { font-size:2.2rem; margin-bottom:1.3rem; display:block; }
.sensory-card h3 { font-family:var(--f-serif); font-size:1.3rem; color:var(--fg); margin-bottom:.4rem; font-weight:400; }
.sensory-card__sub { font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--accent); margin-bottom:1rem; display:block; }
.sensory-card p { font-size:.88rem; color:var(--fg-sub); font-weight:300; line-height:1.7; }
.sensory-card__line { width:28px; height:1px; background:var(--accent); margin:1.4rem auto 0; transition:width .4s var(--ease); }
.sensory-card:hover .sensory-card__line { width:55px; }
@media(max-width:880px){.sensory-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.sensory-grid{grid-template-columns:1fr;gap:1rem;} .sensory-section{padding:4rem 1.2rem;}}

/* ════════════════════════════════════════════════════════
   MARQUEE
   ════════════════════════════════════════════════════════ */
.marquee-strip { padding:1.8rem 0; background:var(--bg); border-top:1px solid var(--border-soft); border-bottom:1px solid var(--border-soft); overflow:hidden; }
.marquee-inner { display:flex; gap:3.5rem; white-space:nowrap; animation:marquee 28s linear infinite; width:max-content; }
.marquee-strip:hover .marquee-inner { animation-play-state:paused; }
.marquee-item { font-family:var(--f-serif); font-size:.9rem; color:var(--fg-sub); letter-spacing:.2em; text-transform:uppercase; flex-shrink:0; display:flex; align-items:center; gap:1.2rem; }
.marquee-item::after { content:'✦'; color:var(--accent); font-size:.65rem; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ════════════════════════════════════════════════════════
   CAROUSEL
   ════════════════════════════════════════════════════════ */
.carousel-section { padding:5rem 0; background:var(--bg); overflow:hidden; }
.section-intro { text-align:center; padding:0 var(--gap); margin-bottom:2.5rem; }
.carousel-outer { position:relative; z-index: 10; }
.carousel-outer::before,.carousel-outer::after { content:''; position:absolute; top:0; bottom:0; width:clamp(40px,7vw,100px); z-index:15; pointer-events:none; }
.carousel-outer::before { left:0; background:linear-gradient(to right,var(--fade),transparent); }
.carousel-outer::after  { right:0; background:linear-gradient(to left,var(--fade),transparent); }
.carousel-track { display:flex; gap:1.5rem; overflow-x:auto; scroll-snap-type:x mandatory; padding:1rem var(--gap) 2rem; -ms-overflow-style:none; scrollbar-width:none; position:relative; z-index:12; }
.carousel-track::-webkit-scrollbar { display:none; }
.carousel-slide { flex:0 0 270px; scroll-snap-align:start; position:relative; border-radius:var(--r); overflow:hidden; text-decoration:none; aspect-ratio:3/4; border:1px solid var(--border-soft); transition:transform .45s var(--ease),box-shadow .45s,border-color .3s; z-index:20; }
.carousel-slide:hover { transform:translateY(-7px) scale(1.02); box-shadow:var(--shadow); border-color:var(--accent-soft); z-index:25; }
.carousel-slide__bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.55; transition:transform .55s var(--ease),opacity .4s; background:var(--bg2); }
.carousel-slide:hover .carousel-slide__bg { transform:scale(1.06); opacity:.82; }
.carousel-slide::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,var(--fade) 0%,transparent 55%); z-index:1; pointer-events:none; }
.carousel-slide__content { position:absolute; bottom:0; left:0; right:0; padding:1.5rem; z-index:2; }
.carousel-slide__id { font-size:.55rem; color:var(--accent); letter-spacing:.32em; text-transform:uppercase; display:block; margin-bottom:.35rem; }
.carousel-slide__title { font-family:var(--f-serif); font-size:1.1rem; color:var(--fg); line-height:1.2; font-weight:400; }
.carousel-arrows { display:flex; justify-content:center; gap:1rem; margin-top:1.5rem; padding:0 var(--gap); position:relative; z-index:30; }
.carousel-btn { background:var(--glass); border:1px solid var(--border); color:var(--accent); width:44px; height:44px; border-radius:50%; cursor:pointer; font-size:1.15rem; display:flex; align-items:center; justify-content:center; transition:all .3s; flex-shrink:0; backdrop-filter:blur(8px); }
.carousel-btn:hover { background:var(--glass-hi); border-color:var(--accent); transform:scale(1.1); }
@media(max-width:760px){.carousel-slide{flex:0 0 220px;}}
@media(max-width:460px){.carousel-slide{flex:0 0 74vw;} .carousel-track{gap:1rem;}}

/* ════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════ */
.btn-primary { background:var(--accent); color:#fff; font-weight:600; padding:.9rem 2rem; font-family:var(--f-sans); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; text-decoration:none; transition:all .3s var(--ease); border-radius:3px; display:inline-block; border:1.5px solid var(--accent); }
.btn-primary:hover { background:transparent; color:var(--accent); }
.btn-secondary { color:var(--accent); text-decoration:none; text-transform:uppercase; font-size:.7rem; font-weight:600; letter-spacing:.22em; transition:opacity .3s; display:inline-block; }
.btn-secondary:hover { opacity:.6; }

/* ════════════════════════════════════════════════════════
   ROOMS GRID
   ════════════════════════════════════════════════════════ */
.rooms-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:1rem; margin-top:4rem; }
.room-card { position:relative; aspect-ratio:1/1.2; overflow:hidden; text-decoration:none; transition:transform .55s var(--ease); }
.room-card::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,var(--bg) 0%,transparent 55%); z-index:1; }
.room-card:hover { transform:scale(1.04); }
.room-card__bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.42; mix-blend-mode:luminosity; transition:opacity .5s,transform .5s; background:var(--bg2); }
.room-card:hover .room-card__bg { opacity:.85; mix-blend-mode:normal; transform:scale(1.07); }
html[data-theme="light"] .room-card__bg { mix-blend-mode:multiply; opacity:.55; }
.room-card__content { position:absolute; bottom:1.5rem; left:1.5rem; z-index:2; }
.room-card__id { font-size:.56rem; color:var(--accent); letter-spacing:.2em; display:block; }
.room-card__title { font-family:var(--f-serif); font-size:1.15rem; color:var(--fg); margin-top:.4rem; }
@media(max-width:1400px){.rooms-grid{grid-template-columns:repeat(5,1fr)}}
@media(max-width:1100px){.rooms-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:768px) {.rooms-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}}
@media(max-width:480px) {.rooms-grid{grid-template-columns:repeat(2,1fr);gap:.3rem}}

/* ════════════════════════════════════════════════════════
   MEMBERS SECTION
   ════════════════════════════════════════════════════════ */
.members-section { padding:7rem var(--gap); background:var(--bg2); }
.members-wall { max-width:900px; margin:0 auto; }
.members-tabs { display:flex; border-bottom:1px solid var(--border-soft); margin-bottom:3rem; }
.members-tab { padding:.9rem 2rem; font-size:.68rem; letter-spacing:.25em; text-transform:uppercase; cursor:pointer; color:var(--fg-sub); border-bottom:2px solid transparent; transition:all .3s; background:none; border-top:none; border-left:none; border-right:none; }
.members-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.members-panel { display:none; } .members-panel.active { display:block; }
.members-form { display:flex; flex-direction:column; gap:1.2rem; max-width:480px; margin:0 auto; }
.members-form input { background:var(--bg-card); border:1px solid var(--border-soft); color:var(--fg); padding:.85rem 1.1rem; border-radius:4px; font-family:var(--f-sans); font-size:.9rem; outline:none; transition:border-color .3s; width:100%; }
.members-form input:focus { border-color:var(--accent); }
.members-form button { width:100%; }
.members-benefits { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-bottom:3rem; }
.benefit-card { padding:1.8rem; background:var(--bg-card); border:1px solid var(--border-soft); border-radius:var(--r); text-align:center; }
.benefit-icon { font-size:1.8rem; margin-bottom:1rem; }
.benefit-card h4 { font-family:var(--f-serif); font-size:1.1rem; color:var(--fg); margin-bottom:.5rem; font-weight:400; }
.benefit-card p { font-size:.82rem; color:var(--fg-sub); line-height:1.6; }
@media(max-width:700px){.members-benefits{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.members-benefits{grid-template-columns:1fr;} .members-tabs{flex-wrap:wrap;}}

/* ════════════════════════════════════════════════════════
   MISC
   ════════════════════════════════════════════════════════ */
.transmission-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:3.5rem; margin-top:5rem; padding:0 var(--gap); }
.transmission-node { border-left:1px solid var(--border-soft); padding:2rem; transition:border-color .5s; }
.transmission-node:hover { border-color:var(--accent); background:var(--glass); }
.transmission-id { font-size:.58rem; color:var(--accent); opacity:.5; margin-bottom:1rem; display:block; }
.books-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:2rem; margin-top:4rem; }
@media(max-width:480px) { .books-grid { grid-template-columns:repeat(2,1fr); gap:1rem; } }
.book-card { cursor:pointer; transition:transform .55s var(--ease); }
.book-card:hover { transform:translateY(-11px); }
.book-card__img-container { aspect-ratio:2/3; overflow:hidden; border-radius:3px; border:1px solid var(--border-soft); margin-bottom:1.3rem; background:var(--bg-card); }
.book-card__img-container img { width:100%; height:100%; object-fit:cover; }

/* ── FOOTER ── */
footer { border-top:1px solid var(--border-soft); background:var(--bg); transition:background .5s var(--ease); }
.footer__inner { display:flex; flex-direction:column; align-items:center; gap:1.4rem; text-align:center; padding:2.8rem var(--gap); }
.footer__copy { font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:var(--fg-sub); }
.footer-legal-bar { text-align:center; padding:.8rem var(--gap); border-top:1px solid var(--border-soft); font-size:.6rem; letter-spacing:.15em; text-transform:uppercase; color:var(--fg-sub); }
.footer-legal-bar a { color:var(--fg-sub); text-decoration:none; transition:color .25s; }
.footer-legal-bar a:hover { color:var(--accent); }

/* ────────────────────────────────────────────────────────
   MODALS
   ──────────────────────────────────────────────────────── */
.modal-overlay, .book-modal {
    position: fixed; inset: 0; z-index: 10000;
    background: rgba(0,0,0,0.85); backdrop-filter: blur(14px);
    display: flex; align-items: center; justify-content: center;
    padding: 1.5rem; opacity: 0; pointer-events: none;
    transition: opacity 0.4s var(--ease);
}
.modal-overlay.open, .book-modal.active, .book-modal.open {
    opacity: 1; pointer-events: all;
}

.product-modal, .book-modal__content {
    background: var(--bg2); border: 1px solid var(--border-soft);
    border-radius: 14px; overflow: hidden; max-width: 860px; width: 100%;
    max-height: 90vh; overflow-y: auto; display: grid;
    grid-template-columns: 1fr 1fr;
    transform: scale(0.95) translateY(20px);
    transition: transform 0.45s var(--ease);
    position: relative;
}
.modal-overlay.open .product-modal, .book-modal.active .book-modal__content {
    transform: scale(1) translateY(0);
}

.modal__img, .book-modal__img-wrap { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--bg); }
.modal__img img, .book-modal__img-wrap img { width: 100%; height: 100%; object-fit: cover; }

.modal__body, .book-modal__info { padding: 2.5rem; display: flex; flex-direction: column; gap: 1rem; justify-content: center; }
.modal__close, .book-modal__close {
    position: absolute; top: 1.2rem; right: 1.2rem; width: 44px; height: 44px;
    border-radius: 50%; background: var(--bg2); border: 1px solid var(--accent);
    color: var(--fg); font-size: 1.8rem; display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 1000; transition: all 0.3s;
    line-height:1; padding-bottom: 4px;
}
.modal__close:hover, .book-modal__close:hover { border-color: var(--accent); color: #fff; background: var(--accent); transform: scale(1.1); }

.modal__desc, #modal-desc { font-size: 0.9rem; color: var(--fg-sub); line-height: 1.75; font-weight: 300; }

@media(max-width: 680px) {
    .product-modal, .book-modal__content { grid-template-columns: 1fr; }
    .modal__img, .book-modal__img-wrap { aspect-ratio: 16/9; }
}

/* ────────────────────────────────────────────────────────
   TOAST
   ──────────────────────────────────────────────────────── */
.cart-toast {
    position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%) translateY(100px);
    background: var(--accent); color: #fff; padding: 0.8rem 1.8rem;
    border-radius: 100px; font-size: 0.65rem; letter-spacing: 0.15em;
    text-transform: uppercase; z-index: 10000; opacity: 0;
    transition: all 0.5s var(--ease); box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}
.cart-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── LAYOUT ── */
.container { max-width:1400px; margin:0 auto; }
.container--narrow { max-width:780px; margin:0 auto; }
.section { padding:7rem var(--gap); }
@media(max-width:768px){ .section{padding:4.5rem 1.2rem;} }

/* ── Book Filter Chips ── */
.book-filter-chip {
    background:var(--bg-card); border:1.5px solid var(--border-soft);
    color:var(--fg-sub); border-radius:50px; padding:.4rem 1.1rem;
    font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
    cursor:pointer; transition:all .25s var(--ease);
}
.book-filter-chip:hover { border-color:var(--accent-soft); color:var(--fg); }
.book-filter-chip.active { background:var(--accent); border-color:var(--accent); color:#fff; }

/* ── Book Card Overlay ── */
.book-card { position:relative; overflow:hidden; cursor:pointer; }
.book-card__overlay {
    position:absolute; top:0; left:0; width:100%; height:100%;
    background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center;
    opacity:0; transition:opacity .3s var(--ease);
}
.book-card:hover .book-card__overlay { opacity:1; }
.book-card__btn {
    background:rgba(0,0,0,.7); backdrop-filter:blur(8px);
    color:var(--accent); border:1px solid var(--accent-soft);
    padding:.45rem 1.2rem; border-radius:50px; font-size:.6rem;
    letter-spacing:.15em; text-transform:uppercase; cursor:pointer;
    transition:all .3s;
}
.book-card__btn:hover { background:var(--accent); color:#fff; }

/* ── Search Input Focus ── */
#book-search:focus { border-color:var(--accent) !important; }

/* ── Nav Search Button (Standardized as nav-icon-btn) ── */
.dom-search-btn {
    position:relative;
    display:flex; align-items:center; justify-content:center;
    width:36px; height:36px;
    border-radius:50%;
    border:1.5px solid var(--border);
    background:var(--glass);
    color:var(--fg);
    cursor:pointer;
    flex-shrink:0;
    transition:all .3s var(--ease);
}
.dom-search-btn:hover { background:var(--glass-hi); border-color:var(--accent); transform:scale(1.1); }
.dom-search-btn svg { width:15px; height:15px; stroke:var(--fg); transition:stroke .3s; }
.dom-search-btn:hover svg { stroke:var(--accent); }

/* ═══ MEMBER DASHBOARD ═══ */
.substance-portal {
    max-width: 1000px;
    margin: 3rem auto 6rem;
    padding: 0 var(--gap);
}

.substance-section {
    margin-bottom: 8rem;
}

.substance-label {
    font-size: 0.7rem;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 3rem;
    opacity: 0.8;
}

/* Timeline */
.timeline-container {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-left: 1px solid var(--border-soft);
    padding-left: 3rem;
    margin-left: 1rem;
}

.timeline-slot {
    position: relative;
    padding: 2.5rem 0;
    border-bottom: 1px solid rgba(240,235,227,0.03);
}

.timeline-slot::before {
    content: '';
    position: absolute;
    left: -3.32rem;
    top: 3.25rem;
    width: 6px;
    height: 6px;
    background: var(--accent);
    border-radius: 50%;
    box-shadow: 0 0 12px var(--accent);
}

.ts-time {
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    color: var(--fg-dim);
    margin-bottom: 0.8rem;
    opacity: 0.6;
}

.ts-activity {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    margin-bottom: 0.7rem;
    color: var(--fg);
    font-weight: 300;
}

.ts-detail {
    font-size: 0.95rem;
    color: var(--fg-sub);
    max-width: 640px;
    line-height: 1.7;
    opacity: 0.75;
}

/* Library */
.library-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 2.5rem;
}

.library-item {
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--border-soft);
    padding: 2.5rem;
    border-radius: 2px;
    display: flex;
    gap: 1.5rem;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.library-item:hover {
    transform: translateY(-8px);
    border-color: var(--accent);
    background: rgba(255,255,255,0.04);
}

.li-icon {
    font-size: 2rem;
    opacity: 0.6;
}

.li-meta {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.li-title {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    color: var(--fg);
    line-height: 1.3;
}

.li-subtitle {
    font-size: 0.85rem;
    color: var(--fg-dim);
    font-style: italic;
    opacity: 0.7;
}

.li-tag {
    margin-top: 0.8rem;
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--accent);
    opacity: 0.6;
}

/* Filters */
.library-filters {
    display: flex;
    gap: 1.2rem;
}

.filter-btn {
    background: transparent;
    border: 1px solid var(--border-soft);
    color: var(--fg-dim);
    padding: 0.6rem 1.5rem;
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.4s ease;
    border-radius: 2px;
}

.filter-btn:hover {
    border-color: var(--accent);
    color: var(--fg);
}

.filter-btn.active {
    background: var(--accent);
    color: var(--bg);
    border-color: var(--accent);
}

@media (max-width: 768px) {
    .timeline-container { margin-left: 0.5rem; padding-left: 1.8rem; }
    .ts-activity { font-size: 1.35rem; }
    .library-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .substance-section { margin-bottom: 5rem; }
}


/* Beautiful Emojis */
.emoji, .sensory-icon, #theme-toggle, .cart-toast span:first-child { font-family: 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji', sans-serif !important; }

/* ──────── 6-STAGE JOURNEY SLIDER ──────── */
.journey-section {
    padding: 6rem 2rem;
    background: var(--bg2);
    overflow: hidden;
}
.journey-header {
    text-align: center;
    margin-bottom: 3.5rem;
}
.journey-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    max-width: 1300px;
    margin: 0 auto;
}
.journey-track {
    display: flex;
    gap: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 1rem 0;
    cursor: grab;
    scroll-behavior: smooth;
    flex: 1;
}
.journey-track::-webkit-scrollbar { display: none; }
.journey-track:active { cursor: grabbing; }
.journey-stage {
    scroll-snap-align: center;
    scroll-snap-stop: always;
    flex: 0 0 100%;
    background: var(--bg-card);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: 3rem 2.5rem;
    transition: all 0.4s ease;
    position: relative;
    box-sizing: border-box;
}
.journey-num {
    font-size: 0.6rem;
    letter-spacing: 0.3em;
    color: var(--accent);
    font-weight: 700;
    display: block;
    margin-bottom: 0.8rem;
}
.journey-title {
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--fg);
    margin-bottom: 0.4rem;
    line-height: 1.3;
}
.journey-sub {
    font-family: 'Luxurious Script', cursive;
    font-size: 1.2rem;
    color: var(--accent);
    margin-bottom: 1rem;
    opacity: 0.85;
}
.journey-desc {
    font-size: 0.72rem;
    line-height: 1.7;
    color: var(--fg-sub);
    opacity: 0.75;
}
.journey-arrow {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--fg);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-size: 1.1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.journey-arrow:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--bg);
}
.journey-arrow:disabled {
    opacity: 0.2;
    cursor: default;
    pointer-events: none;
}
.journey-dots {
    display: flex;
    justify-content: center;
    gap: 0.6rem;
    margin-top: 2rem;
}
.journey-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
}
.journey-dot.active {
    background: var(--accent);
    width: 24px;
    border-radius: 4px;
}
@media (max-width: 768px) {
    .journey-section { padding: 4rem 1rem; }
    .journey-arrow { display: none; }
}

