/* ============================================================
   COCOBOLO — Exotic Woodworks & Crafts
   Dark-premium stylesheet
   ============================================================ */

/* ---- Jakarta Sans (licensed) — uncomment after adding .woff2 to /fonts/.
   Until then, Plus Jakarta Sans (the free "Jakarta Sans") loads from Google.
@font-face { font-family:"Jakarta Sans"; src:url("../fonts/JakartaSans-Light.woff2") format("woff2"); font-weight:300; font-display:swap; }
@font-face { font-family:"Jakarta Sans"; src:url("../fonts/JakartaSans-Regular.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Jakarta Sans"; src:url("../fonts/JakartaSans-Medium.woff2") format("woff2"); font-weight:500; font-display:swap; }
------------------------------------------------------------- */

/* ===================== TOKENS ===================== */
:root {
  /* brand constants (same in both themes) */
  --brown:     #5e2c24;
  --brown-lite:#7c3a2f;
  --cream:     #f2ece3;

  /* ---- LIGHT theme (default — the original Cocobolo brand) ---- */
  --bg:        #f9f8f6;   /* page */
  --bg-2:      #f1efe9;   /* alt sections */
  --surface:   #ffffff;   /* cards */
  --surface-2: #efece5;   /* inputs / raised */
  --text:      #222222;
  --muted:     #6c6660;
  --faint:     #cfc8bd;   /* manifest soft words */
  --olive:     #828c51;
  --wood:      #5e2c24;   /* ACCENT — brand brown in light */
  --wood-deep: #451f19;
  --wood-ink:  #f9f8f6;   /* text/icon that sits ON the accent fill */
  --line:      rgba(34,34,34,.12);
  --line-2:    rgba(34,34,34,.06);
  --header-bg: rgba(249,248,246,.82);

  --font: "Jakarta Sans","Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  --radius:    18px;
  --radius-sm: 12px;
  --container: 1440px;
  --pad:       clamp(1.25rem,5vw,4.5rem);
  --section:   clamp(5rem,11vw,11rem);

  --ease:    cubic-bezier(.22,1,.36,1);
  --ease-io: cubic-bezier(.65,.05,.36,1);
  --header-h: 80px;
}

/* ---- DARK theme ---- */
[data-theme="dark"] {
  --bg:        #15110d;
  --bg-2:      #1b1610;
  --surface:   #211a14;
  --surface-2: #2b221b;
  --text:      #f2ece3;
  --muted:     #a89d8e;
  --faint:     #6b6052;
  --olive:     #8e9a5a;
  --wood:      #c79a5e;   /* ACCENT — warm amber in dark */
  --wood-deep: #a87b41;
  --wood-ink:  #1a130d;
  --line:      rgba(242,236,227,.12);
  --line-2:    rgba(242,236,227,.06);
  --header-bg: rgba(21,17,13,.72);
}

/* Sections that stay dark in BOTH themes (cinematic) — pin light-on-dark tokens locally */
.hero,.story,.editorial,.mat3d,.why,.footer {
  --text:#f2ece3; --muted:rgba(242,236,227,.66);
  --line:rgba(242,236,227,.12); --line-2:rgba(242,236,227,.06);
  --surface:rgba(242,236,227,.05); --surface-2:rgba(242,236,227,.09);
  --wood:#c79a5e; --wood-deep:#a87b41; --wood-ink:#1a130d; --olive:#8e9a5a;
}

/* ===================== RESET ===================== */
*,*::before,*::after { box-sizing:border-box; }
* { margin:0; }
html { -webkit-text-size-adjust:100%; scroll-padding-top:var(--header-h); overflow-x:clip; }
html.lenis,html.lenis body { height:auto; }
.lenis.lenis-smooth { scroll-behavior:auto !important; }
.lenis.lenis-stopped { overflow:hidden; }

body {
  font-family:var(--font);
  font-weight:400;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:clamp(1rem,.97rem + .15vw,1.0625rem);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:clip;
}
body::before {
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
input,textarea { font:inherit; color:inherit; }
ul,ol { list-style:none; padding:0; }
::selection { background:var(--wood); color:var(--wood-ink); }
:focus-visible { outline:2px solid var(--wood); outline-offset:3px; border-radius:2px; }

/* ===================== LAYOUT ===================== */
.container { width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }
.section { padding-block:var(--section); position:relative; z-index:2; }

.section__label {
  font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--wood);
  display:inline-flex; align-items:center; gap:.7em; margin-bottom:1.5rem; font-weight:500;
}
.section__label::before { content:""; width:26px; height:1px; background:var(--wood); }
.section__title { font-weight:300; font-size:clamp(2rem,1.1rem + 3.4vw,3.8rem); line-height:1.06; letter-spacing:-.03em; max-width:20ch; color:var(--text); }
.section__title--sm { font-size:clamp(1.5rem,1rem + 2vw,2.5rem); }
.section__head { display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; margin-bottom:clamp(2.5rem,5vw,4.5rem); flex-wrap:wrap; }
.section__link { position:relative; white-space:nowrap; padding-bottom:4px; color:var(--wood); font-weight:500; }
.section__link::after { content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background:var(--wood); transform:scaleX(0); transform-origin:right; transition:transform .5s var(--ease); }
.section__link:hover::after { transform:scaleX(1); transform-origin:left; }

/* split-text helpers */
.ln { display:block; overflow:hidden; padding-bottom:.06em; }
.ln-i { display:block; }
.wd { display:inline-block; }
.wd-i { display:inline-block; transform:translateY(.55em); opacity:0; transition:transform .8s var(--ease),opacity .8s var(--ease); }
[data-split].in-view .wd-i { transform:none; opacity:1; }
.mwd { display:inline-block; color:var(--faint); transition:color .35s var(--ease); }
.manifest__text.in-view .mwd { color:var(--text); }
body.no-gsap .steps__line i { width:100%; }

