/* =============================================================
   COSTA MOTOR — Defender restoration atelier · Barcelona
   v3 · Cinematic Dark · Full rebuild
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;background:#060402}
body{min-height:100vh}
img,picture,video{display:block;max-width:100%;height:auto}
button{background:0;border:0;cursor:pointer;font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
input,select,textarea,button{font:inherit;color:inherit}
ul,ol{list-style:none}
video{background:#060402}

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --void:#060402;
  --deep:#0A0705;
  --char:#140F0A;
  --raised:#1A140D;
  --warm:#241B10;

  --ink:#F4EEE0;
  --ink-90:rgba(244,238,224,.90);
  --ink-70:rgba(244,238,224,.70);
  --ink-55:rgba(244,238,224,.55);
  --ink-40:rgba(244,238,224,.40);
  --ink-25:rgba(244,238,224,.25);
  --ink-14:rgba(244,238,224,.14);
  --ink-08:rgba(244,238,224,.08);
  --ink-04:rgba(244,238,224,.04);

  --oxide:#C85A33;
  --oxide-soft:#B04929;
  --oxide-glow:rgba(200,90,51,.35);
  --amber:#D4A366;

  --serif:'Fraunces','Times New Roman',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;

  --s--1:clamp(.78rem,.76rem + .08vw,.85rem);
  --s-0:clamp(.95rem,.92rem + .15vw,1.05rem);
  --s-1:clamp(1.10rem,1.05rem + .25vw,1.30rem);
  --s-2:clamp(1.40rem,1.20rem + .85vw,1.85rem);
  --s-3:clamp(1.90rem,1.50rem + 1.80vw,3.00rem);
  --s-4:clamp(2.60rem,1.90rem + 3.20vw,4.75rem);
  --s-5:clamp(3.40rem,2.30rem + 5.50vw,7.00rem);
  --s-6:clamp(4.20rem,2.50rem + 8.00vw,9.50rem);
  --s-7:clamp(5.00rem,2.80rem + 11.00vw,13.00rem);

  --gutter:clamp(20px,4vw,48px);
  --col-max:1720px;
  --ease:cubic-bezier(.2,.6,.2,1);
  --ease-long:cubic-bezier(.19,1,.22,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --d1:200ms;
  --d2:460ms;
  --d3:900ms;
  --d4:1600ms;
}

body{
  background:var(--void);
  color:var(--ink);
  font-family:var(--sans);
  font-size:var(--s-0);
  font-weight:350;
  line-height:1.55;
  letter-spacing:-.008em;
  overflow-x:hidden;
}
::selection{background:var(--oxide);color:var(--ink)}

/* ============================================================
   PRELOADER — logo draws in, fills, wipes away to reveal hero
   ============================================================ */
.preloader{
  position:fixed;
  inset:0;
  background:var(--void);
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity 700ms var(--ease),visibility 700ms step-end;
}
.preloader.is-done{
  opacity:0;
  visibility:hidden;
  transition:opacity 700ms var(--ease),visibility 700ms step-end 700ms;
}
.preloader__mark{
  width:min(180px,32vw);
  aspect-ratio:1;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.preloader__mark img{
  width:100%;
  height:100%;
  object-fit:contain;
  opacity:0;
  transform:scale(.92);
  transition:opacity 900ms var(--ease),transform 900ms var(--ease);
}
.preloader.is-shown .preloader__mark img{
  opacity:1;
  transform:scale(1);
}
.preloader__ring{
  position:absolute;
  inset:-10%;
  border:1px solid var(--ink-25);
  border-radius:50%;
  opacity:0;
  transition:opacity 600ms var(--ease) 300ms,transform 2200ms var(--ease-long);
}
.preloader.is-shown .preloader__ring{
  opacity:1;
  transform:scale(1.15);
}
.preloader__progress{
  position:absolute;
  bottom:14%;
  left:50%;
  transform:translateX(-50%);
  width:120px;
  height:1px;
  background:var(--ink-14);
  overflow:hidden;
}
.preloader__progress::after{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:0%;
  background:var(--oxide);
  animation:preload 1400ms var(--ease) forwards;
}
@keyframes preload{
  0%{width:0%}
  100%{width:100%}
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.eyebrow{
  font-family:var(--sans);
  font-size:var(--s--1);
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.eyebrow--oxide{color:var(--oxide)}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:24px;
  height:1px;
  background:currentColor;
  opacity:.6;
}
.eyebrow.no-rule::before{display:none}

h1,h2,h3,h4,.serif{
  font-family:var(--serif);
  font-weight:300;
  line-height:1.02;
  letter-spacing:-.024em;
  font-variation-settings:"opsz" 144,"SOFT" 30;
  color:var(--ink);
}
.h0{font-size:var(--s-7);line-height:.92;letter-spacing:-.042em;font-weight:300}
h1,.h1{font-size:var(--s-6);line-height:.94;letter-spacing:-.036em}
h2,.h2{font-size:var(--s-5);line-height:.98;letter-spacing:-.030em}
h3,.h3{font-size:var(--s-4);line-height:1.02;letter-spacing:-.022em}
h4,.h4{font-size:var(--s-3);line-height:1.08;letter-spacing:-.016em}
h5,.h5{font-size:var(--s-2);line-height:1.14;letter-spacing:-.010em}
.italic{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100}

.lede{
  font-family:var(--serif);
  font-weight:300;
  font-size:var(--s-2);
  line-height:1.30;
  letter-spacing:-.012em;
  max-width:34ch;
  color:var(--ink-90);
}
.body{
  font-weight:350;
  line-height:1.65;
  max-width:58ch;
  color:var(--ink-70);
}
.body p+p{margin-top:1.15em}
.body strong{color:var(--ink);font-weight:500}

.numeral{
  font-family:var(--serif);
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  color:var(--oxide);
}

/* Word reveal — split into lines, translate up */
/* reveal-text: visible by default; only hidden-before-animation when JS is ready */
.reveal-text{display:inline-block;overflow:hidden;vertical-align:baseline}
.reveal-text > span{display:inline-block;transform:translateY(0);opacity:1;transition:transform 1100ms var(--ease-long),opacity 900ms var(--ease)}
.js-ready .reveal-text:not(.is-in) > span{transform:translateY(110%);opacity:0}
.js-ready .reveal-text.is-in > span{transform:translateY(0);opacity:1}
.reveal-text[data-delay="1"] > span{transition-delay:80ms}
.reveal-text[data-delay="2"] > span{transition-delay:180ms}
.reveal-text[data-delay="3"] > span{transition-delay:280ms}
.reveal-text[data-delay="4"] > span{transition-delay:380ms}
.reveal-text[data-delay="5"] > span{transition-delay:500ms}
.reveal-text[data-delay="6"] > span{transition-delay:640ms}

/* fade-in: visible by default, only hidden if JS is working AND hasn't revealed yet */
.fade-in{opacity:1;transform:none;transition:opacity 900ms var(--ease-long),transform 900ms var(--ease-long)}
.js-ready .fade-in:not(.is-in){opacity:0;transform:translateY(16px)}
.js-ready .fade-in.is-in{opacity:1;transform:translateY(0)}
.fade-in[data-delay="1"]{transition-delay:120ms}
.fade-in[data-delay="2"]{transition-delay:240ms}
.fade-in[data-delay="3"]{transition-delay:360ms}
.fade-in[data-delay="4"]{transition-delay:480ms}
.fade-in[data-delay="5"]{transition-delay:600ms}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.shell{width:100%;max-width:var(--col-max);margin:0 auto;padding:0 var(--gutter)}
.shell--tight{max-width:1200px}
.shell--prose{max-width:780px}

.section{padding:clamp(80px,10vw,160px) 0}
.section--lg{padding:clamp(120px,14vw,220px) 0}

.hairline{height:1px;background:var(--ink-14);border:0;width:100%}

/* ============================================================
   PROGRESS BAR
   ============================================================ */
.progress{
  position:fixed;
  top:0;left:0;
  height:2px;
  background:var(--oxide);
  z-index:120;
  transition:width 90ms linear;
  width:0;
  pointer-events:none;
  box-shadow:0 0 12px var(--oxide-glow);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:20px var(--gutter);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  background:transparent;
  transition:background var(--d2) var(--ease),padding var(--d2) var(--ease),border-color var(--d2) var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(6,4,2,.78);
  backdrop-filter:blur(18px) saturate(1.1);
  -webkit-backdrop-filter:blur(18px) saturate(1.1);
  border-bottom-color:var(--ink-08);
  padding-top:14px;
  padding-bottom:14px;
}
.nav__brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:var(--ink);
  line-height:1;
  transition:opacity var(--d2) var(--ease);
}
.nav__brand img{
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--ink);
  padding:2px;
  transition:width var(--d2) var(--ease),height var(--d2) var(--ease);
}
.nav.is-scrolled .nav__brand img{width:36px;height:36px}
.nav__brand .wordmark{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.12rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
}
.nav__brand .wordmark em{
  font-style:normal;
  color:var(--oxide);
  margin:0 3px;
}
.nav__links{
  display:flex;
  align-items:center;
  gap:44px;
}
.nav__link{
  font-size:.78rem;
  font-weight:400;
  letter-spacing:.14em;
  text-transform:uppercase;
  position:relative;
  padding:6px 0;
  color:var(--ink-70);
  transition:color var(--d1) var(--ease);
}
.nav__link::after{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:-2px;
  height:1px;
  background:var(--oxide);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform var(--d2) var(--ease);
}
.nav__link:hover,.nav__link.is-active{color:var(--ink)}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1)}

