@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;1,9..144,300;1,9..144,400&family=Work+Sans:wght@300;400;500&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --warm-grey:#eae6e0;
  --smoke:#d8d4ce;
  --charcoal:#1e1c1a;
  --deep-char:#121110;
  --concrete:#8a8580;
  --copper:#b07845;
  --copper-muted:rgba(176,120,69,0.3);
  --text-light:rgba(255,255,255,0.7);
  --text-dark:#1e1c1a;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Work Sans',-apple-system,sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
}
html{scroll-behavior:smooth;overflow-x:hidden;background:var(--deep-char)}
body{font-family:var(--sans);color:var(--warm-grey);background:var(--deep-char);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--copper-muted);color:var(--warm-grey)}
img{max-width:100%;display:block}

/* ── LOADER ── */
.loader{position:fixed;inset:0;z-index:9999;background:var(--deep-char);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;transition:opacity 1.2s var(--ease),visibility 1.2s}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-line{width:60px;height:1px;background:rgba(255,255,255,0.08);position:relative;overflow:hidden}
.loader-line::after{content:'';position:absolute;inset:0;background:var(--copper);animation:sweep 1.8s ease-in-out infinite}
@keyframes sweep{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.loader-text{font-family:var(--sans);font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,0.25)}

/* ── CURSOR ── */
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;border-radius:50%;background:var(--copper);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:opacity .3s,transform .2s;will-change:transform;opacity:0}
.cursor-ring{position:fixed;top:0;left:0;width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(176,120,69,0.55);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:opacity .3s,width .35s var(--ease),height .35s var(--ease),border-color .35s;will-change:transform;opacity:0}
.cursor-dot.visible,.cursor-ring.visible{opacity:1}
.cursor-dot.hover{transform:translate(-50%,-50%) scale(2.5)}
.cursor-ring.hover{width:52px;height:52px;border-color:rgba(176,120,69,0.25)}
@media(hover:none),(max-width:1024px){.cursor-dot,.cursor-ring{display:none!important}}

/* ── SCROLL PROGRESS ── */
.progress{position:fixed;top:0;left:0;height:2px;background:var(--copper);z-index:9997;width:0;pointer-events:none}

/* ── NAV (editorial minimal) ── */
.nav{position:fixed;top:0;left:0;width:100%;z-index:105;padding:1.8rem 3rem;display:flex;align-items:center;justify-content:space-between;pointer-events:none;transition:background .4s ease,backdrop-filter .4s ease}
.nav *{pointer-events:auto}
.nav.scrolled{background:rgba(18,17,16,0.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.nav-logo{font-family:var(--serif);font-size:1.4rem;font-weight:300;color:#fff;text-decoration:none;letter-spacing:-.01em;opacity:.95}
.nav-logo em{font-style:italic;color:var(--copper)}
.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:106}
.hamburger span{display:block;width:24px;height:1px;background:#fff;transition:all .3s ease}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Full-screen menu overlay */
.full-menu{position:fixed;inset:0;z-index:104;background:var(--deep-char);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;visibility:hidden;transition:opacity .6s var(--ease),visibility .6s}
.full-menu.open{opacity:1;visibility:visible}
.full-menu a{font-family:var(--serif);font-size:clamp(2.5rem,6vw,4.5rem);font-weight:300;color:rgba(255,255,255,0.2);text-decoration:none;line-height:1.3;transition:color .4s ease,transform .4s var(--ease);display:block;padding:.2rem 0}
.full-menu a:hover{color:#fff;transform:translateX(10px)}
.full-menu-footer{position:absolute;bottom:3rem;left:3rem;right:3rem;display:flex;justify-content:space-between;align-items:flex-end}
.full-menu-footer span{font-family:var(--sans);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,0.2)}
.full-menu-social{display:flex;gap:2rem}
.full-menu-social a{font-family:var(--sans)!important;font-size:.7rem!important;letter-spacing:.15em;text-transform:uppercase;color:var(--copper)!important}
.full-menu-social a:hover{color:#fff!important}

/* ── HERO (cinematic full-screen) ── */
.hero{position:relative;height:100vh;height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--deep-char)}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%;filter:brightness(.4) contrast(1.05) saturate(.9);transform:scale(1.15);transition:transform 12s var(--ease)}
.hero.loaded .hero-bg img{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:
  radial-gradient(ellipse 80% 60% at 50% 50%,transparent 0%,rgba(18,17,16,.6) 100%),
  linear-gradient(to top,rgba(18,17,16,.9) 0%,transparent 40%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:900px;padding:0 2rem}
.hero-tag{font-family:var(--sans);font-size:.6rem;letter-spacing:.5em;text-transform:uppercase;color:var(--copper);margin-bottom:2rem;opacity:0;transform:translateY(20px)}
.hero-title{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,7vw,6.5rem);line-height:1;letter-spacing:-.03em;color:#fff;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--copper)}
.hero-sub{font-family:var(--sans);font-size:clamp(.85rem,1.2vw,1rem);line-height:1.8;color:rgba(255,255,255,0.5);max-width:500px;margin:0 auto;opacity:0;transform:translateY(20px)}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.8rem}
.hero-scroll span{font-family:var(--sans);font-size:.5rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,0.2)}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.2),transparent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.6)}}
.word{display:inline-block;opacity:0;transform:translateY(20px)}.word.visible{opacity:1;transform:translateY(0);transition:opacity .6s var(--ease),transform .6s var(--ease)}