/* ===================== BUTTONS ===================== */
.btn {
  --bg-btn:var(--wood); --fg:var(--wood-ink);
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  padding:1.05em 1.95em; border-radius:100px; font-weight:600; font-size:.95rem; letter-spacing:.01em; line-height:1;
  position:relative; overflow:hidden; isolation:isolate;
  transition:transform .5s var(--ease),color .4s var(--ease),border-color .4s var(--ease);
}
.btn--sm { padding:.78em 1.45em; font-size:.85rem; }
.btn--full { width:100%; }
.btn--solid { background:var(--bg-btn); color:var(--fg); }
.btn--solid::before { content:""; position:absolute; inset:0; z-index:-1; background:var(--wood-deep); transform:translateY(101%); transition:transform .5s var(--ease); }
.btn--solid:hover { transform:translateY(-3px); }
.btn--solid:hover::before { transform:translateY(0); }
.btn--ghost,.btn--line { background:transparent; color:var(--text); border:1px solid var(--line); font-weight:500; }
.btn--ghost::before,.btn--line::before { content:""; position:absolute; inset:0; z-index:-1; background:var(--cream); transform:translateY(101%); transition:transform .5s var(--ease); }
.btn--ghost:hover,.btn--line:hover { color:#1a130d; border-color:var(--cream); transform:translateY(-3px); }
.btn--ghost:hover::before,.btn--line:hover::before { transform:translateY(0); }
.magnetic { will-change:transform; }

/* ===================== LOGO ===================== */
.logo { display:inline-flex; align-items:center; line-height:0; }
.logo__img { height:42px; width:auto; display:block; }
.logo__img--color { display:none; }
.logo--lg .logo__img { height:44px; }
.loader__logo .logo__img { height:54px; }
/* header logo: white over the dark hero, colour once scrolled onto light (light theme), white when scrolled in dark theme */
.header.is-scrolled .logo__img--white { display:none; }
.header.is-scrolled .logo__img--color { display:block; }
[data-theme="dark"] .header.is-scrolled .logo__img--white { display:block; }
[data-theme="dark"] .header.is-scrolled .logo__img--color { display:none; }
body.menu-open .header .logo__img--white { display:block; }
body.menu-open .header .logo__img--color { display:none; }
/* loader logo follows the theme (its background is the page bg) */
.loader__logo .logo__img--white { display:none; }
.loader__logo .logo__img--color { display:block; }
[data-theme="dark"] .loader__logo .logo__img--white { display:block; }
[data-theme="dark"] .loader__logo .logo__img--color { display:none; }

/* ===================== PROGRESS + CURSOR ===================== */
.progress { position:fixed; top:0; left:0; width:100%; height:3px; z-index:200; pointer-events:none; }
.progress__bar { display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--brown),var(--wood)); }

.cursor { position:fixed; top:0; left:0; z-index:300; pointer-events:none; display:none; }
.cursor__dot { position:fixed; width:7px; height:7px; background:var(--wood); border-radius:50%; transform:translate(-50%,-50%); }
.cursor__ring {
  position:fixed; width:40px; height:40px; border:1px solid rgba(199,154,94,.6); border-radius:50%;
  transform:translate(-50%,-50%); transition:width .3s var(--ease),height .3s var(--ease),background-color .3s var(--ease),border-color .3s var(--ease);
  display:flex; align-items:center; justify-content:center; font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--wood-ink); font-weight:600;
}
.cursor.is-hover .cursor__ring { width:60px; height:60px; border-color:var(--wood); }
.cursor.is-view .cursor__ring { width:92px; height:92px; background:var(--wood); border-color:var(--wood); }
@media (hover:hover) and (pointer:fine){ .cursor{display:block;} body.has-cursor,body.has-cursor a,body.has-cursor button{cursor:none;} }

/* ===================== LOADER ===================== */
.loader { position:fixed; inset:0; z-index:400; background:var(--bg); display:grid; place-items:center; transition:opacity .7s var(--ease),visibility .7s; animation:loaderFail 0s linear 4.5s forwards; }
.loader.is-done { opacity:0; visibility:hidden; pointer-events:none; }
@keyframes loaderFail { to { opacity:0; visibility:hidden; pointer-events:none; } }
.loader__inner { display:flex; flex-direction:column; align-items:center; gap:1.4rem; width:min(80vw,360px); }
.loader__logo { font-size:clamp(2rem,7vw,3.4rem); letter-spacing:-.02em; }
.loader__logo .logo__word{color:var(--text);} .loader__logo .logo__dot,.loader__logo .logo__tld{color:var(--wood);}
.loader__bar { width:100%; height:2px; background:var(--surface-2); overflow:hidden; }
.loader__bar span { display:block; height:100%; width:0%; background:var(--wood); }
.loader__count { font-size:.8rem; letter-spacing:.2em; color:var(--muted); }