.nav__right{display:inline-flex;align-items:center;gap:28px}
.nav__lang{
  display:inline-flex;
  align-items:center;
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
}
.nav__lang button{
  padding:6px 4px;
  color:var(--ink-40);
  transition:color var(--d1) var(--ease);
}
.nav__lang button[aria-pressed="true"]{color:var(--ink)}
.nav__lang .sep{opacity:.3;padding:0 2px}

.nav__burger{
  display:none;
  width:32px;height:22px;
  position:relative;
  color:var(--ink);
}
.nav__burger span{
  position:absolute;
  left:0;right:0;
  height:1px;
  background:currentColor;
  transition:transform var(--d2) var(--ease),top var(--d2) var(--ease);
}
.nav__burger span:nth-child(1){top:8px}
.nav__burger span:nth-child(2){top:14px}
.nav.is-menu-open .nav__burger span:nth-child(1){top:11px;transform:rotate(45deg)}
.nav.is-menu-open .nav__burger span:nth-child(2){top:11px;transform:rotate(-45deg)}

.mobile-menu{
  position:fixed;
  inset:0;
  background:var(--void);
  z-index:90;
  padding:130px var(--gutter) 48px;
  transform:translateY(-101%);
  transition:transform var(--d3) var(--ease-long);
  display:flex;
  flex-direction:column;
  gap:8px;
  pointer-events:none;
  visibility:hidden;
}
.mobile-menu.is-open{
  transform:translateY(0);
  pointer-events:auto;
  visibility:visible;
}
.mobile-menu a{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.2rem,8vw,3.6rem);
  line-height:1.1;
  letter-spacing:-.022em;
  padding:14px 0;
  border-bottom:1px solid var(--ink-08);
  color:var(--ink);
  transition:color var(--d1) var(--ease),padding-left var(--d2) var(--ease);
}
.mobile-menu a:hover{color:var(--oxide);padding-left:12px}

/* Language toggle inside mobile drawer */
.mobile-menu__lang{
  margin-top:auto;
  padding-top:48px;
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.mobile-menu__lang button{
  background:none;
  border:none;
  color:var(--ink-55);
  font-family:inherit;
  font-size:inherit;
  letter-spacing:inherit;
  text-transform:inherit;
  padding:8px 4px;
  cursor:pointer;
  transition:color var(--d1) var(--ease);
}
.mobile-menu__lang button[aria-pressed="true"]{color:var(--oxide)}
.mobile-menu__lang button:hover{color:var(--ink)}
.mobile-menu__lang .sep{color:var(--ink-25)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:16px 28px;
  color:var(--ink);
  border:1px solid var(--ink);
  background:transparent;
  position:relative;
  overflow:hidden;
  transition:color var(--d2) var(--ease),border-color var(--d2) var(--ease);
}
.btn::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--ink);
  transform:translateX(-101%);
  transition:transform var(--d2) var(--ease-out);
  z-index:-1;
}
.btn:hover{color:var(--void)}
.btn:hover::before{transform:translateX(0)}
.btn .arrow{transition:transform var(--d2) var(--ease-long)}
.btn:hover .arrow{transform:translateX(4px)}

.btn--oxide{color:var(--ink);border-color:var(--oxide);background:var(--oxide)}
.btn--oxide::before{background:var(--ink)}
.btn--oxide:hover{color:var(--void);border-color:var(--ink)}

.btn--ghost{border-color:var(--ink-25);color:var(--ink-90)}
.btn--ghost::before{background:var(--ink)}

.link-underline{
  position:relative;
  display:inline-block;
  color:var(--ink-90);
  transition:color var(--d1) var(--ease);
}
.link-underline::after{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:-2px;
  height:1px;
  background:currentColor;
  opacity:.4;
  transition:opacity var(--d2) var(--ease),transform var(--d2) var(--ease);
  transform-origin:left center;
}
.link-underline:hover{color:var(--oxide)}
.link-underline:hover::after{opacity:1;transform:scaleY(1.5)}

/* ============================================================
   HERO — Cinematic video full-bleed
   ============================================================ */
.hero{
  position:relative;
  height:100vh;
  height:100dvh;
  min-height:600px;
  max-height:1000px;
  overflow:hidden;
  background:var(--void);
}
.hero__video-wrap{
  position:absolute;
  inset:0;
  overflow:hidden;
}
.hero__video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:1;
  transition:opacity 1800ms var(--ease) 200ms,transform 3000ms var(--ease-long) 200ms;
}
.js-ready .hero:not(.is-live) .hero__video{opacity:0;transform:scale(1.06)}
.hero.is-live .hero__video{opacity:1;transform:scale(1)}

/* The hero video is square 720x720 — needs generous dark fields on desktop */
.hero__veil{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at center,transparent 0%,transparent 40%,rgba(6,4,2,.4) 80%,rgba(6,4,2,.7) 100%),
    linear-gradient(180deg,rgba(6,4,2,.3) 0%,rgba(6,4,2,0) 25%,rgba(6,4,2,0) 55%,rgba(6,4,2,.75) 100%);
  z-index:2;
  pointer-events:none;
}
.hero__grain{
  position:absolute;
  inset:0;
  opacity:.06;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:3;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}
.hero__content{
  position:absolute;
  inset:0;
  z-index:5;
  padding:calc(110px + var(--gutter)) var(--gutter) clamp(48px,7vw,100px);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:clamp(48px,6vw,80px);
}
.hero__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  flex:0 0 auto;
  position:absolute;
  top:calc(110px + 8px);
  left:var(--gutter);
  right:var(--gutter);
}
.hero__badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border:1px solid var(--ink-25);
  background:rgba(6,4,2,.4);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-90);
  font-weight:500;
}
.hero__badge .dot{
  width:6px;height:6px;
  background:var(--oxide);
  border-radius:50%;
  box-shadow:0 0 8px var(--oxide-glow);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.9)}
}
.hero__kahn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:.64rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}
.hero__kahn::before{
  content:"";
  display:inline-block;
  width:20px;height:1px;
  background:currentColor;
}

.hero__main{
  display:flex;
  flex-direction:column;
  gap:clamp(36px,4vw,56px);
  max-width:var(--col-max);
  width:100%;
  margin:0 auto;
}
.hero__title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.8rem,8.5vw,8rem);
  line-height:.92;
  letter-spacing:-.04em;
  color:var(--ink);
  max-width:14ch;
}
.hero__title .break{display:block}
.hero__title .italic{
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  color:var(--oxide);
}
.hero__sub{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:40px;
  flex-wrap:wrap;
}
.hero__lede{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.05rem,1.4vw,1.3rem);
  line-height:1.45;
  color:var(--ink-90);
  max-width:34ch;
}
.hero__cta{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.hero__meta{
  position:absolute;
  bottom:clamp(48px,7vw,100px);
  right:var(--gutter);
  font-size:.64rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  text-align:right;
  line-height:1.8;
  display:none;
}

/* scroll indicator */
.hero__scroll{
  position:absolute;
  bottom:clamp(16px,2vw,24px);
  left:50%;
  transform:translateX(-50%);
  z-index:6;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  color:var(--ink-55);
  font-size:.62rem;
  letter-spacing:.3em;
  text-transform:uppercase;
}
.hero__scroll .line{
  width:1px;
  height:32px;
  background:linear-gradient(180deg,transparent 0%,var(--ink-55) 50%,transparent 100%);
  animation:scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{transform:translateY(-12px);opacity:0}
  50%{opacity:1}
  100%{transform:translateY(12px);opacity:0}
}

/* ============================================================
   VERITY ROW — the trust bar right under hero
   ============================================================ */
.verity{
  background:var(--deep);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
  padding:clamp(48px,6vw,80px) 0;
  position:relative;
}
.verity__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.verity__item{
  padding:0 clamp(16px,2vw,32px);
  border-right:1px solid var(--ink-08);
  text-align:center;
}
.verity__item:last-child{border-right:0}
.verity__item:first-child{padding-left:0}
.verity__item:last-child{padding-right:0}
.verity__value{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2rem,3.5vw,3rem);
  line-height:1;
  color:var(--ink);
  margin-bottom:14px;
  letter-spacing:-.02em;
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:4px;
}
.verity__value .unit{
  font-family:var(--sans);
  font-size:.34em;
  font-weight:400;
  color:var(--oxide);
  letter-spacing:.08em;
  text-transform:lowercase;
  margin-left:6px;
}
.verity__value .prefix{
  font-family:var(--sans);
  font-weight:400;
  font-size:.32em;
  color:var(--ink-55);
  margin-right:6px;
}
.verity__value .num{
  display:inline-block;
  min-width:1ch;
  font-variant-numeric:tabular-nums;
}
/* Hide the fallback "0" until JS starts animating — prevents a "we have zero" flash on load */
.verity__value .num[data-to]{
  opacity:0;
  transition:opacity .35s ease-out;
}
.verity__value .num[data-to].is-counting,
.verity__value .num[data-to].is-done{
  opacity:1;
}
/* If JS fails entirely (no-JS, CSP block, etc.), reveal after a delay so the stat is never invisible */
.verity__value .num[data-to]{
  animation:num-reveal-fallback 0s linear 4s forwards;
}
@keyframes num-reveal-fallback{ to{ opacity:1; } }
.verity__label{
  font-size:.70rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-55);
  line-height:1.6;
}

