/* ═══════════════════════════════════════════════════════════
   LIONS CAMP — SIGNATURE STYLESHEET
   "Desert Monastery" direction — Amangiri × Aesop × Nobu
   Supersedes astonish.css + refine.css via !important.
   Load LAST. One coherent voice.
   ═══════════════════════════════════════════════════════════ */

/* ─── CORE TOKENS ───────────────────────────────────────── */
:root {
    --ink:       #0B0A08;     /* true background, warm black */
    --ink-2:     #151210;     /* surface */
    --paper:     #F5EFE3;     /* body text */
    --paper-hi:  #FFFFFF;     /* display text */
    --mute:      #8A8170;     /* muted text */
    --accent:    #C9A35E;     /* single signature gold */
    --accent-l:  #E6C791;
    --rule:      rgba(201,163,94,.18);
    --ff-d:      'Playfair Display', Georgia, serif;
    --ff-b:      'Inter', system-ui, sans-serif;
    --ease:      cubic-bezier(.16,1,.3,1);
}

body {
    background: var(--ink) !important;
    color: var(--paper) !important;
    font-family: var(--ff-b) !important;
    font-size: 17px !important;
    line-height: 1.7 !important;
    letter-spacing: 0 !important;
    font-weight: 300 !important;
    -webkit-font-smoothing: antialiased !important;
}

/* ═══════════════════════════════════════════════════════════
   1. NOISE REMOVAL — hide what doesn't belong in premium
   ═══════════════════════════════════════════════════════════ */
.grain, .corner, .hero-vignette,
#motion-canvas,
.kpi-glow, .rev-tile-glow, .phase-glow,
.zone-panel::after, .zone-panel::before,
.zone-overlay::after, .zone-overlay::before {
    display: none !important;
}

/* Tone down the marquees — use only one, subtle */
.marquee:nth-of-type(2) { display: none !important; }
.marquee {
    background: transparent !important;
    border: none !important;
    padding: 2rem 0 !important;
    margin: 0 !important;
    opacity: .55;
}
.marquee::before, .marquee::after { display: none !important; }
.marquee-item {
    font-family: var(--ff-b) !important;
    font-style: normal !important;
    font-size: .72rem !important;
    letter-spacing: .55em !important;
    font-weight: 500 !important;
    color: rgba(201,163,94,.5) !important;
    text-transform: uppercase;
    gap: 2rem !important;
}
.marquee-item::after { content: '·' !important; color: var(--accent); font-size: 1em !important; opacity: .6; }

/* ═══════════════════════════════════════════════════════════
   2. LEFT RAIL — signature gold hairline (Aesop device)
   ═══════════════════════════════════════════════════════════ */
@media (min-width: 1024px) {
    body::before {
        content: '';
        position: fixed;
        top: 0; bottom: 0;
        left: clamp(1.5rem, 3vw, 2.5rem);
        width: 1px;
        background: linear-gradient(
            to bottom,
            transparent 0%,
            rgba(201,163,94,.22) 10%,
            rgba(201,163,94,.22) 90%,
            transparent 100%
        );
        z-index: 60;
        pointer-events: none;
    }
    body::after {
        content: '';
        position: fixed;
        top: 50%;
        left: clamp(1.5rem, 3vw, 2.5rem);
        width: 1px;
        height: 60px;
        background: var(--accent);
        transform: translate(-.5px, -50%);
        box-shadow: 0 0 8px rgba(201,163,94,.35);
        z-index: 61;
        pointer-events: none;
        transition: top .3s var(--ease);
    }
}

/* ═══════════════════════════════════════════════════════════
   3. NAV — minimal ink
   ═══════════════════════════════════════════════════════════ */
#main-nav {
    background: transparent !important;
}
#main-nav.nav-solid {
    background: rgba(11,10,8,.6) !important;
    backdrop-filter: blur(24px) saturate(1.1) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.1) !important;
    border-bottom: none !important;
    box-shadow: 0 1px 0 rgba(201,163,94,.06);
}
.nav-inner { padding: 0 clamp(3rem, 6vw, 5.5rem) !important; height: clamp(4rem, 5vw, 5.5rem) !important; }
.nav-logo-main {
    font-family: var(--ff-b) !important;
    font-size: .78rem !important;
    letter-spacing: .42em !important;
    font-weight: 600 !important;
    color: var(--paper-hi) !important;
}
.nav-logo-sub { display: none !important; }
.nav-link {
    font-size: .68rem !important;
    letter-spacing: .4em !important;
    color: rgba(245,239,227,.5) !important;
    font-weight: 400 !important;
    text-transform: uppercase;
}
.nav-link:hover { color: var(--accent-l) !important; }
.nav-link::after, .nav-link::before { display: none !important; }
.nav-links { gap: 2.5rem !important; }