/* ===================== HEADER ===================== */
.header { position:fixed; top:0; left:0; width:100%; z-index:150; transition:background-color .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s var(--ease),transform .5s var(--ease); }
.header::before { content:""; position:absolute; left:0; right:0; top:0; height:175%; pointer-events:none; z-index:-1; background:linear-gradient(to bottom, rgba(8,5,3,.5), transparent); transition:opacity .4s var(--ease); }
.header.is-scrolled::before, body.menu-open .header::before { opacity:0; }
.header__inner { display:flex; align-items:center; justify-content:space-between; height:var(--header-h); gap:1.5rem; }
.header.is-scrolled { background:var(--header-bg); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); box-shadow:0 1px 0 var(--line-2); }
[data-theme="light"] .header.is-scrolled { box-shadow:0 1px 0 rgba(255,255,255,.95); }
.header.is-scrolled .logo__word { color:var(--text); }
.header.is-scrolled .nav a { color:var(--text); }
.header.is-scrolled .lang { color:var(--muted); }
.header.is-scrolled .lang__opt.is-active { color:var(--text); }
.header.is-scrolled .burger span { background:var(--text); }
.header.is-scrolled .theme-toggle { color:var(--text); border-color:var(--line); }
body.menu-open .header .logo__word { color:var(--cream); }
body.menu-open .header .lang { color:rgba(242,236,227,.7); }
body.menu-open .header .lang__opt.is-active { color:var(--cream); }
body.menu-open .header .burger span { background:var(--cream); }
.header.is-hidden { transform:translateY(-100%); }
.nav { display:flex; gap:clamp(1.2rem,2.4vw,2.4rem); }
.nav a { position:relative; font-size:.95rem; padding:.4em 0; color:var(--cream); transition:color .3s var(--ease); }
.nav a::after { content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.nav a:hover { color:#fff; }
.nav a:hover::after { transform:scaleX(1); transform-origin:left; }
/* light header (scrolled in light theme) is too bright for white — keep hover the brand brown there */
[data-theme="light"] .header.is-scrolled .nav a:hover { color:var(--wood); }
.header__actions { display:flex; align-items:center; gap:1rem; }
.lang { display:inline-flex; align-items:center; gap:.35em; font-size:.82rem; letter-spacing:.06em; font-weight:500; color:rgba(242,236,227,.7); }
.lang__opt.is-active { color:var(--cream); } .lang__sep { opacity:.4; }
.theme-toggle { width:38px; height:38px; border-radius:50%; border:1px solid rgba(242,236,227,.3); color:var(--cream); display:grid; place-items:center; flex:none; transition:color .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease); }
.theme-toggle:hover { border-color:var(--wood); color:var(--wood); transform:rotate(12deg); }
.theme-toggle svg { width:17px; height:17px; }
.theme-toggle .ic-sun { display:none; }
[data-theme="dark"] .theme-toggle .ic-sun { display:block; }
[data-theme="dark"] .theme-toggle .ic-moon { display:none; }
.burger { display:none; width:30px; height:22px; position:relative; }
.burger span { position:absolute; left:0; width:100%; height:2px; background:var(--cream); border-radius:2px; transition:transform .4s var(--ease),opacity .3s,top .4s var(--ease); }
.burger span:nth-child(1){top:4px;} .burger span:nth-child(2){top:15px;}
body.menu-open .burger span:nth-child(1){top:10px;transform:rotate(45deg);}
body.menu-open .burger span:nth-child(2){top:10px;transform:rotate(-45deg);}
body.menu-open .header{background:transparent;box-shadow:none;backdrop-filter:none;}

/* ===================== MOBILE MENU ===================== */
.mobile-menu { position:fixed; inset:0; z-index:140; background:linear-gradient(160deg,#221610,#120d09); color:var(--cream); padding:calc(var(--header-h) + 2rem) var(--pad) 2.5rem; display:flex; flex-direction:column; justify-content:space-between; clip-path:inset(0 0 100% 0); transition:clip-path .7s var(--ease); visibility:hidden; }
body.menu-open .mobile-menu { clip-path:inset(0 0 0 0); visibility:visible; }
.mobile-menu__nav { display:flex; flex-direction:column; gap:.3rem; margin-top:auto; }
.mobile-menu__nav a { font-size:clamp(2rem,11vw,3.2rem); font-weight:300; letter-spacing:-.02em; padding:.16em 0; display:flex; align-items:baseline; gap:.6rem; opacity:0; transform:translateY(20px); }
.mobile-menu__nav a span { font-size:.8rem; color:var(--wood); letter-spacing:.1em; }
body.menu-open .mobile-menu__nav a { animation:menuIn .6s var(--ease) forwards; }
body.menu-open .mobile-menu__nav a:nth-child(1){animation-delay:.16s;}
body.menu-open .mobile-menu__nav a:nth-child(2){animation-delay:.22s;}
body.menu-open .mobile-menu__nav a:nth-child(3){animation-delay:.28s;}
body.menu-open .mobile-menu__nav a:nth-child(4){animation-delay:.34s;}
body.menu-open .mobile-menu__nav a:nth-child(5){animation-delay:.40s;}
@keyframes menuIn { to { opacity:1; transform:none; } }
.mobile-menu__foot { display:flex; flex-direction:column; gap:1rem; align-items:flex-start; margin-top:2rem; }
.mobile-menu__phone { font-size:1.1rem; opacity:.85; }

/* ===================== HERO ===================== */
.hero { position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:flex-end; padding:calc(var(--header-h) + 2rem) 0 2.4rem; overflow:hidden; z-index:2; }
.hero__bg { position:absolute; inset:-2.6%; z-index:-2; will-change:transform; transition:transform .5s var(--ease); }
.hero__bg img { width:100%; height:100%; object-fit:cover; will-change:transform; }
.hero__veil { position:absolute; inset:0; background:
  linear-gradient(to top, rgba(15,11,8,.92) 0%, rgba(15,11,8,.45) 40%, rgba(15,11,8,.35) 64%, rgba(15,11,8,.72) 100%),
  radial-gradient(120% 80% at 80% 10%, rgba(199,154,94,.10), transparent 60%); }
.hero__inner { position:relative; width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); will-change:transform; transition:transform .5s var(--ease); }
.hero__eyebrow { font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; color:var(--wood); font-weight:500; margin-bottom:1.4rem; }
.hero__title { font-weight:300; font-size:clamp(2.7rem,1rem + 7vw,7rem); line-height:.98; letter-spacing:-.04em; margin-bottom:1.5rem; color:var(--cream); max-width:15ch; }
.hero__title em { font-style:normal; color:var(--wood); }
.hero__lead { font-size:clamp(1.05rem,.96rem + .55vw,1.32rem); color:rgba(242,236,227,.82); max-width:54ch; margin-bottom:2.2rem; font-weight:300; }
.hero__actions { display:flex; gap:1rem; flex-wrap:wrap; }

.hero__cards { position:relative; width:100%; max-width:var(--container); margin:clamp(2.5rem,6vw,4rem) auto 0; padding-inline:var(--pad); display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(.8rem,1.5vw,1.2rem); }
.hcard { padding:1.3rem 1.4rem; border-radius:var(--radius-sm); border:1px solid var(--line); background:rgba(28,22,16,.45); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); transition:border-color .4s var(--ease),background-color .4s var(--ease),transform .5s var(--ease); }
.hcard:hover { border-color:rgba(199,154,94,.5); transform:translateY(-4px); }
.hcard__k { font-size:.72rem; letter-spacing:.12em; color:var(--wood); font-weight:600; }
.hcard h3 { font-weight:500; font-size:1.05rem; margin:.5rem 0 .4rem; color:var(--cream); }
.hcard p { font-size:.86rem; color:var(--muted); font-weight:300; }

.hero__scene { position:absolute; top:calc(var(--header-h) + 1.3rem); right:var(--pad); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(242,236,227,.6); z-index:1; }
.hero__scene i { color:var(--wood); font-style:normal; }
.hero__scroll { position:absolute; left:var(--pad); bottom:1.6rem; display:flex; align-items:center; gap:.8rem; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(242,236,227,.6); }
.hero__scroll-line { width:54px; height:1px; background:rgba(242,236,227,.3); position:relative; overflow:hidden; }
.hero__scroll-line::after { content:""; position:absolute; inset:0; background:var(--wood); transform:translateX(-100%); animation:scrollLine 2.2s var(--ease-io) infinite; }
@keyframes scrollLine { 50%{transform:translateX(0);} 100%{transform:translateX(100%);} }

/* hero load reveal */
body.js .hero__title .ln-i { transform:translateY(112%); }
body.js .hero__eyebrow, body.js .hero__lead, body.js .hero__actions { opacity:0; transform:translateY(22px); }
body.js .hero__cards, body.js .hero__scene, body.js .hero__scroll { opacity:0; }
body.js.is-ready .hero__title .ln-i { transform:translateY(0); transition:transform 1.1s var(--ease); }
body.js.is-ready .hero__title .ln:last-child .ln-i { transition-delay:.12s; }
body.js.is-ready .hero__eyebrow, body.js.is-ready .hero__lead, body.js.is-ready .hero__actions { opacity:1; transform:none; transition:opacity .9s var(--ease),transform .9s var(--ease); }
body.js.is-ready .hero__eyebrow { transition-delay:.15s; }
body.js.is-ready .hero__lead { transition-delay:.5s; }
body.js.is-ready .hero__actions { transition-delay:.62s; }
body.js.is-ready .hero__cards { opacity:1; transition:opacity 1s var(--ease) .8s; }
body.js.is-ready .hero__scene { opacity:1; transition:opacity 1s var(--ease) 1s; }
body.js.is-ready .hero__scroll { opacity:1; transition:opacity 1s var(--ease) 1.1s; }

/* ===================== MANIFESTO ===================== */
.manifest__text { font-weight:300; font-size:clamp(1.6rem,.9rem + 3vw,3.4rem); line-height:1.28; letter-spacing:-.02em; max-width:24ch; }

/* ===================== STORY (cinematic scroll film) ===================== */
.story { position:relative; z-index:2; background:#15110d; }
.story__pin { position:relative; padding-block:var(--section); }
.story__layers, .story__progress, .story__scene { display:none; }
.story__content { position:relative; }
.story__beat { padding:2.4rem 0; border-top:1px solid var(--line); max-width:32ch; }
.story__beat:last-child { border-bottom:1px solid var(--line); }
.story__step { font-size:.78rem; letter-spacing:.2em; color:var(--wood); }
.story__line { font-weight:300; font-size:clamp(2rem,1.2rem + 3.4vw,4rem); line-height:1.02; letter-spacing:-.03em; color:var(--cream); margin:.6rem 0 1rem; }
.story__line em { font-style:normal; color:var(--wood); }
.story__beat p { color:rgba(242,236,227,.78); font-weight:300; max-width:40ch; font-size:clamp(1rem,.95rem + .4vw,1.18rem); }
/* cinematic mode (desktop) */
.story.is-cinematic { z-index:6; }
.story.is-cinematic .story__pin { height:100svh; padding-block:0; overflow:hidden; display:flex; align-items:center; }
.story.is-cinematic .story__layers { display:block; position:absolute; inset:0; z-index:0; }
.story.is-cinematic .story__layer { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.14); transition:opacity 1.1s var(--ease),transform 6s var(--ease); }
.story.is-cinematic .story__layer.is-active { opacity:1; transform:scale(1); }
.story.is-cinematic .story__veil { display:block; position:absolute; inset:0; background:linear-gradient(90deg, rgba(15,11,8,.92) 0%, rgba(15,11,8,.55) 52%, rgba(15,11,8,.3) 100%); }
.story.is-cinematic .story__content { position:relative; z-index:1; min-height:clamp(300px,42vh,460px); }
.story.is-cinematic .story__beat { position:absolute; top:0; left:0; right:0; opacity:0; transform:translateY(48px); transition:opacity .7s var(--ease),transform .7s var(--ease); pointer-events:none; border:none; padding:0; max-width:26ch; }
.story.is-cinematic .story__beat.is-active { opacity:1; transform:none; pointer-events:auto; }
.story.is-cinematic .story__line { font-size:clamp(2.6rem,1rem + 5.5vw,6rem); }
.story.is-cinematic .story__progress { display:block; position:absolute; left:var(--pad); right:var(--pad); bottom:2.4rem; height:2px; background:rgba(242,236,227,.16); z-index:1; }
.story.is-cinematic .story__progress span { display:block; height:100%; width:25%; background:var(--wood); transition:width .4s var(--ease); }
.story.is-cinematic .story__scene { display:block; position:absolute; top:1.4rem; right:var(--pad); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(242,236,227,.65); z-index:1; }
.story.is-cinematic .story__scene i { color:var(--wood); font-style:normal; }

/* ===================== EDITORIAL (type over image) ===================== */
.editorial { position:relative; min-height:88vh; display:flex; align-items:center; overflow:hidden; z-index:2; }
.editorial__bg { position:absolute; inset:0; z-index:-2; }
.editorial__bg img { width:100%; height:100%; object-fit:cover; }
.editorial__bg::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(15,11,8,.86) 0%, rgba(15,11,8,.5) 55%, rgba(15,11,8,.3) 100%); }
.editorial__inner { position:relative; width:100%; }
.editorial__word { font-weight:300; font-size:clamp(3.5rem,8vw + 1rem,12rem); line-height:.92; letter-spacing:-.04em; color:var(--cream); }
.editorial__word em { font-style:normal; -webkit-text-stroke:1px rgba(242,236,227,.55); color:transparent; }
.editorial__sub { margin-top:1.6rem; max-width:42ch; color:rgba(242,236,227,.8); font-weight:300; font-size:clamp(1rem,.95rem + .4vw,1.2rem); }
.editorial__meta { margin-top:2rem; display:flex; gap:2.5rem; flex-wrap:wrap; }
.editorial__meta div span { display:block; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--wood); margin-bottom:.3rem; }
.editorial__meta div strong { font-weight:300; font-size:clamp(1.6rem,1rem + 1.5vw,2.4rem); color:var(--cream); letter-spacing:-.02em; }