/* ============================================================
   INTRO — philosophy block
   ============================================================ */
.intro{
  padding:clamp(120px,14vw,200px) 0;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.intro__bg-video{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:-2;
  opacity:.22;
  pointer-events:none;
  filter:saturate(.7) contrast(.95);
}
.intro__bg-veil{
  position:absolute;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(12,10,8,.5) 0%, rgba(12,10,8,.88) 60%, rgba(12,10,8,.95) 100%),
    linear-gradient(180deg, var(--bg) 0%, rgba(12,10,8,.9) 30%, rgba(12,10,8,.9) 70%, var(--bg) 100%);
}
.intro__grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:clamp(48px,8vw,160px);
  align-items:start;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  position:relative;
  z-index:1;
}
.intro__side{
  position:sticky;
  top:140px;
  display:flex;
  flex-direction:column;
  gap:32px;
}
.intro__side .eyebrow{margin-bottom:0}
.intro__mark{
  width:clamp(120px,15vw,180px);
  height:auto;
  padding:0;
  background:transparent;
  border-radius:0;
  display:block;
  margin-bottom:8px;
}
.intro__mark img{
  width:100%;
  height:auto;
  object-fit:contain;
  border-radius:0;
  opacity:.92;
  display:block;
}
.intro__num{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(3rem,6vw,5rem);
  line-height:1;
  color:var(--oxide);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.intro__body{max-width:48ch}
.intro__lede{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem,3vw,2.6rem);
  line-height:1.18;
  letter-spacing:-.018em;
  color:var(--ink);
  margin-bottom:40px;
  max-width:24ch;
}
.intro__text{
  color:var(--ink-70);
  font-size:1.02rem;
  line-height:1.7;
}
.intro__text p+p{margin-top:1.2em}
.intro__text strong{color:var(--ink);font-weight:500}

/* ============================================================
   LIFESTYLE BREAKAWAY — full-bleed video (Video 4)
   ============================================================ */
.breakaway{
  position:relative;
  height:80vh;
  min-height:520px;
  max-height:900px;
  overflow:hidden;
  background:var(--void);
}
.breakaway__video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.95;
}
.breakaway__veil{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(6,4,2,.55) 0%,rgba(6,4,2,0) 30%,rgba(6,4,2,0) 60%,rgba(6,4,2,.75) 100%);
  z-index:2;
}
.breakaway__content{
  position:absolute;
  inset:0;
  z-index:3;
  padding:clamp(60px,7vw,100px) var(--gutter);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  max-width:var(--col-max);
  margin:0 auto;
}
.breakaway__top .eyebrow{color:var(--ink-90)}
.breakaway__bottom{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
}
.breakaway__pull{
  font-family:var(--serif);
  font-weight:300;
  font-style:italic;
  font-size:clamp(2rem,4.5vw,4rem);
  line-height:1.05;
  letter-spacing:-.022em;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  max-width:18ch;
}
.breakaway__cite{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-style:normal;
  font-family:var(--sans);
}

/* ============================================================
   CHAPTERS — the 5-stage narrative
   Each chapter is a sticky-scroll section: image pinned, text advances
   ============================================================ */
.chapters{
  padding:clamp(100px,12vw,180px) 0 0;
}
.chapters__head{
  max-width:var(--col-max);
  margin:0 auto clamp(80px,10vw,140px);
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:clamp(40px,6vw,100px);
  align-items:end;
}
.chapters__head h2{max-width:12ch}
.chapters__head p{color:var(--ink-70);max-width:40ch;font-size:1.05rem;line-height:1.6}

.chapter{
  position:relative;
  padding:clamp(100px,12vw,180px) 0;
  border-top:1px solid var(--ink-08);
}
.chapter:first-child{border-top:0;padding-top:0}
.chapter__inner{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:clamp(48px,7vw,120px);
  align-items:start;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.chapter--reverse .chapter__media{grid-column:2;grid-row:1}
.chapter--reverse .chapter__text{grid-column:1;grid-row:1}

.chapter__media{
  position:relative;
}
.chapter__media-frame{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--raised);
}
.chapter__media-frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.05);
  transition:transform 2000ms var(--ease-long);
}
.chapter.is-in .chapter__media-frame img{transform:scale(1)}
.chapter__media-label{
  position:absolute;
  left:20px;
  top:20px;
  font-size:.64rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-90);
  font-weight:500;
  text-shadow:0 1px 3px rgba(0,0,0,.6);
  z-index:2;
}

.chapter__text{
  position:sticky;
  top:120px;
  display:flex;
  flex-direction:column;
  gap:40px;
  padding:clamp(20px,3vw,60px) 0;
}
.chapter__n{
  display:flex;
  align-items:baseline;
  gap:20px;
  color:var(--oxide);
  font-family:var(--serif);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  font-style:italic;
}
.chapter__n .big{
  font-size:clamp(3rem,4.5vw,4.5rem);
  line-height:1;
  letter-spacing:-.02em;
}
.chapter__n .label{
  font-family:var(--sans);
  font-style:normal;
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}
.chapter__title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.4rem,4.5vw,4rem);
  line-height:1;
  letter-spacing:-.028em;
  color:var(--ink);
}
.chapter__title .italic{
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  color:var(--oxide);
}
.chapter__body{
  color:var(--ink-70);
  max-width:46ch;
  font-size:1.02rem;
  line-height:1.7;
}
.chapter__body p+p{margin-top:1.1em}
.chapter__body strong{color:var(--ink);font-weight:500}

.chapter__pointer{
  display:inline-flex;
  align-items:center;
  gap:16px;
  padding-top:20px;
  border-top:1px solid var(--ink-14);
  max-width:280px;
}
.chapter__pointer-num{
  font-family:var(--serif);
  font-style:italic;
  color:var(--oxide);
  font-size:1.2rem;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.chapter__pointer-label{
  font-size:.66rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-55);
}

/* ============================================================
   DESIGN YOUR OWN — interactive chooser with showroom bg
   ============================================================ */
.chooser{
  position:relative;
  padding:clamp(120px,14vw,200px) 0;
  overflow:hidden;
  background:var(--deep);
}
.chooser__bg{
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:1;
}
.chooser__bg video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.35;
  filter:brightness(.8) contrast(1.1);
}
.chooser__bg-veil{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(10,7,5,.6) 0%,rgba(10,7,5,.8) 100%);
}
.chooser__inner{
  position:relative;
  z-index:2;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.chooser__head{
  text-align:center;
  margin-bottom:clamp(60px,8vw,100px);
}
.chooser__head h2{margin-bottom:24px;max-width:16ch;margin-left:auto;margin-right:auto}
.chooser__head p{color:var(--ink-70);max-width:52ch;margin:0 auto;font-size:1.05rem;line-height:1.6}
.chooser__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(4px,.6vw,12px);
  margin-bottom:48px;
}
.chooser__step{
  padding:clamp(20px,2.5vw,32px);
  border:1px solid var(--ink-14);
  background:rgba(6,4,2,.5);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:border-color var(--d2) var(--ease),background var(--d2) var(--ease);
}
.chooser__step.is-active{border-color:var(--oxide);background:rgba(6,4,2,.7)}
.chooser__step-n{
  display:flex;
  align-items:baseline;
  gap:12px;
  margin-bottom:20px;
}
.chooser__step-n .num{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.4rem;
  color:var(--oxide);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.chooser__step-n .label{
  font-size:.68rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}
.chooser__step h4{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.2rem,1.8vw,1.5rem);
  margin-bottom:20px;
  line-height:1.1;
  color:var(--ink);
}
.chooser__options{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.chooser__opt{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  border:1px solid transparent;
  background:rgba(244,238,224,.03);
  font-size:.82rem;
  color:var(--ink-70);
  cursor:pointer;
  transition:color var(--d1) var(--ease),background var(--d1) var(--ease),border-color var(--d1) var(--ease);
  text-align:left;
}
.chooser__opt:hover{color:var(--ink);background:rgba(244,238,224,.06)}
.chooser__opt.is-selected{
  color:var(--ink);
  border-color:var(--oxide);
  background:rgba(200,90,51,.1);
}
.chooser__opt .swatch{
  width:14px;height:14px;
  border-radius:50%;
  border:1px solid var(--ink-25);
}
.chooser__cta{
  display:flex;
  justify-content:center;
  padding-top:32px;
  border-top:1px solid var(--ink-14);
}
.chooser__summary{
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.1rem,1.6vw,1.35rem);
  color:var(--ink-90);
  margin-bottom:32px;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  min-height:2em;
}