/* ═══════════════════════════════════════════════════════════
   4. HERO — monumental
   ═══════════════════════════════════════════════════════════ */
#hero { height: 100svh !important; min-height: 720px !important; }
.hero-bg img {
    filter: brightness(.85) contrast(1.1) saturate(.6) sepia(.25) !important;
}
.hero-grad--top, .hero-grad--radial { display: none !important; }
.hero-grad--bottom {
    background: linear-gradient(to top, var(--ink) 0%, transparent 45%) !important;
}
.hero-content { padding: 0 clamp(3rem, 6vw, 6rem) !important; }

.hero-title {
    line-height: .92 !important;
    letter-spacing: -.025em !important;
}
.hero-word {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: clamp(4.5rem, 14vw, 14rem) !important;
    color: var(--paper-hi) !important;
    text-shadow: 0 2px 40px rgba(0,0,0,.35) !important;
    background: none !important;
    -webkit-text-fill-color: currentColor !important;
    animation: none !important;
}
.hero-word--gold {
    font-style: italic !important;
    color: var(--accent-l) !important;
    font-weight: 300 !important;
}
#hero-line1, #hero-line2 {
    background: var(--accent) !important;
    height: 1px !important;
    width: 50px !important;
    margin: 2rem auto !important;
    box-shadow: none !important;
}
#hero-line1 { margin-bottom: 2.5rem !important; }
.hero-sub {
    font-family: var(--ff-d) !important;
    font-style: italic !important;
    font-weight: 400 !important;
    font-size: clamp(1.15rem, 1.6vw, 1.5rem) !important;
    color: rgba(245,239,227,.75) !important;
    letter-spacing: .1em !important;
    margin-top: .5rem !important;
    text-shadow: 0 1px 10px rgba(0,0,0,.5) !important;
}
.hero-tag {
    font-size: .65rem !important;
    letter-spacing: .6em !important;
    color: rgba(201,163,94,.7) !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    text-shadow: none !important;
}
.hero-scroll { color: rgba(245,239,227,.4) !important; font-size: .85rem !important; }

/* ═══════════════════════════════════════════════════════════
   5. COMPOUND + KPIs — single quiet band
   ═══════════════════════════════════════════════════════════ */
#compound {
    padding: clamp(7rem, 12vw, 11rem) 0 clamp(7rem, 12vw, 11rem) !important;
    margin: 0 !important;
}
.compound-img-wrap {
    max-width: 1240px !important;
    margin: 0 auto !important;
    padding: 0 clamp(1.5rem, 4vw, 4rem) !important;
}
.compound-img-wrap img {
    filter: brightness(.92) contrast(1.05) saturate(.75) sepia(.15) !important;
    border-radius: 2px;
}
.compound-overlay { display: none !important; }

/* Hotspots: minimal, static, no animations */
.hotspot { width: 14px !important; height: 14px !important; opacity: .55 !important; }
.hotspot::after { display: none !important; }
.hotspot::before {
    width: 8px !important; height: 8px !important;
    background: var(--accent-l) !important;
    box-shadow: 0 0 0 2px var(--ink), 0 0 12px rgba(201,163,94,.5) !important;
    animation: none !important;
}
.hotspot:hover { opacity: 1 !important; }