/* ── MARQUEE TEXT STRIP ── */
.marquee{overflow:hidden;padding:1.2rem 0;border-top:1px solid rgba(255,255,255,0.04);border-bottom:1px solid rgba(255,255,255,0.04);background:var(--deep-char)}
.marquee-track{display:flex;gap:0;animation:marquee 30s linear infinite;width:max-content}
.marquee-item{font-family:var(--serif);font-size:clamp(.8rem,1.2vw,1rem);font-weight:300;font-style:italic;color:rgba(255,255,255,0.12);white-space:nowrap;padding:0 3rem;display:flex;align-items:center;gap:3rem}
.marquee-item::after{content:'·';color:var(--copper-muted);font-style:normal}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── CHAPTER SECTIONS ── */
.chapter{padding:clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem);position:relative}
.chapter-inner{max-width:1200px;margin:0 auto}
.chapter-number{font-family:var(--sans);font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;color:var(--copper);margin-bottom:3rem;display:flex;align-items:center;gap:1.5rem}
.chapter-number::after{content:'';flex:1;height:1px;background:rgba(176,120,69,0.15);max-width:200px}
.chapter-headline{font-family:var(--serif);font-weight:300;font-size:clamp(2rem,4.5vw,4rem);line-height:1.15;color:#fff;max-width:800px;margin-bottom:2rem;letter-spacing:-.02em}
.chapter-headline em{font-style:italic;color:var(--copper)}
.chapter-body{font-family:var(--sans);font-size:clamp(.88rem,1.1vw,1rem);line-height:1.8;color:rgba(255,255,255,0.5);max-width:600px}

/* ── FULL-BLEED IMAGE BREAK ── */
.image-break{position:relative;height:60vh;min-height:400px;overflow:hidden}
.image-break img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) contrast(1.05)}
.image-break-caption{position:absolute;bottom:2rem;left:3rem;font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,0.35)}

/* ── STACKED IMAGE + TEXT ── */
.story-block{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:80vh}
.story-block-image{position:relative;overflow:hidden}
.story-block-image img{width:100%;height:100%;object-fit:cover;min-height:500px;filter:brightness(.75) contrast(1.05);transition:transform 1.5s var(--ease)}
.story-block-image:hover img{transform:scale(1.03)}
.story-block-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(3rem,6vw,6rem);background:var(--charcoal)}

/* ── HORIZONTAL SCROLL FILM STRIP ── */
.filmstrip{padding:clamp(4rem,8vw,6rem) 0;overflow:hidden}
.filmstrip-label{font-family:var(--sans);font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;color:var(--copper);margin-bottom:2.5rem;padding-left:clamp(1.5rem,5vw,4rem);display:flex;align-items:center;gap:1.5rem}
.filmstrip-label::after{content:'';flex:1;height:1px;background:rgba(176,120,69,0.15);max-width:300px}
.filmstrip-track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 clamp(1.5rem,5vw,4rem) 2rem;scrollbar-width:none;cursor:grab}
.filmstrip-track:active{cursor:grabbing}
.filmstrip-track::-webkit-scrollbar{display:none}
.filmstrip-frame{flex-shrink:0;width:clamp(280px,30vw,420px);scroll-snap-align:start;position:relative;overflow:hidden;border-radius:3px}
.filmstrip-frame img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform 1s var(--ease);filter:brightness(.85) contrast(1.05)}
.filmstrip-frame:hover img{transform:scale(1.05)}
.filmstrip-frame-caption{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;background:linear-gradient(transparent,rgba(18,17,16,.85));font-family:var(--sans);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,0.6);transform:translateY(100%);transition:transform .5s var(--ease)}
.filmstrip-frame:hover .filmstrip-frame-caption{transform:translateY(0)}