/* ============================================================
   PROJECTS GRID — on homepage
   ============================================================ */
.projects-strip{
  padding:clamp(100px,12vw,180px) 0;
  position:relative;
}
.projects-strip__head{
  max-width:var(--col-max);
  margin:0 auto clamp(60px,7vw,100px);
  padding:0 var(--gutter);
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
}
.projects-strip__head h2{max-width:18ch}

.projects-strip__grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:clamp(12px,1.5vw,24px);
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.project-card{
  position:relative;
  overflow:hidden;
  background:var(--raised);
  display:block;
}
.project-card__frame{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
}
.project-card__frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1800ms var(--ease-long),opacity 700ms var(--ease);
}
.project-card__frame img.alt{opacity:0}
.project-card:hover .project-card__frame img.main{transform:scale(1.05);opacity:0}
.project-card:hover .project-card__frame img.alt{opacity:1}
.project-card__veil{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(6,4,2,0) 40%,rgba(6,4,2,.85) 100%);
  z-index:2;
}
.project-card__text{
  position:absolute;
  left:24px;
  right:24px;
  bottom:22px;
  z-index:3;
  color:var(--ink);
}
.project-card__name{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(1.4rem,2vw,1.8rem);
  letter-spacing:-.018em;
  line-height:1;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  margin-bottom:8px;
  display:block;
}
.project-card__spec{
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-70);
}
.project-card__index{
  position:absolute;
  top:16px;
  left:20px;
  z-index:3;
  font-family:var(--serif);
  font-style:italic;
  font-size:.85rem;
  color:var(--ink-70);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  text-shadow:0 1px 3px rgba(0,0,0,.6);
}

/* Homepage featured layout — flagship is big, others smaller */
.pc--feat{grid-column:span 8}
.pc--feat .project-card__frame{aspect-ratio:16/10}
.pc--std{grid-column:span 4}
.pc--half{grid-column:span 6}
.pc--half .project-card__frame{aspect-ratio:4/3}

/* ============================================================
   COMMISSION — CTA block with prices
   ============================================================ */
.commission{
  padding:clamp(140px,16vw,220px) 0;
  text-align:center;
  position:relative;
  background:var(--deep);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
}
.commission__inner{
  max-width:900px;
  margin:0 auto;
  padding:0 var(--gutter);
}
.commission h2{
  font-size:clamp(2.4rem,6vw,5.5rem);
  line-height:1;
  letter-spacing:-.032em;
  max-width:18ch;
  margin:32px auto 40px;
}
.commission__body{
  max-width:52ch;
  margin:0 auto 48px;
  color:var(--ink-70);
  font-size:1.05rem;
  line-height:1.6;
}
.commission__prices{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:0;
  border-top:1px solid var(--ink-14);
  border-bottom:1px solid var(--ink-14);
  margin:56px 0;
}
.commission__price{
  padding:32px 20px;
  border-right:1px solid var(--ink-14);
}
.commission__price:last-child{border-right:0}
.commission__price-label{
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  margin-bottom:12px;
  font-weight:500;
}
.commission__price-value{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem,3vw,2.4rem);
  line-height:1;
  color:var(--ink);
  letter-spacing:-.02em;
}
.commission__price-value .prefix{
  font-size:.5em;
  color:var(--ink-55);
  margin-right:6px;
  letter-spacing:.04em;
  font-weight:400;
}
.commission__price-term{
  font-size:.72rem;
  color:var(--ink-55);
  margin-top:12px;
  letter-spacing:.08em;
}
.commission__ctas{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
}
.commission__slots{
  margin-top:48px;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
}
.commission__slots .oxide{color:var(--oxide);font-weight:500}

/* ============================================================
   INSTAGRAM — WIP + feed link
   ============================================================ */
.social{
  padding:clamp(100px,12vw,180px) 0;
  background:var(--void);
}
.social__head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:end;
  max-width:var(--col-max);
  margin:0 auto clamp(60px,7vw,100px);
  padding:0 var(--gutter);
}
.social__head h2{max-width:16ch}
.social__head p{color:var(--ink-70);max-width:44ch;font-size:1.05rem;line-height:1.6}

.social__wip{
  max-width:var(--col-max);
  margin:0 auto clamp(80px,10vw,140px);
  padding:0 var(--gutter);
}
.social__wip-label{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:32px;
  color:var(--oxide);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
}
.social__wip-label .dot{
  width:8px;height:8px;
  background:var(--oxide);
  border-radius:50%;
  box-shadow:0 0 10px var(--oxide-glow);
  animation:pulse 2.4s ease-in-out infinite;
}
.social__wip-label .rule{
  flex:1;
  height:1px;
  background:var(--ink-14);
}
.wip-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,1.5vw,24px);
}
.wip-card{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--raised);
}
.wip-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.8s var(--ease-long);
}
.wip-card:hover img{transform:scale(1.04)}
.wip-card__veil{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(6,4,2,.85) 100%);
}
.wip-card__text{
  position:absolute;
  left:20px;right:20px;bottom:20px;
  color:var(--ink);
}
.wip-card__status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;height:32px;
  border:1px solid var(--oxide);
  color:var(--oxide);
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:.9rem;
  letter-spacing:0;
  margin-bottom:14px;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  background:transparent;
  text-transform:none;
}
.wip-card__name{
  font-family:var(--serif);
  font-weight:300;
  font-style:normal;
  font-size:clamp(1.3rem,2vw,1.6rem);
  letter-spacing:-.016em;
  line-height:1.1;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  margin-bottom:10px;
  display:block;
}
.wip-card__meta{
  font-size:.78rem;
  letter-spacing:.02em;
  text-transform:none;
  color:var(--ink-70);
  font-weight:300;
  line-height:1.5;
}

.social__feed{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.ig-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:clamp(4px,.6vw,10px);
  margin-bottom:40px;
}
.ig-tile{
  aspect-ratio:1;
  overflow:hidden;
  background:var(--raised);
  position:relative;
  display:block;
}
.ig-tile img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 1.4s var(--ease-long),opacity var(--d2) var(--ease);
  opacity:.88;
}
.ig-tile:hover img{transform:scale(1.06);opacity:1}
.ig-tile__veil{
  position:absolute;
  inset:0;
  background:rgba(6,4,2,.2);
  opacity:0;
  transition:opacity var(--d2) var(--ease);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink);
  font-size:.68rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:500;
}
.ig-tile:hover .ig-tile__veil{opacity:1}
.ig-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding-top:24px;
  border-top:1px solid var(--ink-14);
  flex-wrap:wrap;
}
.ig-footer__handle{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.2rem,1.8vw,1.6rem);
  color:var(--ink);
  letter-spacing:-.014em;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.ig-footer__cta{
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--oxide);
  display:inline-flex;
  align-items:center;
  gap:10px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--void);
  color:var(--ink-70);
  padding:clamp(100px,10vw,160px) 0 36px;
  border-top:1px solid var(--ink-08);
}
.site-footer h5{
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-family:var(--sans);
  font-weight:500;
  margin-bottom:20px;
}
.footer__top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(40px,5vw,80px);
  padding:0 var(--gutter);
  max-width:var(--col-max);
  margin:0 auto;
  padding-bottom:clamp(60px,7vw,100px);
  border-bottom:1px solid var(--ink-08);
}
.footer__brand{display:flex;flex-direction:column;gap:28px}
.footer__brand-mark{
  width:76px;
  height:76px;
  border-radius:50%;
  background:var(--ink);
  padding:3px;
}
.footer__brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.footer__brand h3{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2rem,3.5vw,3rem);
  line-height:1;
  letter-spacing:-.024em;
  color:var(--ink);
  max-width:16ch;
}
.footer__brand p{
  font-size:.96rem;
  color:var(--ink-70);
  max-width:40ch;
  line-height:1.6;
}
.footer__col ul{display:flex;flex-direction:column;gap:12px}
.footer__col a{
  font-size:.94rem;
  color:var(--ink-70);
  transition:color var(--d1) var(--ease);
}
.footer__col a:hover{color:var(--oxide)}
.footer__col address{
  font-style:normal;
  font-size:.94rem;
  line-height:1.7;
  color:var(--ink-70);
}
.address-link{
  color:inherit;
  text-decoration:none;
  transition:color var(--d1) var(--ease);
  display:inline-block;
}
.address-link:hover{color:var(--oxide)}
.address-link::after{
  content:" ↗";
  color:var(--ink-40);
  font-size:.78em;
  margin-left:2px;
  transition:color var(--d1) var(--ease);
}
.address-link:hover::after{color:var(--oxide)}

.footer__base{
  padding:36px var(--gutter) 0;
  max-width:var(--col-max);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.76rem;
  color:var(--ink-40);
  letter-spacing:.06em;
  flex-wrap:wrap;
  gap:16px;
}
.footer__base .mark{
  font-family:var(--serif);
  font-size:.88rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-70);
}