/* KPI: quiet typographic strip */
.kpi-strip {
    max-width: 1240px !important;
    margin: clamp(5rem, 9vw, 9rem) auto 0 !important;
    padding: clamp(3rem, 5vw, 4rem) clamp(1.5rem, 4vw, 4rem) !important;
    border: none !important;
    border-top: 1px solid var(--rule) !important;
    border-bottom: 1px solid var(--rule) !important;
    background: transparent !important;
    position: relative !important;
}
.kpi-strip::before, .kpi-strip::after { display: none !important; }
.kpi-row { gap: 1rem !important; }
.kpi-cell {
    padding: .5rem !important;
    border: none !important;
    background: none !important;
    text-align: center;
}
.kpi-num {
    font-family: var(--ff-d) !important;
    font-size: clamp(1.8rem, 2.6vw, 2.4rem) !important;
    font-weight: 400 !important;
    color: var(--paper-hi) !important;
    background: none !important;
    -webkit-text-fill-color: var(--paper-hi) !important;
    letter-spacing: -.01em !important;
    display: block;
}
.kpi-label {
    font-size: .62rem !important;
    letter-spacing: .38em !important;
    color: rgba(138,129,112,.75) !important;
    font-weight: 500 !important;
    margin-top: .4rem !important;
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════
   6. JOURNEY — compact editorial row
   ═══════════════════════════════════════════════════════════ */
.journey-wrap {
    padding: clamp(7rem, 11vw, 10rem) clamp(1.5rem, 4vw, 4rem) !important;
    max-width: 1240px !important;
    margin: 0 auto !important;
}
.journey-grid { gap: 0 !important; grid-template-columns: repeat(6, 1fr) !important; }
.journey-card {
    padding: 2.5rem 1rem !important;
    background: none !important;
    border: none !important;
    border-left: 1px solid var(--rule) !important;
    border-radius: 0 !important;
    text-align: center;
    box-shadow: none !important;
    transform: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.journey-card:first-child { border-left: none !important; }
.journey-card:hover { transform: none !important; box-shadow: none !important; border-color: var(--rule) !important; }
.jc-number {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: 1rem !important;
    color: var(--accent) !important;
    letter-spacing: 0 !important;
    margin-bottom: 1rem;
}
.jc-icon { display: none !important; }
.jc-title, .journey-card h3 {
    font-family: var(--ff-d) !important;
    font-size: 1.15rem !important;
    font-weight: 500 !important;
    color: var(--paper-hi) !important;
    letter-spacing: 0 !important;
    margin-bottom: .5rem !important;
}
.jc-copy, .journey-card p {
    font-size: .78rem !important;
    letter-spacing: .08em !important;
    color: var(--mute) !important;
    text-transform: uppercase;
    line-height: 1.7 !important;
}
.journey-line { display: none !important; }

/* ═══════════════════════════════════════════════════════════
   7. ZONES — reduce density (hide every other panel)
   Show 6 hero chapters instead of 12 micro-panels
   ═══════════════════════════════════════════════════════════ */
/* Keep: panels 1, 3, 5, 7, 9, 11 — hide the others */
.zone-panel:nth-of-type(even):not(.zone-panel--break) {
    display: none !important;
}
/* Break panels stay visible but simplified */
.zone-panel--break {
    height: 45svh !important;
    min-height: 320px !important;
}

.zone-panel {
    height: 100svh !important;
    min-height: 720px !important;
    margin: 0 !important;
}
.zone-bg-img {
    filter: brightness(.8) contrast(1.1) saturate(.55) sepia(.22) !important;
}

/* Single direction overlay — no more left/right/center clutter */
.zone-overlay, .zone-overlay--left, .zone-overlay--right, .zone-overlay--center {
    background: linear-gradient(
        to top,
        rgba(11,10,8,.88) 0%,
        rgba(11,10,8,.35) 30%,
        rgba(11,10,8,.2) 60%,
        rgba(11,10,8,.4) 100%
    ) !important;
}

.zone-inner, .zone-inner--left, .zone-inner--right, .zone-inner--center {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: clamp(6rem, 10vw, 10rem) clamp(2rem, 6vw, 6rem) !important;
    align-items: flex-start !important;
    text-align: left !important;
    justify-content: flex-end !important;
}
.zone-inner > * { max-width: 540px !important; margin-right: auto !important; margin-left: 0 !important; }
.zone-inner[data-chapter]::before {
    font-size: clamp(6rem, 10vw, 9rem) !important;
    color: rgba(201,163,94,.08) !important;
    top: auto !important;
    bottom: 75% !important;
    left: clamp(2rem, 6vw, 6rem) !important;
    right: auto !important;
    transform: none !important;
    text-shadow: none !important;
    font-style: normal !important;
}

.zone-heading {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: clamp(2.4rem, 5.5vw, 4.5rem) !important;
    letter-spacing: -.02em !important;
    line-height: 1.05 !important;
    color: var(--paper-hi) !important;
    text-shadow: 0 2px 30px rgba(0,0,0,.6) !important;
    background: none !important;
    -webkit-text-fill-color: var(--paper-hi) !important;
    margin-bottom: 1.75rem !important;
}
.zone-heading em { font-style: italic; color: var(--accent-l) !important; font-weight: 300 !important; }
.zone-heading::after { display: none !important; }

.zone-caption {
    font-size: 1rem !important;
    line-height: 1.9 !important;
    color: rgba(245,239,227,.8) !important;
    max-width: 46ch !important;
    font-weight: 300 !important;
    text-shadow: 0 1px 12px rgba(0,0,0,.6) !important;
    margin-bottom: 2rem !important;
}

/* Zone bullet lists → typographic, no bullets */
.zone-list { border-top: 1px solid var(--rule) !important; padding-top: 1.5rem !important; }
.zone-list li {
    font-size: .82rem !important;
    letter-spacing: .22em !important;
    color: var(--mute) !important;
    text-transform: uppercase !important;
    font-weight: 500 !important;
    padding: .65rem 0 !important;
    border-bottom: 1px solid var(--rule) !important;
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}
.zone-list li::before {
    content: '—' !important;
    color: var(--accent) !important;
    font-size: 1em !important;
    margin: 0 !important;
    width: auto !important;
    height: auto !important;
    background: none !important;
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   8. SECTION HEADERS — editorial
   ═══════════════════════════════════════════════════════════ */
#ecosystem, #phases, #revenue, #pitch-summary {
    padding: clamp(9rem, 14vw, 13rem) clamp(2rem, 5vw, 5rem) !important;
    background: var(--ink) !important;
}
.section-header {
    max-width: 720px !important;
    margin: 0 auto clamp(5rem, 9vw, 8rem) !important;
    text-align: center;
}
.eyebrow {
    font-size: .65rem !important;
    letter-spacing: .52em !important;
    color: var(--accent) !important;
    font-weight: 500 !important;
    margin-bottom: 2rem !important;
    text-transform: uppercase;
}
.section-title {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: clamp(2.5rem, 5.2vw, 4.2rem) !important;
    color: var(--paper-hi) !important;
    letter-spacing: -.02em !important;
    line-height: 1.05 !important;
    background: none !important;
    -webkit-text-fill-color: var(--paper-hi) !important;
    padding-bottom: 0 !important;
    margin: 0 !important;
}
.section-title em { font-style: italic !important; color: var(--accent-l) !important; font-weight: 300 !important; }
.section-title::after { display: none !important; }
.section-sub {
    font-size: 1.02rem !important;
    color: rgba(138,129,112,1) !important;
    line-height: 1.9 !important;
    max-width: 58ch !important;
    margin: 2.5rem auto 0 !important;
    padding: 0 !important;
    font-weight: 300 !important;
}

/* ═══════════════════════════════════════════════════════════
   9. CARDS — flat, typographic
   ═══════════════════════════════════════════════════════════ */
.phases-grid, .fin-grid, .rev-mosaic {
    max-width: 1100px !important;
    margin: 0 auto !important;
    gap: 1px !important;
    background: var(--rule);
    border: 1px solid var(--rule);
}
.phase-card, .fin-card, .rev-tile {
    background: var(--ink) !important;
    border: none !important;
    padding: clamp(2.5rem, 4vw, 4rem) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    transition: background .3s ease !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.phase-card:hover, .fin-card:hover, .rev-tile:hover {
    background: var(--ink-2) !important;
    transform: none !important;
    box-shadow: none !important;
    border-color: transparent !important;
}
.phase-card *, .fin-card *, .rev-tile * { text-align: left !important; }

/* Revenue tile hero: make it stand out via size only */
.rev-tile--hero { grid-column: span 2 !important; }
.rev-tile-badge, .fin-card h4, .phase-card h3, .rev-tile h3 {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: 1.35rem !important;
    color: var(--paper-hi) !important;
    letter-spacing: 0 !important;
}
.rev-tile p, .fin-card p, .phase-card p {
    color: var(--mute) !important;
    font-size: .92rem !important;
    line-height: 1.8 !important;
}

/* Remove SVG gauge dramatic effects */
.rev-tile-gauge, .rev-tile-gauge--sm { opacity: .85; }
.rev-gauge-num { color: var(--accent-l) !important; -webkit-text-fill-color: var(--accent-l) !important; }

/* ═══════════════════════════════════════════════════════════
   10. ECOSYSTEM — simplify orbital drama
   ═══════════════════════════════════════════════════════════ */
.eco-bg img { filter: brightness(.7) contrast(1) saturate(.4) sepia(.25) !important; }
.eco-bg-overlay { background: linear-gradient(to top, var(--ink), rgba(11,10,8,.5) 60%, var(--ink)) !important; }
#eco-particle-canvas { opacity: .35 !important; }
.eco-hub { border-color: rgba(201,163,94,.3) !important; background: var(--ink) !important; }
.eco-hub-title, .eco-hub-sub { color: var(--paper-hi) !important; }

/* ═══════════════════════════════════════════════════════════
   11. FOOTER — quiet sign-off
   ═══════════════════════════════════════════════════════════ */
#site-footer {
    padding: clamp(6rem, 10vw, 9rem) 2rem 3rem !important;
    border-top: 1px solid var(--rule) !important;
    margin-top: 0 !important;
    background: var(--ink) !important;
}
.footer-brand {
    font-family: var(--ff-d) !important;
    font-weight: 400 !important;
    font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
    letter-spacing: .02em !important;
    color: var(--paper-hi) !important;
}
.footer-tag {
    font-size: .65rem !important;
    letter-spacing: .55em !important;
    color: var(--mute) !important;
    margin-top: 1rem !important;
}
.footer-divider {
    width: 30px !important;
    background: var(--accent) !important;
    opacity: .6;
}
.footer-copy {
    font-size: .7rem !important;
    letter-spacing: .3em !important;
    color: rgba(138,129,112,.5) !important;
}

/* ═══════════════════════════════════════════════════════════
   12. SCROLLBAR & SELECTION
   ═══════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 2px !important; }
::-webkit-scrollbar-thumb { background: rgba(201,163,94,.3) !important; }
::selection { background: rgba(201,163,94,.28) !important; color: var(--paper-hi) !important; }

/* ═══════════════════════════════════════════════════════════
   13. MOBILE — same voice, proportional
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    body::before, body::after { display: none !important; }
    .nav-inner { padding: 0 1.25rem !important; }

    #hero { min-height: 620px !important; }
    .hero-word { font-size: clamp(3.2rem, 16vw, 6rem) !important; }
    .hero-content { padding: 0 1.5rem !important; }

    .zone-panel { height: auto !important; min-height: 0 !important; }
    .zone-inner {
        padding: 5rem 1.5rem !important;
        min-height: 75svh !important;
        justify-content: flex-end !important;
    }
    .zone-inner > * { max-width: none !important; }
    .zone-inner[data-chapter]::before {
        font-size: 4.5rem !important;
        bottom: 72% !important;
        left: 1.5rem !important;
    }
    .zone-heading { font-size: clamp(2rem, 8vw, 2.8rem) !important; }

    #compound { padding: 4rem 0 !important; }
    #ecosystem, #phases, #revenue, #pitch-summary {
        padding: 5rem 1.25rem !important;
    }
    .journey-wrap { padding: 4rem 1.25rem !important; }
    .section-header { margin-bottom: 3rem !important; }
    .section-title { font-size: clamp(1.9rem, 7vw, 2.6rem) !important; }

    .journey-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .journey-card { border-left: none !important; border-bottom: 1px solid var(--rule) !important; }

    .rev-mosaic, .phases-grid, .fin-grid { grid-template-columns: 1fr !important; }
    .rev-tile--hero { grid-column: 1 !important; }

    .kpi-strip { margin-top: 3rem !important; padding: 2.5rem 1rem !important; }
    .kpi-num { font-size: 1.6rem !important; }
    .kpi-label { font-size: .58rem !important; letter-spacing: .3em !important; }
}

/* Touch-device: kill cursor and all hover flourishes */
@media (hover: none), (pointer: coarse) {
    .cur-dot, .cur-ring { display: none !important; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .marquee-track { animation: none !important; }
}