/* ── STATS BAND ── */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,0.06);border-bottom:1px solid rgba(255,255,255,0.06)}
.stat{text-align:center;padding:clamp(2.5rem,5vw,4rem) 1rem;border-right:1px solid rgba(255,255,255,0.06)}
.stat:last-child{border-right:none}
.stat-val{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;color:#fff;letter-spacing:-.02em;margin-bottom:.4rem}
.stat-lbl{font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--concrete)}

/* ── QUOTE BLOCK ── */
.quote-section{padding:clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem);text-align:center}
.quote-mark{font-family:var(--serif);font-size:5rem;color:var(--copper-muted);line-height:1;margin-bottom:1rem}
.quote-text{font-family:var(--serif);font-size:clamp(1.2rem,2.5vw,2rem);font-weight:300;font-style:italic;line-height:1.5;color:rgba(255,255,255,0.7);max-width:750px;margin:0 auto 2rem}
.quote-cite{font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper)}

/* ── CONTACT ── */
.contact-section{padding:clamp(5rem,10vw,8rem) clamp(1.5rem,5vw,4rem);text-align:center}
.contact-headline{font-family:var(--serif);font-weight:300;font-size:clamp(2.5rem,5vw,5rem);line-height:1.1;color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em}
.contact-sub{font-family:var(--sans);font-size:clamp(.85rem,1.1vw,1rem);color:rgba(255,255,255,0.4);max-width:450px;margin:0 auto 2.5rem;line-height:1.7}
.contact-btn{font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);text-decoration:none;padding:1rem 2.5rem;border:1px solid var(--copper-muted);display:inline-block;transition:all .5s var(--ease)}
.contact-btn:hover{background:var(--copper);color:var(--deep-char);border-color:var(--copper)}
.contact-links{display:flex;gap:2.5rem;justify-content:center;margin-top:2rem}
.contact-links a{font-family:var(--sans);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,0.3);text-decoration:none;transition:color .3s ease}
.contact-links a:hover{color:var(--copper)}

/* ── FOOTER (minimal) ── */
.footer{padding:3rem clamp(1.5rem,5vw,4rem);border-top:1px solid rgba(255,255,255,0.04)}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-left{font-family:var(--sans);font-size:.6rem;letter-spacing:.1em;color:rgba(255,255,255,0.15)}
.footer-right{display:flex;gap:2rem}
.footer-right a{font-family:var(--sans);font-size:.6rem;color:rgba(255,255,255,0.15);text-decoration:none;transition:color .3s ease}
.footer-right a:hover{color:rgba(255,255,255,0.4)}

/* ── REVEALS ── */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-scale{opacity:0;transform:scale(.95);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── WORD REVEAL ── */
[data-word-reveal] .word{opacity:.1}[data-word-reveal] .word.visible{opacity:1}

/* ══════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════ */
@media(max-width:1024px){
  .nav{padding:1.5rem 2rem}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .story-block{min-height:auto}
}
@media(max-width:768px){
  .nav{padding:1rem 1.2rem}
  .hero-title{font-size:clamp(2.2rem,10vw,3.5rem)}
  .hero-sub{font-size:.85rem}
  .hero-scroll{display:none}
  .story-block{grid-template-columns:1fr}
  .story-block-image img{min-height:300px}
  .story-block-text{padding:clamp(2.5rem,5vw,4rem)}
  .chapter{padding:clamp(3.5rem,8vw,5rem) 1.2rem}
  .chapter-headline{font-size:clamp(1.6rem,6vw,2.4rem)}
  .image-break{height:45vh;min-height:280px}
  .image-break-caption{left:1.2rem;bottom:1.2rem}
  .stats-band{grid-template-columns:1fr 1fr}
  .filmstrip-frame{width:clamp(240px,70vw,320px)}
  .contact-headline{font-size:clamp(1.8rem,8vw,3rem)}
  .contact-links{flex-direction:column;gap:1rem}
  .footer-inner{flex-direction:column;gap:1rem;text-align:center}
  .footer-right{gap:1.5rem}
}
@media(max-width:480px){
  .hero{min-height:auto;height:100svh}
  .hero-tag{font-size:.5rem;letter-spacing:.35em}
  .stats-band{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06);padding:2rem 1rem}
  .stat:last-child{border-bottom:none}
  .marquee-item{font-size:.75rem;padding:0 2rem}
  .nav{padding:.8rem 1rem}
}