/* ============================================================
   WHATSAPP FLOAT
   ============================================================ */
.wa-float{
  position:fixed;
  right:clamp(14px,2.4vw,22px);
  bottom:clamp(14px,2.4vw,22px);
  width:44px;height:44px;
  background:rgba(20,22,20,.82);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:80;
  box-shadow:0 1px 2px rgba(0,0,0,.18),0 4px 14px rgba(0,0,0,.22);
  transition:transform var(--d2) var(--ease-long),background var(--d2) var(--ease-long),border-color var(--d2) var(--ease-long);
  opacity:.88;
}
.wa-float:hover{transform:scale(1.06);background:#1FA855;border-color:rgba(255,255,255,.18);opacity:1}
.wa-float svg{width:19px;height:19px;fill:rgba(255,255,255,.86);transition:fill var(--d2) var(--ease-long)}
.wa-float:hover svg{fill:#fff}

/* Emphasis inside intro/chapter copy — replaces the old <strong> pattern which broke the ES/EN toggle */
.intro__rules{
  font-style:normal;
  font-weight:500;
  color:var(--ink);
  letter-spacing:.002em;
}

/* ============================================================
   OWNERS — testimonials
   ============================================================ */
.owners{
  padding:clamp(100px,13vw,180px) 0;
  background:var(--bg);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
}
.owners__inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.owners__head{
  max-width:720px;
  margin:0 auto clamp(60px,8vw,120px);
  text-align:center;
}
.owners__head h2{
  margin-top:24px;
  max-width:22ch;
  margin-left:auto;
  margin-right:auto;
}
.owners__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(40px,5vw,80px);
  align-items:stretch;
}
.owner{
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:clamp(20px,2.4vw,32px);
  position:relative;
  height:100%;
}
.owner::before{
  content:"";
  display:block;
  width:32px;
  height:1px;
  background:var(--oxide);
  opacity:.5;
  margin-bottom:8px;
}
.owner__quote{
  margin:0;
  font-family:var(--serif);
  font-weight:300;
  font-style:normal;
  font-size:clamp(1.05rem,1.35vw,1.2rem);
  line-height:1.55;
  color:var(--ink);
  letter-spacing:-.005em;
  font-variation-settings:"opsz" 48,"SOFT" 100;
  max-width:38ch;
}
.owner__cite{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:auto;
  padding-top:clamp(16px,2vw,24px);
  border-top:1px solid var(--ink-08);
  font-style:normal;
}
.owner__name{
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--ink);
  font-weight:300;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.owner__meta{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}

/* ============================================================
   WORKSHOP STRIP — approach.html editorial photo band
   ============================================================ */
.workshop-strip{
  padding:clamp(80px,9vw,140px) var(--gutter);
  background:var(--bg);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
}
.workshop-strip__head{
  max-width:var(--col-max);
  margin:0 auto clamp(48px,6vw,80px);
  text-align:left;
}
.workshop-strip__head h2{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  line-height:1.05;
  letter-spacing:-.02em;
}
.workshop-strip__head p{
  margin-top:20px;
  max-width:62ch;
  color:var(--ink-70);
  font-size:.98rem;
  line-height:1.55;
}
.workshop-strip__grid{
  max-width:var(--col-max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:minmax(180px,auto);
  gap:14px;
}
.workshop-strip__cell{
  position:relative;
  margin:0;
  overflow:hidden;
  background:var(--ink-08);
}
.workshop-strip__cell img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1.2s var(--ease-long);
}
.workshop-strip__cell:hover img{transform:scale(1.04)}
.workshop-strip__cell figcaption{
  position:absolute;
  left:16px;bottom:14px;right:16px;
  font-family:var(--sans);
  font-size:.68rem;
  font-weight:400;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.92);
  text-shadow:0 1px 2px rgba(0,0,0,.6);
  z-index:2;
}
.workshop-strip__cell::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,0) 38%);
  pointer-events:none;
}
/* Editorial asymmetric layout */
.ws-a{grid-column:span 7;grid-row:span 2;aspect-ratio:auto}
.ws-b{grid-column:span 5;grid-row:span 1}
.ws-c{grid-column:span 5;grid-row:span 1}
.ws-d{grid-column:span 4;grid-row:span 1}
.ws-e{grid-column:span 4;grid-row:span 1}
.ws-f{grid-column:span 4;grid-row:span 1}
@media (max-width:860px){
  .workshop-strip__grid{grid-auto-rows:minmax(220px,auto);gap:10px}
  .ws-a,.ws-b,.ws-c,.ws-d,.ws-e,.ws-f{grid-column:span 12;grid-row:span 1}
}

/* ============================================================
   PAGE HEAD — for subpages
   ============================================================ */
.page-head{
  padding:clamp(160px,18vw,240px) 0 clamp(60px,7vw,100px);
  border-bottom:1px solid var(--ink-08);
}
.page-head__inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.page-head h1{
  font-size:clamp(3rem,8vw,7.5rem);
  line-height:.96;
  letter-spacing:-.034em;
  max-width:15ch;
  margin:32px 0 48px;
}
.page-head__lede{
  font-size:clamp(1.2rem,1.8vw,1.6rem);
  max-width:38ch;
  color:var(--ink-90);
}

/* Hero variant — text + image side by side, image bleeds to right edge */
.page-head--hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:clamp(40px,5vw,80px);
  align-items:center;
  padding:clamp(140px,15vw,200px) 0 clamp(80px,9vw,120px);
}
.page-head--hero .page-head__inner{
  padding-left:var(--gutter);
  padding-right:0;
  margin:0;
  max-width:none;
}
.page-head--hero .page-head__lede{max-width:42ch}
.page-head__visual{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--void);
}
.page-head__visual img{
  position:absolute;
  top:0;left:0;
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.02);
  transition:transform 3000ms var(--ease-long);
}
.page-head--hero.is-in .page-head__visual img{transform:scale(1)}

/* ============================================================
   REGISTER — chronological project list
   ============================================================ */
.register{
  padding:clamp(60px,8vw,100px) 0;
}
.register__head{
  max-width:var(--col-max);
  margin:0 auto clamp(48px,6vw,80px);
  padding:0 var(--gutter);
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:24px;
  flex-wrap:wrap;
}
.register__head h2{max-width:14ch}
.register__head .total{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.1rem,1.5vw,1.3rem);
  color:var(--oxide);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.register__list{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  border-top:1px solid var(--ink-25);
}
.register__row{
  display:grid;
  grid-template-columns:96px 1.4fr 1.6fr 1fr auto;
  gap:clamp(16px,2vw,40px);
  padding:22px 0;
  border-bottom:1px solid var(--ink-08);
  align-items:center;
  transition:background var(--d1) var(--ease),padding-left var(--d2) var(--ease);
  position:relative;
}
.register__row::before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:2px;
  background:var(--oxide);
  transform:scaleY(0);
  transform-origin:center;
  transition:transform var(--d2) var(--ease);
}
.register__row:hover{background:rgba(244,238,224,.03);padding-left:16px}
.register__row:hover::before{transform:scaleY(1)}
.register__thumb{
  display:block;
  width:96px;height:64px;
  overflow:hidden;
  background:var(--ink-08);
  flex-shrink:0;
}
.register__thumb img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1s var(--ease-long);
}
.register__row:hover .register__thumb img{transform:scale(1.05)}
.register__name{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.3rem,2vw,1.75rem);
  letter-spacing:-.018em;
  line-height:1;
  color:var(--ink);
}
.register__spec{font-size:.84rem;color:var(--ink-70)}
.register__dest{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-55)}
.register__arrow{
  font-family:var(--serif);
  font-style:italic;
  color:var(--ink-40);
  transition:color var(--d1) var(--ease),transform var(--d2) var(--ease-long);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.register__row:hover .register__arrow{color:var(--oxide);transform:translateX(6px)}

/* ============================================================
   GALLERY MASONRY
   ============================================================ */
.gallery-head{
  max-width:var(--col-max);
  margin:clamp(80px,10vw,140px) auto clamp(48px,6vw,80px);
  padding:0 var(--gutter);
}
.gallery-head h2{max-width:14ch}

.masonry{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:clamp(12px,1.5vw,24px);
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter) clamp(100px,12vw,160px);
}
.masonry .project-card{display:block}
/* Hierarchy: Falcon full-bleed hero → descending importance down to Kai */
.m-a{grid-column:span 12}.m-a .project-card__frame{aspect-ratio:16/9}       /* Falcon signature */
.m-b{grid-column:span 8}.m-b .project-card__frame{aspect-ratio:4/3}         /* Lisboa */
.m-c{grid-column:span 4}.m-c .project-card__frame{aspect-ratio:4/5}         /* Zeus portrait */
.m-d{grid-column:span 7}.m-d .project-card__frame{aspect-ratio:16/10}       /* Maximus */
.m-e{grid-column:span 5}.m-e .project-card__frame{aspect-ratio:4/5}         /* Andorra portrait */
.m-f{grid-column:span 6}.m-f .project-card__frame{aspect-ratio:4/3}         /* Apolo */
.m-g{grid-column:span 6}.m-g .project-card__frame{aspect-ratio:4/3}         /* Rambo */
.m-h{grid-column:span 6}.m-h .project-card__frame{aspect-ratio:4/3}         /* Formentera */
.m-i{grid-column:span 6}.m-i .project-card__frame{aspect-ratio:4/3}         /* Kai */