/* ===================== ABOUT + STATS ===================== */
.about { background:var(--bg-2); }
.about__grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.about__media { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5; position:relative; }
.about__media img { width:100%; height:100%; object-fit:cover; }
.about__text p { color:rgba(242,236,227,.8); font-weight:300; font-size:clamp(1.05rem,.98rem + .4vw,1.25rem); max-width:46ch; }
.about__stats { margin-top:2.4rem; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.about__stat { background:var(--bg-2); padding:1.6rem 1.4rem; }
.about__stat span { display:block; font-weight:300; font-size:clamp(2rem,1.4rem + 1.8vw,3.2rem); letter-spacing:-.03em; color:var(--cream); }
.about__stat small { display:block; margin-top:.4rem; font-size:.85rem; color:var(--muted); }

/* ===================== AUDIENCE ===================== */
.paths { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,1.6vw,1.4rem); }
.path { position:relative; padding:2rem 1.8rem 2.2rem; border-radius:var(--radius); border:1px solid var(--line); background:var(--surface); display:flex; flex-direction:column; min-height:340px; transform-style:preserve-3d; will-change:transform; transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .6s var(--ease); }
.path:hover { box-shadow:0 40px 70px -40px rgba(0,0,0,.7); border-color:rgba(199,154,94,.35); }
.path--primary { background:linear-gradient(155deg,var(--brown),#3a1c16); border-color:var(--brown-lite); }
.path__tag { position:absolute; top:1.4rem; right:1.4rem; font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--wood-ink); background:var(--wood); padding:.4em .8em; border-radius:100px; font-weight:600; }
.path__num { font-size:.8rem; letter-spacing:.1em; color:var(--wood); font-weight:600; }
.path--primary .path__num { color:rgba(242,236,227,.7); }
.path h3 { font-weight:400; font-size:clamp(1.3rem,1.1rem + .6vw,1.7rem); letter-spacing:-.01em; margin:.9rem 0 .8rem; color:var(--text); }
.path--primary h3 { color:var(--cream); }
.path p { color:var(--muted); font-weight:300; font-size:.98rem; flex:1; }
.path--primary p { color:rgba(242,236,227,.82); }
.path__link { margin-top:1.4rem; font-weight:500; color:var(--wood); width:fit-content; position:relative; }
.path--primary .path__link { color:var(--cream); }
.path__link::after { content:""; position:absolute; left:0; bottom:-3px; width:100%; height:1px; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.path__link:hover::after { transform:scaleX(1); transform-origin:left; }

/* ===================== CAPABILITIES ===================== */
.caps { position:relative; }
.caps__list { border-top:1px solid var(--line); }
.cap { position:relative; display:grid; grid-template-columns:auto 1fr auto auto; align-items:center; gap:1.5rem; padding:clamp(1.3rem,2.6vw,2.3rem) .4rem; border-bottom:1px solid var(--line); cursor:pointer; transition:padding-left .5s var(--ease); }
.cap__index { font-size:.8rem; color:var(--wood); font-weight:600; letter-spacing:.05em; }
.cap__name { font-weight:300; font-size:clamp(1.5rem,1rem + 2.2vw,2.8rem); letter-spacing:-.02em; line-height:1.05; color:var(--text); transition:color .4s var(--ease); }
.cap__meta { justify-self:end; text-align:right; color:var(--muted); font-size:.9rem; max-width:22ch; transition:color .4s var(--ease),opacity .4s; }
.cap__arrow { font-size:1.4rem; color:var(--wood); opacity:0; transform:translateX(-10px); transition:opacity .4s var(--ease),transform .5s var(--ease); }
@media (hover:hover) and (pointer:fine){
  .caps__list:hover .cap { opacity:.4; transition:opacity .4s var(--ease),padding-left .5s var(--ease); }
  .caps__list .cap:hover { opacity:1; padding-left:1.5rem; }
  .cap:hover .cap__name { color:var(--wood); }
  .cap:hover .cap__arrow { opacity:1; transform:translateX(0); }
  .cap:hover .cap__meta { opacity:0; }
}
.caps__preview { position:fixed; top:0; left:0; width:300px; height:380px; border-radius:12px; overflow:hidden; pointer-events:none; opacity:0; z-index:60; transform:translate(-50%,-50%) scale(.92); box-shadow:0 30px 60px -25px rgba(0,0,0,.8); will-change:transform,opacity; }
.caps__preview img { width:100%; height:100%; object-fit:cover; }

/* ===================== MATERIALS — INTERACTIVE 3D ===================== */
.mat3d { position:relative; z-index:2; color:var(--cream);
  background:radial-gradient(120% 120% at 22% 10%, #2a1a12 0%, #1a120d 48%, #100b08 100%); }
.mat3d .section__label { color:var(--wood); }
.mat3d .section__label::before { background:var(--wood); }
.mat3d__hint { font-size:.78rem; letter-spacing:.06em; color:rgba(242,236,227,.5); display:inline-flex; align-items:center; gap:.6em; white-space:nowrap; }
.mat3d__hint::before { content:""; width:26px; height:1px; background:rgba(242,236,227,.4); }
.mat3d__grid { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.mat3d__stage { position:relative; aspect-ratio:1/1; max-height:60vh; border-radius:var(--radius); overflow:hidden; cursor:grab; background:radial-gradient(circle at 50% 40%, rgba(199,154,94,.12), transparent 62%); }
.mat3d__stage:active { cursor:grabbing; }
.mat3d__stage canvas { width:100% !important; height:100% !important; display:block; touch-action:pan-y; }
.mat3d__fallback { position:absolute; inset:13% 15%; border-radius:14px; display:none; background:linear-gradient(135deg,#c69a5e,#7c5026); box-shadow:0 40px 70px -30px rgba(0,0,0,.6); transition:background .5s var(--ease); }
.mat3d__fallback::after { content:""; position:absolute; inset:0; border-radius:14px; background-image:repeating-linear-gradient(95deg,rgba(0,0,0,.07) 0 2px,transparent 2px 8px); mix-blend-mode:overlay; }
.mat3d.no-webgl .mat3d__stage { cursor:default; }
.mat3d.no-webgl .mat3d__stage canvas { display:none; }
.mat3d.no-webgl .mat3d__fallback { display:block; }
.mat3d.no-webgl .mat3d__hint { display:none; }
.mat3d__badge { position:absolute; left:1.2rem; bottom:1.1rem; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cream); background:rgba(0,0,0,.4); padding:.45em .9em; border-radius:100px; pointer-events:none; }
.mat3d__tabs { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:2rem; }
.mtab { padding:.55em 1.1em; border-radius:100px; border:1px solid var(--line); font-size:.9rem; font-weight:500; color:rgba(242,236,227,.8); transition:color .35s var(--ease),background-color .35s var(--ease),border-color .35s var(--ease); }
.mtab:hover { border-color:var(--wood); color:var(--cream); }
.mtab.is-active { background:var(--wood); color:var(--wood-ink); border-color:var(--wood); }
.mat3d__panes { position:relative; }
.mpane { display:none; }
.mpane.is-active { display:block; animation:paneIn .5s var(--ease); }
@keyframes paneIn { from { opacity:0; transform:translateY(14px); } to { opacity:1; transform:none; } }
.mat3d__num { font-size:.78rem; letter-spacing:.16em; color:rgba(242,236,227,.55); }
.mpane h3 { font-weight:300; font-size:clamp(2rem,1.4rem + 2.6vw,3.4rem); letter-spacing:-.03em; line-height:1; margin:.5rem 0 1rem; color:var(--cream); }
.mpane h3 em { font-style:normal; color:var(--wood); }
.mpane p { font-size:clamp(1rem,.95rem + .35vw,1.15rem); color:rgba(242,236,227,.82); font-weight:300; max-width:46ch; }
.mat3d__tags { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.3rem; }
.mat3d__tags li { font-size:.8rem; padding:.45em .9em; border:1px solid var(--line); border-radius:100px; color:rgba(242,236,227,.9); }
.mat3d__cta { display:inline-block; margin-top:1.5rem; color:var(--cream); font-weight:500; border-bottom:1px solid rgba(242,236,227,.5); padding-bottom:3px; transition:color .4s,border-color .4s; }
.mat3d__cta:hover { color:var(--wood); border-color:var(--wood); }

/* ===================== WORK (horizontal) ===================== */
.work { padding-block:var(--section); position:relative; z-index:2; overflow:hidden; }
.work__intro { display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; margin-bottom:clamp(2.5rem,5vw,4rem); flex-wrap:wrap; }
.work__desc { color:var(--muted); max-width:46ch; font-weight:300; }
.work__viewport { overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; scroll-snap-type:x mandatory; scrollbar-width:none; }
.work__viewport::-webkit-scrollbar { display:none; }
.work__viewport.is-pinned { overflow:visible; scroll-snap-type:none; }
.work__track { display:flex; gap:clamp(1rem,1.6vw,1.6rem); padding-inline:var(--pad); width:max-content; }
.work__panel { position:relative; flex:0 0 auto; width:clamp(300px,46vw,600px); height:clamp(340px,60vh,580px); border-radius:var(--radius-sm); overflow:hidden; margin:0; scroll-snap-align:center; }
.work__panel img { width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.work__panel:hover img { transform:scale(1.05); }
.work__panel figcaption { position:absolute; left:0; right:0; bottom:0; padding:1.6rem 1.3rem 1.2rem; color:var(--cream); font-size:.92rem; font-weight:500; background:linear-gradient(to top,rgba(8,5,3,.85),transparent); display:flex; }
.work__panel figcaption span:first-child { color:var(--wood); }
.work__progress { margin:2.2rem var(--pad) 0; height:2px; background:var(--surface-2); }
.work__progress span { display:block; height:100%; width:10%; background:var(--wood); }
.work__viewport:not(.is-pinned) + .work__progress { display:none; }

/* ===================== GALLERY ===================== */
.gallery-sec { background:var(--bg-2); }
.filters { display:flex; flex-wrap:wrap; gap:.6rem; }
.filter { padding:.6em 1.25em; border-radius:100px; border:1px solid var(--line); font-size:.88rem; font-weight:500; color:var(--muted); transition:color .35s var(--ease),background-color .35s var(--ease),border-color .35s var(--ease); }
.filter:hover { border-color:var(--wood); color:var(--text); }
.filter.is-active { background:var(--wood); border-color:var(--wood); color:var(--wood-ink); }
.gallery { display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:1fr; gap:clamp(.8rem,1.5vw,1.2rem); margin-top:2.4rem; }
.gallery__item { position:relative; overflow:hidden; border-radius:var(--radius-sm); aspect-ratio:3/2; margin:0; transform-style:preserve-3d; will-change:transform; }
.gallery__item--tall { grid-row:span 2; aspect-ratio:3/4; }
.gallery__item img { width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.gallery__item:hover img { transform:scale(1.07); }
.gallery__item figcaption { position:absolute; left:0; right:0; bottom:0; padding:1.4rem 1.1rem 1rem; color:var(--cream); font-size:.9rem; font-weight:500; background:linear-gradient(to top,rgba(8,5,3,.85),transparent); display:flex; flex-direction:column; gap:.45rem; transform:translateY(8px); opacity:0; transition:transform .5s var(--ease),opacity .5s var(--ease); }
.gallery__item:hover figcaption { transform:none; opacity:1; }
.gallery__mat { align-self:flex-start; font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; background:var(--wood); color:var(--wood-ink); padding:.3em .7em; border-radius:100px; font-weight:600; }
.gallery__item.is-hidden { display:none; }

/* ===================== PROCESS ===================== */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.4rem,3vw,2.6rem); position:relative; }
.steps__line { position:absolute; top:0; left:0; right:0; height:1px; background:var(--line); }
.steps__line i { display:block; height:100%; width:0%; background:var(--wood); }
.step { position:relative; padding-top:2rem; }
.step__num { display:block; font-size:clamp(2.2rem,4vw,3.4rem); font-weight:300; color:var(--wood); letter-spacing:-.03em; line-height:1; margin-bottom:1.2rem; }
.step h3 { font-weight:400; font-size:1.2rem; margin-bottom:.6rem; letter-spacing:-.01em; color:var(--text); }
.step p { color:var(--muted); font-size:.96rem; font-weight:300; }

/* ===================== WHY ===================== */
.why { background:linear-gradient(160deg,#241710,#140e0a); color:var(--cream); overflow:hidden; }
.why .section__label { color:var(--wood); } .why .section__label::before { background:var(--wood); }
.why__inner { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.why__list { margin-top:2.2rem; display:grid; gap:.2rem; }
.why__list li { padding:1rem 0; border-top:1px solid var(--line); font-size:clamp(1.05rem,.9rem + .6vw,1.35rem); font-weight:300; display:flex; align-items:center; gap:1rem; }
.why__list li::before { content:""; width:9px; height:9px; border-radius:50%; background:var(--wood); flex:none; }
.why__list li:last-child { border-bottom:1px solid var(--line); }
.stats { display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,3vw,2.5rem); }
.stat { padding:1.8rem; border-radius:var(--radius); background:rgba(242,236,227,.04); border:1px solid var(--line); }
.stat__num { display:block; font-size:clamp(2.6rem,2rem + 3vw,4.4rem); font-weight:300; line-height:1; letter-spacing:-.04em; color:var(--cream); }
.stat__label { display:block; margin-top:.7rem; font-size:.92rem; color:rgba(242,236,227,.65); }
.marquee { margin-top:clamp(3rem,6vw,5rem); overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding-block:1.4rem; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee__track { display:inline-flex; align-items:center; gap:1.6rem; white-space:nowrap; animation:marquee 36s linear infinite; }
.marquee__track span { font-size:clamp(1.4rem,1rem + 1.8vw,2.4rem); font-weight:300; letter-spacing:-.01em; color:var(--cream); }
.marquee__track i { color:var(--wood); font-style:normal; font-size:.7em; }
@keyframes marquee { to { transform:translateX(-50%); } }

/* ===================== QUOTE ===================== */
.quote { background:var(--bg-2); text-align:center; }
.quote .section__label { justify-content:center; }
.quote__text { font-weight:300; font-size:clamp(1.5rem,1rem + 2.6vw,3rem); line-height:1.3; letter-spacing:-.02em; max-width:24ch; margin:0 auto; }
.quote__text .wd { color:var(--text); }
.quote__author { margin-top:1.6rem; color:var(--wood); font-weight:500; letter-spacing:.02em; }

/* ===================== CONTACT ===================== */
.contact__head { max-width:60ch; margin-bottom:clamp(2.5rem,5vw,4rem); }
.contact__title { font-weight:300; font-size:clamp(2rem,1.2rem + 3.6vw,4rem); line-height:1.04; letter-spacing:-.03em; margin-bottom:1.2rem; color:var(--text); }
.contact__lead { color:var(--muted); font-weight:300; max-width:50ch; }
.contact__inner { display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.contact__details { display:grid; gap:.2rem; margin-bottom:1.8rem; }
.contact__details li { display:flex; justify-content:space-between; gap:1rem; padding:1rem 0; border-top:1px solid var(--line); align-items:center; }
.contact__details li:last-child { border-bottom:1px solid var(--line); }
.contact__k { color:var(--muted); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; }
.contact__details a { font-weight:500; color:var(--text); position:relative; }
.contact__details a::after { content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1px; background:var(--wood); transform:scaleX(0); transform-origin:right; transition:transform .4s var(--ease); }
.contact__details a:hover::after { transform:scaleX(1); transform-origin:left; }
.contact__quick { display:flex; gap:.8rem; flex-wrap:wrap; }
.contact__form { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.5rem,3vw,2.5rem); display:grid; gap:1.1rem; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field { display:grid; gap:.45rem; }
.field label,.field__label { font-size:.8rem; letter-spacing:.06em; color:var(--muted); }
.field input,.field textarea { background:var(--surface-2); border:1px solid transparent; border-radius:var(--radius-sm); padding:.9em 1em; color:var(--text); transition:border-color .3s var(--ease),background-color .3s var(--ease); resize:vertical; width:100%; }
.field input::placeholder,.field textarea::placeholder { color:var(--faint); }
.field input:focus,.field textarea:focus { outline:none; border-color:var(--wood); background:#34291f; }
.chips { display:flex; gap:.5rem; flex-wrap:wrap; }
.chip { padding:.55em 1em; border-radius:100px; border:1px solid var(--line); font-size:.85rem; font-weight:500; color:var(--muted); transition:color .3s,background-color .3s,border-color .3s; }
.chip:hover { border-color:var(--wood); color:var(--text); }
.chip.is-active { background:var(--wood); border-color:var(--wood); color:var(--wood-ink); }
.contact__note { font-size:.9rem; min-height:1.2em; }
.contact__note.is-ok { color:var(--olive); } .contact__note.is-err { color:var(--wood); }

/* ===================== FOOTER ===================== */
.footer { background:#0f0b07; color:var(--cream); position:relative; z-index:2; border-top:1px solid var(--line); }
.footer__top-row { padding-top:clamp(2.2rem,4vw,3.4rem); padding-bottom:clamp(1.8rem,3.5vw,2.8rem); border-bottom:1px solid var(--line); }
.footer__cta-link { display:inline-flex; align-items:center; gap:1rem; font-weight:300; font-size:clamp(1.8rem,1rem + 2.6vw,3.2rem); letter-spacing:-.03em; color:var(--cream); }
.footer__cta-arrow { color:var(--wood); transition:transform .5s var(--ease); display:inline-block; }
.footer__cta-link:hover .footer__cta-arrow { transform:translate(8px,-8px); }
.footer__inner { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; padding-block:clamp(1.8rem,3.5vw,2.6rem); align-items:start; }
.footer__tag { margin-top:1rem; font-size:.76rem; letter-spacing:.22em; color:rgba(242,236,227,.5); }
.footer__nav,.footer__contact { display:grid; gap:.7rem; align-content:start; }
.footer__nav a,.footer__contact a { color:rgba(242,236,227,.7); width:fit-content; transition:color .3s; }
.footer__nav a:hover,.footer__contact a:hover { color:var(--cream); }
.footer__bottom { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding-block:1.6rem; border-top:1px solid var(--line); font-size:.85rem; color:rgba(242,236,227,.5); flex-wrap:wrap; }
.footer__totop { color:rgba(242,236,227,.7); } .footer__totop:hover { color:var(--cream); }

/* ===================== LIGHTBOX ===================== */
.lightbox { position:fixed; inset:0; z-index:250; background:rgba(8,5,3,.95); backdrop-filter:blur(6px); display:grid; place-items:center; padding:clamp(1rem,4vw,3rem); opacity:0; visibility:hidden; transition:opacity .4s var(--ease),visibility .4s; }
.lightbox.is-open { opacity:1; visibility:visible; }
.lightbox__figure { max-width:min(1100px,92vw); max-height:86vh; margin:0; display:flex; flex-direction:column; gap:.9rem; align-items:center; }
.lightbox__figure img { max-width:100%; max-height:78vh; object-fit:contain; border-radius:8px; transform:scale(.96); opacity:0; transition:transform .5s var(--ease),opacity .5s var(--ease); }
.lightbox.is-open .lightbox__figure img { transform:scale(1); opacity:1; }
.lightbox__figure figcaption { color:rgba(242,236,227,.8); font-size:.9rem; letter-spacing:.04em; }
.lightbox__close,.lightbox__nav { position:absolute; color:var(--cream); display:grid; place-items:center; width:54px; height:54px; border-radius:50%; background:rgba(242,236,227,.08); border:1px solid rgba(242,236,227,.18); transition:background-color .3s,transform .3s; line-height:1; }
.lightbox__close:hover,.lightbox__nav:hover { background:rgba(242,236,227,.2); }
.lightbox__close { top:clamp(1rem,3vw,2rem); right:clamp(1rem,3vw,2rem); font-size:1.8rem; }
.lightbox__nav { top:50%; transform:translateY(-50%); font-size:2rem; }
.lightbox__nav:hover { transform:translateY(-50%) scale(1.06); }
.lightbox__nav--prev { left:clamp(.5rem,2vw,2rem); } .lightbox__nav--next { right:clamp(.5rem,2vw,2rem); }

/* ===================== CHAPTER NAV ===================== */
.chapters { position:fixed; right:1.5rem; top:50%; transform:translateY(-50%); z-index:120; display:flex; flex-direction:column; gap:.8rem; align-items:flex-end; }
.chapter { display:flex; align-items:center; gap:.6rem; }
.chapter::before { content:attr(data-label); opacity:0; transform:translateX(6px); transition:opacity .35s var(--ease),transform .35s var(--ease); white-space:nowrap; color:var(--text); font-weight:500; font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; }
.chapter span { display:grid; place-items:center; width:28px; height:28px; border-radius:50%; border:1px solid rgba(242,236,227,.25); font-size:.6rem; font-weight:500; color:rgba(242,236,227,.7); background:rgba(20,14,10,.4); backdrop-filter:blur(4px); transition:background-color .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease); }
.chapter:hover::before { opacity:1; transform:none; }
.chapter:hover span { border-color:var(--wood); color:var(--wood); }
.chapter.is-active span { background:var(--wood); color:var(--wood-ink); border-color:var(--wood); transform:scale(1.08); }

/* ===================== REVEAL ===================== */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease),transform .9s var(--ease); }
.reveal.in-view { opacity:1; transform:none; }
.paths .path:nth-child(2){transition-delay:.08s;} .paths .path:nth-child(3){transition-delay:.16s;}
.why__list li:nth-child(2){transition-delay:.06s;} .why__list li:nth-child(3){transition-delay:.12s;} .why__list li:nth-child(4){transition-delay:.18s;}
.stats .stat:nth-child(2){transition-delay:.08s;} .stats .stat:nth-child(3){transition-delay:.16s;} .stats .stat:nth-child(4){transition-delay:.24s;}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1200px){ .chapters { display:none; } }
@media (max-width:1024px){
  .paths { grid-template-columns:1fr; }
  .steps { grid-template-columns:repeat(2,1fr); }
  .gallery { grid-template-columns:repeat(2,1fr); }
  .about__grid { grid-template-columns:1fr; }
  .about__media { max-width:480px; aspect-ratio:4/3; }
  .hero__cards { grid-template-columns:1fr; }
}
@media (max-width:860px){
  :root { --header-h:66px; }
  .nav,.header__cta { display:none; }
  .burger { display:block; }
  .why__inner { grid-template-columns:1fr; }
  .contact__inner { grid-template-columns:1fr; }
  .footer__inner { grid-template-columns:1fr 1fr; }
  .footer__brand { grid-column:1 / -1; }
  .cap__meta { display:none; }
  .cap { grid-template-columns:auto 1fr auto; }
  .mat3d__grid { grid-template-columns:1fr; gap:2.2rem; }
  .mat3d__stage { max-width:480px; }
  .mat3d .section__head { gap:1rem; }
}
@media (max-width:600px){
  .steps { grid-template-columns:1fr; }
  .stats { grid-template-columns:1fr 1fr; }
  .about__stats { grid-template-columns:1fr 1fr; }
  .field-row { grid-template-columns:1fr; }
  .hero__actions .btn { flex:1; }
  .work__panel { height:54vh; }
  .gallery { grid-template-columns:repeat(2,1fr); }
  .gallery__item--tall { grid-row:span 1; aspect-ratio:3/2; }
  .footer__bottom { flex-direction:column; align-items:flex-start; }
}

/* ===================== REDUCED MOTION ===================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal { opacity:1; transform:none; }
  .manifest__text .mwd { color:var(--text); }
  .cursor { display:none !important; } body.has-cursor { cursor:auto; }
}