/* ============================================================
   PROJECT DETAIL PAGE
   ============================================================ */
.pd-hero{
  position:relative;
  height:90vh;
  height:90dvh;
  min-height:620px;
  overflow:hidden;
  background:var(--void);
}
.pd-hero img{
  position:absolute !important;
  top:0 !important;
  left:0 !important;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  object-fit:cover;
  object-position:center center;
  opacity:.88;
  transform:scale(1.05);
  transition:transform 2500ms var(--ease-long);
}
.pd-hero.is-in img{transform:scale(1)}
.pd-hero__veil{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(6,4,2,.4) 0%,rgba(6,4,2,0) 35%,rgba(6,4,2,.8) 100%);
  z-index:2;
}
.pd-hero__content{
  position:absolute;
  inset:0;
  padding:0 var(--gutter) clamp(60px,7vw,100px);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  z-index:3;
  max-width:var(--col-max);
  margin:0 auto;
}
.pd-hero__kicker{
  display:flex;
  gap:20px;
  align-items:center;
  color:var(--ink-70);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:32px;
  flex-wrap:wrap;
}
.pd-hero__kicker .dot{
  width:4px;height:4px;
  background:currentColor;
  border-radius:50%;
  opacity:.5;
}
.pd-hero__title{
  font-family:var(--serif);
  font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  font-size:clamp(4rem,14vw,13rem);
  line-height:.88;
  letter-spacing:-.042em;
  color:var(--ink);
  margin-bottom:12px;
}
.pd-hero__subtitle{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.2rem,2vw,1.85rem);
  color:var(--ink-90);
  letter-spacing:-.008em;
  max-width:44ch;
}

.pd-specs{
  padding:clamp(100px,12vw,160px) 0;
  border-bottom:1px solid var(--ink-08);
}
.pd-specs__grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:clamp(40px,6vw,120px);
  align-items:start;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.pd-specs__intro h2{
  font-size:clamp(2rem,3.5vw,3rem);
  line-height:1.04;
  letter-spacing:-.022em;
  max-width:16ch;
  margin-bottom:28px;
}
.pd-specs__intro p{color:var(--ink-70);max-width:40ch;font-size:1rem;line-height:1.7}
.pd-specs__intro p+p{margin-top:1em}
.pd-specs__intro .seal{
  width:72px;
  height:72px;
  border:1px solid var(--ink-14);
  border-radius:50%;
  padding:4px;
  margin-bottom:36px;
  background:var(--ink);
}
.pd-specs__intro .seal img{width:100%;height:100%;object-fit:contain;border-radius:50%}

.spec-sheet{border-top:1px solid var(--ink-25)}
.spec-row{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:24px;
  padding:18px 0;
  border-bottom:1px solid var(--ink-08);
  align-items:baseline;
}
.spec-row dt{
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}
.spec-row dd{
  font-family:var(--serif);
  font-weight:300;
  font-size:1.2rem;
  line-height:1.35;
  color:var(--ink);
}

/* Project detail video */
.pd-video-wrap{
  padding:clamp(60px,7vw,100px) 0;
}
.pd-video-wrap .inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.pd-video{
  width:100%;
  aspect-ratio:16/9;
  background:var(--void);
  border:1px solid var(--ink-08);
  position:relative;
  overflow:hidden;
}
.pd-video video{
  width:100%;
  height:100%;
  object-fit:cover;
}
.pd-video__label{
  padding:20px 24px 0;
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
}

.pd-gallery-wrap{
  padding:clamp(60px,8vw,120px) 0 clamp(100px,12vw,160px);
}
.pd-gallery{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:clamp(12px,1.5vw,24px);
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.pd-g-a{grid-column:span 8;aspect-ratio:3/2}
.pd-g-b{grid-column:span 4;aspect-ratio:3/4}
.pd-g-c{grid-column:span 5;aspect-ratio:4/5}
.pd-g-d{grid-column:span 7;aspect-ratio:4/3}
.pd-g-e{grid-column:span 12;aspect-ratio:16/9}
.pd-g-f{grid-column:span 6;aspect-ratio:4/3}
.pd-g-g{grid-column:span 6;aspect-ratio:4/3}
.pd-gallery>div{background:var(--raised);overflow:hidden}
.pd-gallery img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease-long)}
.pd-gallery>div:hover img{transform:scale(1.03)}

.pd-pull{
  padding:clamp(100px,12vw,160px) 0;
  background:var(--deep);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
  text-align:center;
}
.pd-pull blockquote{
  max-width:22ch;
  margin:0 auto;
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(2rem,4.5vw,4rem);
  line-height:1.08;
  letter-spacing:-.022em;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.pd-pull cite{
  display:block;
  margin-top:40px;
  font-style:normal;
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
}
.pd-next{padding:clamp(80px,10vw,140px) 0}
.pd-next__inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.pd-next__label{color:var(--ink-55);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase}
.pd-next__name{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(2rem,5vw,4rem);
  letter-spacing:-.025em;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  transition:color var(--d2) var(--ease);
}
.pd-next a:hover .pd-next__name{color:var(--oxide)}

/* ============================================================
   APPROACH PAGE — Client journey
   ============================================================ */
.journey{
  padding:clamp(100px,12vw,180px) 0;
  border-top:1px solid var(--ink-08);
}
.journey__head{
  max-width:var(--col-max);
  margin:0 auto clamp(80px,10vw,140px);
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:end;
}
.journey__head h2{max-width:16ch}
.journey__head p{color:var(--ink-70);max-width:42ch;font-size:1.05rem;line-height:1.6}
.journey__track{
  position:relative;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.journey__line{
  position:absolute;
  left:calc(var(--gutter) + 30px);
  top:0;bottom:0;
  width:1px;
  background:linear-gradient(180deg,var(--oxide) 0%,var(--ink-14) 70%,transparent 100%);
}
.step{
  display:grid;
  grid-template-columns:80px minmax(0,1fr) clamp(180px,22vw,320px);
  gap:clamp(24px,3vw,60px);
  padding:clamp(40px,5vw,72px) 0;
  position:relative;
  align-items:start;
}
.step__media{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--ink-08);
  margin-top:12px;
}
.step__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1.2s var(--ease-long);
}
.step:hover .step__media img{transform:scale(1.03)}
.step__media::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.35) 100%);
  pointer-events:none;
}
.step__media-label{
  position:absolute;
  left:12px;bottom:10px;right:12px;
  font-family:var(--sans);
  font-size:.62rem;
  font-weight:400;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.88);
  z-index:2;
}
.step__node{
  width:60px;height:60px;
  border-radius:50%;
  border:1px solid var(--ink-25);
  background:var(--void);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.4rem;
  color:var(--oxide);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  position:relative;
  z-index:2;
  transition:border-color var(--d2) var(--ease),background var(--d2) var(--ease);
}
.step.is-in .step__node{border-color:var(--oxide)}
.step__content{padding-top:12px}
.step__label{
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  margin-bottom:14px;
  font-weight:500;
}
.step__title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.6rem,2.5vw,2.2rem);
  line-height:1.1;
  letter-spacing:-.018em;
  color:var(--ink);
  margin-bottom:20px;
  max-width:22ch;
}
.step__body{
  color:var(--ink-70);
  max-width:50ch;
  font-size:1rem;
  line-height:1.65;
}

/* Payment rhythm callout */
.payment{
  padding:clamp(80px,10vw,140px) 0;
  background:var(--deep);
  border-top:1px solid var(--ink-08);
  border-bottom:1px solid var(--ink-08);
}
.payment__inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.payment__head{
  max-width:44ch;
  margin-bottom:clamp(48px,6vw,80px);
}
.payment__head h2{margin-bottom:20px}
.payment__head p{color:var(--ink-70);max-width:40ch}
.payment__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid var(--ink-14);
  border-bottom:1px solid var(--ink-14);
}
.payment__step{
  padding:36px clamp(20px,2.5vw,32px);
  border-right:1px solid var(--ink-14);
  position:relative;
}
.payment__step:last-child{border-right:0}
.payment__step-pct{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem,2.6vw,2.4rem);
  line-height:1;
  color:var(--ink-70);
  letter-spacing:-.014em;
  margin-bottom:18px;
  display:flex;
  align-items:baseline;
}
.payment__step-pct .pct{color:var(--ink);font-style:normal;font-weight:300}
.payment__step-label{
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--oxide);
  font-weight:500;
  margin-bottom:14px;
}
.payment__step-desc{
  font-size:.9rem;
  color:var(--ink-70);
  line-height:1.55;
  max-width:30ch;
}
.payment__footnote{
  max-width:var(--col-max);
  margin:clamp(40px,5vw,64px) auto 0;
  padding:clamp(22px,2.6vw,28px) clamp(24px,3vw,36px);
  border-top:1px solid var(--ink-14);
  font-family:var(--sans);
  font-size:.84rem;
  color:var(--ink-55);
  letter-spacing:.012em;
  line-height:1.55;
  font-style:italic;
}

/* Trust strip */
.trust{padding:clamp(100px,12vw,160px) 0}
.trust__head{
  max-width:var(--col-max);
  margin:0 auto clamp(60px,7vw,100px);
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:end;
}
.trust__head h2{max-width:16ch}
.trust__head p{color:var(--ink-70);max-width:42ch;font-size:1.05rem;line-height:1.6}
.trust__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  border-top:1px solid var(--ink-14);
  border-bottom:1px solid var(--ink-14);
}
.trust__item{
  padding:44px clamp(16px,2vw,28px);
  border-right:1px solid var(--ink-14);
}
.trust__item:last-child{border-right:0}
.trust__icon{
  width:42px;height:42px;
  border:1px solid var(--ink-25);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--serif);
  font-style:italic;
  color:var(--oxide);
  font-size:1rem;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  margin-bottom:28px;
}
.trust__text h3{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.1rem,1.5vw,1.35rem);
  line-height:1.15;
  letter-spacing:-.012em;
  color:var(--ink);
  margin-bottom:16px;
}
.trust__text p{
  color:var(--ink-70);
  font-size:.92rem;
  line-height:1.55;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid{padding:clamp(60px,8vw,100px) 0 clamp(100px,12vw,160px)}
.contact-grid__inner{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:start;
}
.contact-grid__inner--simple{
  grid-template-columns:1fr;
  max-width:780px;
}
.contact-channels{
  display:flex;
  flex-direction:column;
  gap:0;
  border-top:1px solid var(--ink-25);
}
.contact-channels li{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:24px;
  padding:28px 0;
  border-bottom:1px solid var(--ink-08);
  align-items:baseline;
}
.contact-channels .label{
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  font-weight:500;
}
.contact-channels .value{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(1.3rem,2vw,1.7rem);
  letter-spacing:-.012em;
  color:var(--ink);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  transition:color var(--d1) var(--ease);
  display:block;
}
.contact-channels a.value:hover{color:var(--oxide)}
.contact-channels .note{
  font-size:.78rem;
  color:var(--ink-55);
  margin-top:6px;
}
.map-frame{
  width:100%;
  aspect-ratio:4/5;
  border:1px solid var(--ink-14);
  filter:grayscale(1) brightness(.7) contrast(1.1) invert(.92);
  transition:filter var(--d2) var(--ease);
  background:var(--raised);
}
.map-frame:hover{filter:grayscale(.3) brightness(.85) contrast(1) invert(.85)}
.contact-form{
  padding:clamp(60px,8vw,100px) 0;
  border-top:1px solid var(--ink-08);
}
.contact-form__grid{
  max-width:var(--col-max);
  margin:0 auto;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:clamp(40px,6vw,100px);
  align-items:start;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(16px,2vw,32px);
  margin-bottom:28px;
}
.form-row--full{grid-template-columns:1fr}
.field{display:flex;flex-direction:column}
.field label{
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-55);
  margin-bottom:12px;
  font-weight:500;
}
.field input,.field select,.field textarea{
  background:transparent;
  border:0;
  border-bottom:1px solid var(--ink-25);
  padding:10px 0 14px;
  font-size:1.05rem;
  color:var(--ink);
  font-family:var(--sans);
  transition:border-color var(--d1) var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-40)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--oxide)}
.field select{background:var(--void);color:var(--ink)}
.field select option{background:var(--void);color:var(--ink)}
.field textarea{resize:vertical;min-height:120px}
.submit-row{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--ink-08);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.submit-row p{font-size:.82rem;color:var(--ink-55);max-width:40ch}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .chapters__head,.journey__head,.trust__head,.social__head,.pd-specs__grid,.contact-grid__inner,.contact-form__grid,.chooser__grid{
    grid-template-columns:1fr;
  }
  .chooser__grid{grid-template-columns:repeat(2,1fr)}
  .verity__grid{grid-template-columns:repeat(2,1fr);gap:32px 16px}
  .verity__item{border-right:0;text-align:left}
  .payment__grid,.trust__grid{grid-template-columns:repeat(2,1fr)}
  .payment__step,.trust__item{border-right:0;border-bottom:1px solid var(--ink-14)}
  .payment__step:nth-child(2n),.trust__item:nth-child(2n){border-right:0}
  .payment__step:nth-last-child(-n+2),.trust__item:nth-last-child(-n+2){border-bottom:0}
  .wip-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid{grid-template-columns:repeat(4,1fr)}
  .commission__prices{grid-template-columns:1fr}
  .commission__price{border-right:0;border-bottom:1px solid var(--ink-14)}
  .commission__price:last-child{border-bottom:0}
}

@media (max-width:860px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .nav__lang{display:none}
  .intro__grid,.chapter__inner{grid-template-columns:1fr;gap:40px}
  .chapter--reverse .chapter__media{grid-column:1;grid-row:1}
  .chapter--reverse .chapter__text{grid-column:1;grid-row:2}
  .intro__side,.chapter__text{position:static}
  .chooser__grid{grid-template-columns:1fr}
  .verity__grid{grid-template-columns:1fr;gap:24px}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:span 2}
  .contact-channels li{grid-template-columns:1fr;gap:8px}
  .form-row{grid-template-columns:1fr}
  .hero__meta{display:none}
  .hero__scroll{display:none}
  .hero__cta{flex-direction:column;align-items:stretch;gap:12px}
  .hero__cta .btn{width:100%;justify-content:center}
  .hero__top{padding:0 var(--gutter)}
  .hero__kahn{display:none}
  .hero__badge{font-size:.58rem}
  .pc--feat,.pc--std,.pc--half,.m-a,.m-b,.m-c,.m-d,.m-e,.m-f,.m-g,.m-h,.m-i{grid-column:span 12}
  .pc--feat .project-card__frame,.m-a .project-card__frame,.m-d .project-card__frame,.m-h .project-card__frame,.m-i .project-card__frame{aspect-ratio:4/3}
  .pd-g-a,.pd-g-b,.pd-g-c,.pd-g-d,.pd-g-e,.pd-g-f,.pd-g-g{grid-column:span 12;aspect-ratio:4/3}
  .register__row{grid-template-columns:72px 1fr auto;gap:14px;padding:16px 0}
  .register__thumb{width:72px;height:54px}
  .register__spec,.register__dest{display:none}
  .step{grid-template-columns:50px 1fr;gap:20px}
  .step__media{grid-column:2;max-width:320px;margin-top:28px}
  .step__node{width:42px;height:42px;font-size:1rem}
  .journey__line{left:calc(var(--gutter) + 21px)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .wip-grid{grid-template-columns:1fr}
  .owners__grid{grid-template-columns:1fr;gap:48px}
  .owners__head{text-align:left;margin-left:0;margin-right:0}
  .owners__head h2{margin-left:0;margin-right:0}
  .payment__grid,.trust__grid{grid-template-columns:1fr}
  .payment__step:nth-child(2n),.trust__item:nth-child(2n){border-bottom:1px solid var(--ink-14)}
  /* Project detail pages */
  .pd-hero{height:85vh;min-height:560px}
  .pd-hero__title{font-size:clamp(3rem,14vw,5rem)}
  .pd-hero__subtitle{font-size:.95rem;max-width:100%}
  .pd-specs__grid{grid-template-columns:1fr;gap:32px}
  .pd-hero__kicker{gap:10px;flex-wrap:wrap}
  /* Page heads */
  .page-head h1{font-size:clamp(2.4rem,10vw,4rem)}
  .page-head--hero{grid-template-columns:1fr;gap:40px;padding-top:clamp(120px,14vw,160px)}
  .page-head--hero .page-head__inner{padding:0 var(--gutter)}
  .page-head__visual{aspect-ratio:4/3;margin:0 var(--gutter)}
  /* Intro paragraph spacing */
  .intro__num{font-size:clamp(2.4rem,8vw,3.6rem)}
  /* Workshop strip mobile */
  .workshop-strip__grid{grid-template-columns:repeat(2,1fr) !important}
  .workshop-strip__cell{aspect-ratio:4/3}
  /* Hero title size reduction */
  .hero__title{font-size:clamp(2.8rem,12vw,4.4rem);line-height:1.02}
  .hero__lede{font-size:1rem;line-height:1.5}
  /* Commission section mobile */
  .commission__price-value{font-size:clamp(2rem,7vw,3rem)}
  .commission__ctas{flex-direction:column;align-items:stretch}
  .commission__ctas .btn{width:100%;justify-content:center}
}

@media (max-width:560px){
  .footer__top{grid-template-columns:1fr}
  .footer__brand{grid-column:span 1}
  .nav__brand .wordmark{display:none}
  .hero__top{flex-direction:column;gap:12px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .hero__video,.breakaway__video,.chooser__bg video{opacity:.4 !important}
}

/* ============================================================
   v4.0 UPGRADES — landing restructure (Apr 2026)
   ============================================================ */

/* Lean intro: no bg video, lighter vertical rhythm */
.intro--lean{padding:clamp(80px,10vw,140px) 0}
.intro--lean::before{
  content:"";
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(12,10,8,.35) 0%, rgba(12,10,8,.7) 60%, var(--bg) 100%),
    linear-gradient(180deg, var(--bg) 0%, rgba(12,10,8,.85) 40%, rgba(12,10,8,.85) 60%, var(--bg) 100%);
}

/* Teaser variant of chapters — three beats, tighter spacing */
.chapters--teaser{padding-bottom:clamp(40px,6vw,80px)}
.chapters--teaser .chapter{margin-top:clamp(60px,7vw,100px)}
.chapters__more{
  max-width:var(--col-max);
  margin:clamp(40px,5vw,64px) auto 0;
  padding:0 var(--gutter);
  text-align:center;
}
.chapters__more a{
  font-family:var(--serif);
  font-size:clamp(1.05rem,1.4vw,1.3rem);
  font-style:italic;
  color:var(--ink);
  letter-spacing:.01em;
}

/* Instagram callout — replaces "cars in build" page */
.ig-callout{
  max-width:var(--col-max);
  margin:clamp(56px,7vw,88px) auto 0;
  padding:0 var(--gutter);
}
.ig-callout__inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:clamp(24px,4vw,56px);
  align-items:center;
  padding:clamp(32px,5vw,56px) clamp(32px,5vw,64px);
  border:1px solid rgba(230,222,210,.1);
  background:
    linear-gradient(180deg,rgba(142,59,32,.04) 0%, rgba(10,7,5,.4) 100%),
    var(--deep);
  border-radius:2px;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.ig-callout__inner::before{
  content:"";
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse at 85% 50%, rgba(142,59,32,.08), transparent 60%);
}
.ig-callout__left h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(1.4rem,2.4vw,2rem);
  line-height:1.15;
  margin-top:16px;
  max-width:22ch;
}
.ig-callout__left p{
  color:var(--ink-70);
  font-size:1rem;
  line-height:1.6;
  margin-top:14px;
  max-width:48ch;
}
.ig-callout__btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 28px;
  border:1px solid var(--oxide);
  color:var(--ink);
  background:rgba(142,59,32,.12);
  font-size:.95rem;
  letter-spacing:.02em;
  text-transform:uppercase;
  transition:background .3s, transform .3s;
  white-space:nowrap;
}
.ig-callout__btn:hover{
  background:var(--oxide);
  transform:translateX(4px);
}
.ig-callout__btn .arrow{font-family:var(--serif);font-style:italic;font-size:1.1rem}

@media (max-width:760px){
  .ig-callout__inner{grid-template-columns:1fr;gap:24px;text-align:left}
  .ig-callout__btn{justify-self:start}
}

/* Two-column owners variant */
.owners__grid--two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);
}
@media (max-width:780px){
  .owners__grid--two{grid-template-columns:1fr;gap:40px}
}

/* Chooser without background video */
.chooser--lean{
  background:
    radial-gradient(ellipse at 50% 0%, rgba(142,59,32,.08) 0%, transparent 55%),
    var(--deep);
}

/* Hero — IG link style in top-right (was partner badge) */
.hero__kahn{
  color:var(--ink-70);
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:color .3s;
}
.hero__kahn:hover{color:var(--ink)}

/* v4.0 — project page gallery headings */
.pd-gallery-head{
  max-width:var(--col-max);
  margin:0 auto clamp(32px,4vw,56px);
  padding:0 var(--gutter);
}
.pd-gallery-head h2{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.05;
  margin-top:20px;
}

/* ============================================================
   v4.1 — header accent videos + twin-feature projects strip
   ============================================================ */

/* Generic header accent video — portrait, muted, looping, visual anchor */
.header-accent{
  display:block;
  width:100%;
  max-width:380px;
  aspect-ratio:3/4;
  object-fit:cover;
  background:var(--raised);
  filter:brightness(.92) saturate(1.05);
  border-radius:1px;
  margin-bottom:28px;
}

/* Homepage method teaser — right column gets video + p stacked */
.chapters__head--accent .chapters__head-right{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
}
.chapters__head--accent .chapters__head-right .header-accent{margin-bottom:20px}
.chapters__head--accent .chapters__head-right p{
  color:var(--ink-70);
  max-width:40ch;
  font-size:1.05rem;
  line-height:1.6;
}

/* approach.html journey header — same pattern */
.journey__head--accent .journey__head-right{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
}
.journey__head--accent .journey__head-right .header-accent{margin-bottom:24px}
.journey__head--accent .journey__head-right p{
  color:var(--ink-70);
  max-width:42ch;
  font-size:1.05rem;
  line-height:1.6;
}

/* approach.html trust/included header — same pattern */
.trust__head--accent .trust__head-right{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
}
.trust__head--accent .trust__head-right .header-accent{margin-bottom:24px}
.trust__head--accent .trust__head-right p{
  color:var(--ink-70);
  max-width:42ch;
  font-size:1.05rem;
  line-height:1.6;
}

/* approach.html payment header — different: big title+body block + video side */
.payment__head--accent{
  max-width:var(--col-max);
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:clamp(40px,5vw,80px);
  align-items:start;
}
.payment__head--accent .payment__head-left{
  max-width:62ch;
}
.payment__head--accent .header-accent{
  width:100%;
  max-width:420px;
  aspect-ratio:3/4;
  justify-self:end;
  margin-bottom:0;
  margin-top:8px;
}

/* Responsive: collapse accent videos on mobile (save bandwidth, avoid clutter) */
@media (max-width:900px){
  .chapters__head--accent .header-accent,
  .journey__head--accent .header-accent,
  .trust__head--accent .header-accent,
  .payment__head--accent .header-accent{
    max-width:280px;
    margin-bottom:20px;
  }
  .payment__head--accent{grid-template-columns:1fr;gap:28px}
  .payment__head--accent .header-accent{justify-self:start}
}
@media (max-width:640px){
  .chapters__head--accent .header-accent,
  .journey__head--accent .header-accent,
  .trust__head--accent .header-accent,
  .payment__head--accent .header-accent{
    display:none;
  }
}

/* Twin-feature projects strip — 2-row layout with Apolo & Falcon as feature cards */
.projects-strip__grid--twin{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-auto-rows:auto;
  gap:clamp(12px,1.6vw,24px);
}
.projects-strip__grid--twin .pc--feat{grid-column:span 8}
.projects-strip__grid--twin .pc--feat .project-card__frame{aspect-ratio:16/10}
.projects-strip__grid--twin .pc--std{grid-column:span 4}
.projects-strip__grid--twin .pc--std .project-card__frame{aspect-ratio:4/5}
@media (max-width:960px){
  .projects-strip__grid--twin .pc--feat,
  .projects-strip__grid--twin .pc--std{grid-column:span 12}
  .projects-strip__grid--twin .pc--feat .project-card__frame{aspect-ratio:16/10}
  .projects-strip__grid--twin .pc--std .project-card__frame{aspect-ratio:4/3}
}

/* ============================================================
   v5 — Breadcrumbs (visible + semantic, SEO boost)
   ============================================================ */
.breadcrumbs{
  max-width:var(--col-max);
  margin:0 auto;
  padding:clamp(80px,10vw,120px) var(--gutter) 0;
  font-size:.82rem;
  color:var(--ink-55);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.breadcrumbs__list{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  list-style:none;
  padding:0;
  margin:0;
}
.breadcrumbs__list a{
  color:var(--ink-70);
  text-decoration:none;
  transition:color .3s ease;
}
.breadcrumbs__list a:hover{color:var(--ink)}
.breadcrumbs__list .sep{
  color:var(--ink-55);
  opacity:.6;
  font-weight:300;
}
.breadcrumbs__list [aria-current="page"]{
  color:var(--ink);
  font-style:italic;
  font-family:var(--serif);
  text-transform:none;
  letter-spacing:0;
  font-size:.95rem;
}

@media (max-width:640px){
  .breadcrumbs{padding-top:90px;font-size:.72rem}
  .breadcrumbs__list{gap:6px}
}

/* ============================================================
   404 page
   ============================================================ */
.not-found{
  min-height:70vh;
  display:flex;
  align-items:center;
  padding:clamp(120px,18vh,200px) var(--gutter) clamp(80px,12vh,140px);
  position:relative;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(142,59,32,.06) 0%, transparent 60%),
    var(--bg);
}
.not-found__inner{
  max-width:900px;
  margin:0 auto;
  width:100%;
}
.not-found__title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(3.2rem,8vw,7rem);
  line-height:.95;
  letter-spacing:-.01em;
  margin:28px 0 40px;
}
.not-found__title .italic{color:var(--oxide)}
.not-found__title .break{display:block}
.not-found__body{
  color:var(--ink-70);
  font-size:clamp(1rem,1.2vw,1.15rem);
  line-height:1.6;
  max-width:52ch;
  margin-bottom:48px;
}
.not-found__ctas{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
