/* ════════════════════════════════════════════════════════════════
   RECOIL STRATEGY — V6
   Quanta-adapted LIGHT editorial system, warm off-white + FDE
   Architecture built for Cowork ingestion
   ════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap');

/* ════ Tokens ═══════════════════════════════════════════════════ */
:root{
  /* Surfaces — warm off-white, almost white (Aesop / Loro Piana feel) */
  --bg:#F9F6EF;
  --bg-2:#F4F0E5;
  --surface:#FFFFFF;
  --surface-2:#FBF8F1;

  /* Ink — deep warm near-black */
  --ink:#14110D;
  --ink-2:rgba(20,17,13,.66);
  --ink-3:rgba(20,17,13,.44);
  --muted:rgba(20,17,13,.26);

  /* Lines — subtle warm darks */
  --line:rgba(20,17,13,.08);
  --line-2:rgba(20,17,13,.14);
  --line-3:rgba(20,17,13,.22);

  /* Accent — Flat Dark Earth, deepened for light bg readability */
  --fde:#806A48;
  --fde-soft:#A89373;
  --fde-deep:#5C4830;
  --fde-darker:#3D2F1F;
  --halo:rgba(128,106,72,.18);
  --halo-soft:rgba(128,106,72,.08);

  /* Type families */
  --display:"Monument Extended","Schibsted Grotesk","Geist",system-ui,sans-serif;
  /* legacy alias, no longer a serif: accents are now set in the grotesk display */
  --serif:"Schibsted Grotesk","Geist",system-ui,sans-serif;
  --body:"Geist",system-ui,-apple-system,sans-serif;
  /* "mono" = libellés, boutons, sur-titres : désormais Montserrat (plus en monospace) */
  --mono:"Montserrat","Geist",system-ui,sans-serif;
  --code:"Geist Mono",ui-monospace,monospace;

  /* Motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);

  /* Layout */
  --max:1320px;
  --pad-x:clamp(28px,6vw,56px);

  /* Vertical rhythm — strict scale, no overlap */
  --sec-y:clamp(110px,14vw,180px);
  --sec-y-sm:clamp(70px,9vw,110px);
  --sec-y-lg:clamp(140px,17vw,220px);
}

/* ════ Reset ════════════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--fde);color:#FFFFFF}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}

/* Subtle paper grain — adds tactile texture to off-white surface */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:200;
  opacity:.035;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .12  0 0 0 0 .10  0 0 0 0 .07  0 0 0 .7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ════ Layout primitives ════════════════════════════════════════ */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.sec{position:relative;padding-top:var(--sec-y);padding-bottom:var(--sec-y)}
.sec-sm{padding-top:var(--sec-y-sm);padding-bottom:var(--sec-y-sm)}
.sec-lg{padding-top:var(--sec-y-lg);padding-bottom:var(--sec-y-lg)}
.sec-tight{padding-top:var(--sec-y);padding-bottom:var(--sec-y-sm)}

/* ════ Typography ═══════════════════════════════════════════════ */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:-.025em;color:var(--ink)}

.dpy-xl{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(2.6rem,7.2vw,6.4rem);
  line-height:1.04;
  letter-spacing:-.025em;
}
.dpy-lg{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(1.6rem,3.3vw,2.85rem);
  line-height:1.06;
  letter-spacing:-.02em;
}
.dpy-md{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(1.45rem,2.5vw,2rem);
  line-height:1.12;
  letter-spacing:-.018em;
}
.dpy-sm{
  font-family:var(--display);
  font-weight:600;
  font-size:clamp(1.1rem,1.6vw,1.35rem);
  line-height:1.18;
  letter-spacing:-.014em;
}

/* Accent typographique : grotesk lourd, plus de sérif inclinée */
.serif-it{font-family:var(--display);font-style:normal;font-weight:800;letter-spacing:-.035em}
.lead{
  font-size:clamp(1.05rem,1.4vw,1.22rem);
  line-height:1.55;
  color:var(--ink-2);
  font-weight:400;
  max-width:54ch;
}
.body-sm{font-size:15px;color:var(--ink-2);line-height:1.55}
.mono{font-family:var(--mono);font-weight:400}
.tan{color:var(--fde)}

.eye{
  font-family:var(--mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-3);
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eye .dot{
  width:5px;height:5px;border-radius:50%;flex:0 0 auto;
  align-self:flex-start;margin-top:.42em;
  background:var(--fde);
  box-shadow:0 0 10px 1px var(--halo);
}

/* ════ Background atmosphere — soft warm tints on cream ═══════ */
.atmos{position:fixed;inset:0;z-index:-1;overflow:hidden;background:var(--bg);pointer-events:none}
.atmos::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 700px at 50% -8%,rgba(128,106,72,.04),transparent 55%),
    radial-gradient(700px 600px at 92% 35%,rgba(128,106,72,.025),transparent 60%),
    radial-gradient(800px 700px at 8% 75%,rgba(128,106,72,.02),transparent 55%);
}
.atmos::after{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(to right,var(--line) 1px,transparent 1px);
  background-size:calc(100% / 12) 100%;
  opacity:.5;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent 60%);
  -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent 60%);
}

/* ════ Top progress + cursor halo ══════════════════════════════ */
.progress{
  position:fixed;top:0;left:0;height:1px;width:0;
  background:var(--fde);z-index:300;transition:width .1s linear;
}
.cursor-halo{
  position:fixed;z-index:1;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(128,106,72,.08),transparent 65%);
  transform:translate(-50%,-50%);
  pointer-events:none;
  opacity:0;transition:opacity .6s;
  mix-blend-mode:multiply;
}

/* ════ Header ══════════════════════════════════════════════════
   3 états :
   - At top (no class) : full-width header transparent
   - .is-pill : pill flottant centré dark, transitions douces
   - .is-hidden : translateY off-screen
   ═════════════════════════════════════════════════════════════ */
header.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  border-bottom:1px solid transparent;
  transition:transform .55s var(--ease),padding .5s var(--ease);
  will-change:transform;
}
header.site-header .wrap{
  transition:max-width .55s var(--ease),padding .55s var(--ease);
}
.bar{
  display:flex;align-items:center;justify-content:space-between;
  height:84px;
  transition:
    height .45s var(--ease),
    padding .45s var(--ease),
    background .35s var(--ease),
    border-radius .55s var(--ease),
    box-shadow .35s var(--ease),
    color .35s var(--ease);
}

/* ─── State B: pill flottant centré ─── */
header.site-header.is-pill{padding-top:18px}
header.site-header.is-pill .wrap{max-width:880px;padding:0 16px}
header.site-header.is-pill .bar{
  height:60px;
  padding:0 6px 0 24px;
  background:var(--ink);
  border-radius:100px;
  box-shadow:
    0 16px 40px -14px rgba(20,17,13,.32),
    0 6px 18px -10px rgba(20,17,13,.18);
}

/* ─── State C: hidden ─── */
header.site-header.is-hidden{transform:translateY(-130%)}

/* ── Brand ── */
.brand{display:inline-flex;align-items:center;gap:12px;line-height:1;transition:color .35s var(--ease)}
.brand-mark{
  width:34px;height:34px;border-radius:9px;
  background:var(--ink);
  display:grid;place-items:center;
  color:var(--bg);
  font-family:var(--display);font-weight:700;font-size:15px;
  transition:background .35s var(--ease),color .35s var(--ease),width .4s var(--ease),height .4s var(--ease);
}
.brand-word{
  font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.01em;
  color:var(--ink);transition:color .35s var(--ease);
}
.brand-word small{
  display:block;
  font-family:var(--mono);font-weight:400;font-size:9px;
  letter-spacing:.28em;color:var(--ink-3);margin-top:3px;
  transition:color .35s var(--ease);
}

/* In pill: invert brand colors */
header.site-header.is-pill .brand-mark{
  background:var(--bg);color:var(--ink);
  width:30px;height:30px;border-radius:8px;font-size:13px;
}
header.site-header.is-pill .brand-word{color:var(--bg)}
header.site-header.is-pill .brand-word small{color:rgba(249,246,239,.45)}

/* ── Nav ── */
nav.nav{display:flex;gap:36px;transition:gap .4s var(--ease)}
nav.nav a{
  font-size:14px;color:var(--ink-2);position:relative;
  transition:color .3s;padding:6px 0;
}
nav.nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--fde);transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease),background .35s var(--ease);
}
nav.nav a:hover,nav.nav a.is-current{color:var(--ink)}
nav.nav a:hover::after,nav.nav a.is-current::after{transform:scaleX(1)}

/* In pill: light nav text on dark bg */
header.site-header.is-pill nav.nav{gap:26px}
header.site-header.is-pill nav.nav a{color:rgba(249,246,239,.65);font-size:13px}
header.site-header.is-pill nav.nav a:hover,
header.site-header.is-pill nav.nav a.is-current{color:var(--bg)}
header.site-header.is-pill nav.nav a::after{background:var(--bg)}

.hcta{display:flex;align-items:center;gap:14px;transition:gap .4s var(--ease)}
header.site-header.is-pill .hcta{gap:10px}
header.site-header.is-pill .lang{color:rgba(249,246,239,.4)}
header.site-header.is-pill .lang b{color:var(--bg)}

/* In pill: CTA becomes cream-on-dark capsule (high contrast) */
header.site-header.is-pill .hcta .btn-p{
  background:var(--bg);
  color:var(--ink);
  padding:11px 20px;
  font-size:11.5px;
  box-shadow:none;
}
header.site-header.is-pill .hcta .btn-p:hover{
  background:var(--fde-soft);
  transform:none;
}

/* In pill: burger inverted */
header.site-header.is-pill .burger{
  color:var(--bg);
}
.lang{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--ink-3)}
.lang b{color:var(--ink)}
.burger{display:none;width:44px;height:44px;border:0;background:transparent;padding:0;color:var(--ink);font-size:26px;line-height:1;align-items:center;justify-content:center}

/* ════ Buttons ═════════════════════════════════════════════════ */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:11px;
  padding:15px 26px;
  font-family:var(--mono);font-size:12px;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  border-radius:100px;
  border:1px solid transparent;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),color .35s,border-color .35s,background .35s;
  will-change:transform;
  white-space:nowrap;
}
.btn .arr{transition:transform .4s var(--ease);display:inline-block}
.btn:hover .arr{transform:translateX(4px)}
/* Primary CTA — solid deep ink, cream text (Aesop / Loro Piana feel) */
.btn-p{
  background:var(--ink);
  color:var(--bg);font-weight:500;
  box-shadow:0 6px 22px -10px rgba(20,17,13,.35);
}
.btn-p:hover{
  background:var(--fde-deep);
  transform:translateY(-1.5px);
  box-shadow:0 10px 28px -10px rgba(20,17,13,.4);
}
.btn-g{border-color:var(--line-3);color:var(--ink)}
.btn-g:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}

.tlink{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-2);
  padding:8px 0;border-bottom:1px solid var(--line-2);
  transition:color .3s,border-color .3s,gap .35s var(--ease);
}
.tlink:hover{color:var(--fde);border-color:var(--fde);gap:14px}

/* ════ Reveal animations ═══════════════════════════════════════ */
.reveal{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.08em}
.reveal > span{
  display:inline-block;
  transform:translateY(110%);
  transition:transform 1.1s var(--ease);
  transition-delay:calc(var(--i,0) * .07s + .15s);
}
.reveal.in > span{transform:translateY(0)}

.fade-up{opacity:0;transform:translateY(28px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.fade-up.in{opacity:1;transform:none}
.fade-up[data-d="1"]{transition-delay:.1s}
.fade-up[data-d="2"]{transition-delay:.2s}
.fade-up[data-d="3"]{transition-delay:.3s}
.fade-up[data-d="4"]{transition-delay:.4s}

/* ════ Section heads — universal ═══════════════════════════════ */
.shead{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(40px,7vw,90px);
  align-items:end;
  margin-bottom:clamp(60px,8vw,96px);
  padding-bottom:34px;
  border-bottom:1px solid var(--line);
}
.shead-stack{
  grid-template-columns:1fr;
  align-items:start;
  gap:30px;
}
.shead .lbl{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-3);
  display:flex;flex-direction:column;gap:14px;min-width:120px;
}
.shead .lbl b{color:var(--fde);font-weight:500;font-size:11px}
.shead h2{max-width:18ch}
.shead-row{display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap;width:100%}

/* ════ Hero — home page ═══════════════════════════════════════ */
.hero{
  padding-top:clamp(140px,18vh,200px);
  padding-bottom:clamp(80px,10vw,130px);
  text-align:center;
  position:relative;
}
.hero-eye{justify-content:center;margin-bottom:34px}
.hero h1{margin-bottom:30px}
.hero h1 .line{display:block}
.hero-sub{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(1.1rem,1.7vw,1.4rem);
  color:var(--ink);
  max-width:32ch;
  margin:0 auto 22px;
  letter-spacing:-.01em;
}
.hero .lead{margin:0 auto;text-align:center}
.hero-row{
  display:flex;gap:14px;flex-wrap:wrap;justify-content:center;
  margin-top:42px;
}
.scrollcue{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:inline-flex;flex-direction:column;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-3);
  opacity:0;animation:fade-in 1.2s 1.6s var(--ease) forwards;
}
.scrollcue::after{
  content:"";display:inline-block;width:1px;height:24px;
  background:linear-gradient(180deg,var(--fde),transparent);
  animation:cue 2.2s ease-in-out infinite;
}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}
@keyframes fade-in{to{opacity:1}}

/* ════ Page hero (sub-pages) ══════════════════════════════════ */
.page-hero{
  padding-top:clamp(160px,20vh,220px);
  padding-bottom:clamp(60px,9vw,120px);
  border-bottom:1px solid var(--line);
}
.page-hero .crumbs{
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:36px;
}
.page-hero .crumbs a{transition:color .3s}
.page-hero .crumbs a:hover{color:var(--fde)}
.page-hero .crumbs .sep{color:var(--muted)}
.page-hero h1{margin-bottom:28px;max-width:18ch}
.page-hero .lead{max-width:62ch}
.page-hero .meta{
  display:flex;flex-wrap:wrap;gap:28px 56px;
  margin-top:50px;padding-top:30px;border-top:1px solid var(--line);
}
.page-hero .meta-item{
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);
}
.page-hero .meta-item b{
  color:var(--ink);font-weight:500;font-size:14px;
  letter-spacing:.02em;font-family:var(--display);text-transform:none;
}

/* ════ Strip / marquee ═════════════════════════════════════════ */
.strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:34px 0;
  overflow:hidden;
  position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
}
.strip-label{
  position:absolute;left:50%;top:-10px;transform:translateX(-50%);
  background:var(--bg);padding:0 16px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-3);
}
.strip-track{
  display:flex;gap:74px;align-items:center;width:max-content;
  animation:scrollx 42s linear infinite;
}
.strip-track span{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.1rem,1.7vw,1.4rem);
  color:var(--muted);letter-spacing:-.005em;white-space:nowrap;
  transition:color .4s;
}
.strip-track span:hover{color:var(--ink-2)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ════ Bande de confiance ══════════════════════════════════════ */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(24px,3vw,48px);
  padding-top:clamp(40px,5vw,62px);padding-bottom:clamp(40px,5vw,62px);
}
.trust-item{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;text-align:center}
.trust-item b{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.15rem,1.9vw,1.75rem);
  color:var(--fde);letter-spacing:-.02em;line-height:1.04;white-space:nowrap;
}
.trust-item span{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-3);
}
@media(max-width:760px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:36px 20px}}

/* ════ Manifest / About short ═════════════════════════════════ */
.manifest{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:clamp(40px,7vw,100px);
  align-items:start;
}
.manifest .big{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.45rem,2.5vw,2.2rem);
  line-height:1.06;letter-spacing:-.02em;color:var(--ink);
}
.manifest .big em{font-family:var(--display);font-style:normal;font-weight:700;letter-spacing:-.02em;color:var(--fde)}
.manifest .side{padding-top:18px;border-top:1px solid var(--line)}
.manifest .side p{color:var(--ink-2);font-size:15.5px;line-height:1.65;margin-bottom:18px}
.manifest .side .sig{
  margin-top:30px;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}

/* ════ Studio / portrait block ════════════════════════════════ */
.studio{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:clamp(40px,7vw,100px);
  align-items:start;
}
.studio-portrait{position:sticky;top:120px}
.portrait-frame{
  position:relative;
  aspect-ratio:4/5;
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(165deg,#ECE7DA,#F9F6EF);
  border:1px solid var(--line-2);
  isolation:isolate;
}
.portrait-frame::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(500px circle at 30% 25%,rgba(157,138,108,.18),transparent 60%),
    radial-gradient(400px circle at 70% 90%,rgba(157,138,108,.08),transparent 60%);
}
.portrait-frame::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.45;mix-blend-mode:overlay;
}
/* When Hugo plugs his real photo: set background-image on .portrait-photo */
.portrait-photo{position:absolute;inset:0;background-size:cover;background-position:center 30%;background-repeat:no-repeat;filter:grayscale(.12) contrast(1.04);z-index:1}
.portrait-frame.has-photo{background:#15140f}
.portrait-frame.has-photo::before,.portrait-frame.has-photo::after{display:none}
.portrait-frame.has-photo .portrait-inner{justify-content:flex-end}
.portrait-frame.has-photo .portrait-mono{color:rgba(249,246,239,.94);text-shadow:0 1px 10px rgba(0,0,0,.5)}
.portrait-inner{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:28px;
}
.portrait-mono{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-3);
}
.portrait-mark{
  align-self:flex-end;
  font-family:var(--display);font-weight:500;
  font-size:clamp(4rem,9vw,7.5rem);
  line-height:.85;letter-spacing:-.04em;
  color:var(--fde-soft);text-align:right;
}
.portrait-caption{
  display:inline-flex;align-items:center;gap:10px;margin-top:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  color:var(--ink-3);text-transform:uppercase;
}
.dot-fde{
  width:7px;height:7px;border-radius:50%;background:var(--fde);
  box-shadow:0 0 10px var(--halo);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{50%{opacity:.5;transform:scale(.85)}}

.studio-text{padding-top:8px}
.studio-meta{
  display:grid;grid-template-columns:1fr;gap:0;
  margin-top:42px;border-top:1px solid var(--line);
}
.meta-cell{
  padding:22px 0;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:140px 1fr;gap:24px;
  align-items:baseline;
  font-size:15px;color:var(--ink-2);
}
.meta-cell b{
  font-family:var(--mono);font-weight:400;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}

/* ════ Choices grid (four-bad-choices) ════════════════════════ */
.choices{margin-top:clamp(20px,3vw,40px)}
.choice{
  display:grid;
  grid-template-columns:60px 1fr 1.4fr auto;
  gap:clamp(20px,4vw,60px);
  align-items:center;
  padding:clamp(34px,4vw,52px) 0;
  border-top:1px solid var(--line);
  transition:padding-left .5s var(--ease),background .5s var(--ease);
  position:relative;cursor:default;
}
.choice:last-child{border-bottom:1px solid var(--line)}
.choice:hover{padding-left:14px}
.choice::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--fde);transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease);
}
.choice:hover::before{transform:scaleY(1)}
.choice .num{font-family:var(--mono);font-size:12px;color:var(--ink-3);letter-spacing:.12em}
.choice h3{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:-.02em}
.choice .desc{color:var(--ink-2);font-size:15.5px;line-height:1.55;max-width:42ch}
.choice .tag{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line-2);border-radius:100px;padding:7px 14px;
}

.punch{
  margin-top:clamp(50px,6vw,80px);
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.6rem,3vw,2.4rem);
  line-height:1.18;letter-spacing:-.022em;
  max-width:28ch;color:var(--ink);
}
.punch em{font-family:var(--display);font-style:normal;font-weight:800;letter-spacing:-.035em;color:var(--fde)}

/* ════ Services list (Quanta vertical) ════════════════════════ */
.svc-list{border-top:1px solid var(--line-2)}
.svc{
  position:relative;
  display:grid;
  grid-template-columns:clamp(110px,14vw,200px) 1fr clamp(220px,30vw,360px);
  gap:clamp(24px,4vw,60px);
  padding:clamp(40px,5vw,64px) 0;
  border-bottom:1px solid var(--line-2);
  align-items:start;
  transition:padding-left .55s var(--ease);
  overflow:hidden;
}
.svc:hover{padding-left:18px}
.svc::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--fde);transform:scaleY(0);transform-origin:top;
  transition:transform .55s var(--ease);
}
.svc:hover::before{transform:scaleY(1)}
.svc::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px circle at var(--mx,50%) var(--my,50%),rgba(157,138,108,.04),transparent 55%);
  opacity:0;transition:opacity .6s;pointer-events:none;
}
.svc:hover::after{opacity:1}

.svc-num{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2rem,3.6vw,3.4rem);
  line-height:.9;letter-spacing:-.025em;
  color:var(--ink-3);transition:color .55s;
}
.svc-num small{
  display:block;font-family:var(--mono);font-weight:400;
  font-size:10.5px;letter-spacing:.2em;
  color:var(--ink-3);margin-top:14px;text-transform:uppercase;
}
.svc:hover .svc-num{color:var(--fde)}
.svc-body h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.6rem,3vw,2.6rem);
  letter-spacing:-.026em;line-height:1.08;color:var(--ink);
  transition:color .45s;
}
.svc:hover .svc-body h3{color:var(--fde-soft)}
.svc-body p{
  color:var(--ink-2);font-size:16px;line-height:1.6;
  margin-top:18px;max-width:52ch;
}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;padding-top:6px}
.svc-tags .tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line);border-radius:100px;padding:7px 13px;
  transition:color .35s,border-color .35s;
}
.svc:hover .svc-tags .tag{border-color:var(--line-2);color:var(--ink-2)}

/* ════ Service detail block (services.html) ══════════════════ */
.svc-detail{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(40px,6vw,90px);
  padding-top:clamp(60px,8vw,110px);padding-bottom:clamp(60px,8vw,110px);
  border-top:1px solid var(--line);
}
.svc-detail .left{position:sticky;top:120px;align-self:start}
.svc-detail .left .num{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--fde);margin-bottom:18px;display:block;
}
.svc-detail h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:1.02;letter-spacing:-.03em;
}
.svc-detail .left p{color:var(--ink-2);font-size:16px;line-height:1.65;margin-top:24px;max-width:42ch}
.svc-detail .right ul{list-style:none;display:grid;gap:18px}
.svc-detail .right li{
  display:grid;grid-template-columns:40px 1fr;gap:18px;
  padding:22px 0;border-bottom:1px solid var(--line);
  font-size:15.5px;color:var(--ink-2);line-height:1.55;
}
.svc-detail .right li b{
  display:block;color:var(--ink);font-weight:500;font-size:15.5px;
  margin-bottom:4px;font-family:var(--display);
}
.svc-detail .right li .icn{
  font-family:var(--mono);font-size:13px;color:var(--fde);
  letter-spacing:.1em;padding-top:1px;
}

/* ════ Proof / stat band ══════════════════════════════════════ */
.stat-band{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,7vw,100px);align-items:end;
  padding:clamp(60px,8vw,100px) 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.proof-big{
  font-family:var(--display);font-weight:600;
  font-size:clamp(5rem,13vw,11rem);
  line-height:.85;letter-spacing:-.045em;color:var(--fde);
}
.proof-big sup{font-size:.4em;vertical-align:super;font-weight:500;color:var(--fde-deep)}

/* ════ Geo / AI block ═════════════════════════════════════════ */
.geo-block{
  position:relative;
  border:1px solid var(--line-2);
  border-radius:24px;
  padding:clamp(40px,5vw,72px);
  background:linear-gradient(160deg,#ECE7DA,#F4F0E5);
  overflow:hidden;
}
.geo-block::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(600px circle at 88% -10%,rgba(157,138,108,.14),transparent 55%),
    radial-gradient(500px circle at 0% 90%,rgba(157,138,108,.06),transparent 55%);
  pointer-events:none;
}
.geo-block > *{position:relative}
.geo-block h3{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,3vw,2.6rem);
  letter-spacing:-.025em;line-height:1.1;
  max-width:22ch;margin:20px 0 18px;
}
.ai-btns{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}
.ai-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 20px;border:1px solid var(--line-2);border-radius:100px;
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--ink-2);
  transition:color .35s,border-color .35s,background .35s,transform .35s var(--ease);
}
.ai-btn:hover{color:var(--ink);border-color:var(--fde);background:rgba(157,138,108,.04);transform:translateY(-1px)}
.ai-btn .dot{width:6px;height:6px;border-radius:50%;background:var(--fde);box-shadow:0 0 8px var(--halo)}

/* ════ Work stack — Quanta sticky reveal ═════════════════════ */
.work-stack-section{
  padding-top:var(--sec-y);
  padding-bottom:clamp(40px,5vw,80px);
}
.work-stack-section .shead{margin-bottom:clamp(50px,6vw,80px)}

.work-stack{
  display:flex;flex-direction:column;
  gap:clamp(30px,4vw,60px);
}
.work-item{
  position:sticky;
  top:100px;
}
.work-card{
  display:block;position:relative;
  width:100%;
  aspect-ratio:16/10;
  max-height:82vh;
  border-radius:22px;overflow:hidden;
  background:#F4F0E5;
  border:1px solid var(--line-2);
  isolation:isolate;cursor:pointer;
  transition:border-color .4s,transform .6s var(--ease);
  box-shadow:0 20px 50px -28px rgba(20,17,13,.12);
}
.work-card:hover{border-color:var(--line-3)}

/* Layer 1: photo (background-image when ready) or placeholder gradient */
.work-photo{
  position:absolute;inset:0;z-index:1;
  background:var(--work-grad,linear-gradient(135deg,#ECE7DA,#F9F6EF));
  background-size:cover;background-position:center;
  transition:transform .8s var(--ease);
}
.work-card:hover .work-photo{transform:scale(1.035)}

/* Layer 2: grain */
.work-card::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .22 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.35;mix-blend-mode:overlay;
}

/* Layer 3: always-visible tiny number top-left */
.work-num{
  position:absolute;top:clamp(20px,2vw,30px);left:clamp(20px,2vw,30px);
  z-index:4;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-2);
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:8px 14px;border-radius:100px;border:1px solid rgba(20,17,13,.1);
}
.work-num b{color:var(--fde);font-weight:500;margin-right:8px}

/* Layer 4: hover overlay with title + description */
.work-overlay{
  position:absolute;inset:0;z-index:3;
  padding:clamp(34px,5vw,72px);
  display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(180deg,transparent 35%,rgba(249,246,239,.72) 70%,rgba(249,246,239,.94) 100%);
  opacity:0;
  transition:opacity .55s var(--ease);
}
.work-card:hover .work-overlay{opacity:1}

.work-overlay .work-cat{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--fde);margin-bottom:18px;
  transform:translateY(20px);
  transition:transform .55s var(--ease);
}
.work-overlay h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.8rem,4.2vw,3.6rem);
  letter-spacing:-.028em;color:var(--ink);
  margin-bottom:18px;line-height:1;max-width:18ch;
  transform:translateY(30px);
  transition:transform .6s var(--ease) .05s;
}
.work-overlay h3 em{font-family:var(--display);font-style:normal;font-weight:800;color:var(--fde)}
.work-overlay p{
  color:rgba(20,17,13,.78);font-size:15.5px;line-height:1.55;
  max-width:48ch;margin-bottom:28px;
  transform:translateY(40px);
  transition:transform .65s var(--ease) .1s;
}
.work-cta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding-bottom:6px;width:fit-content;
  transform:translateY(50px);
  transition:transform .7s var(--ease) .15s,color .3s,border-color .3s,gap .3s var(--ease);
}
.work-card:hover .work-overlay .work-cat,
.work-card:hover .work-overlay h3,
.work-card:hover .work-overlay p,
.work-card:hover .work-overlay .work-cta{transform:translateY(0)}
.work-card:hover .work-cta{color:var(--fde);border-color:var(--fde);gap:14px}

/* Placeholder tints — replaced by real photos via .work-photo background-image */
.work-card.v1 .work-photo{--work-grad:radial-gradient(85% 75% at 50% 40%,#FFFFFF 0%,#F4F0E5 70%,#E8E1CE 100%)}
.work-card.v2 .work-photo{--work-grad:radial-gradient(80% 70% at 55% 45%,#FCFAF4 0%,#EDE9DB 65%,#E0D9C6 100%)}
.work-card.v3 .work-photo{--work-grad:radial-gradient(85% 70% at 45% 50%,#FFFFFF 0%,#F0EBDC 65%,#E4DCC4 100%)}
.work-card.v4 .work-photo{--work-grad:radial-gradient(80% 75% at 50% 45%,#FBF7EE 0%,#EAE3D0 65%,#DDD4BC 100%)}
.work-card.v5 .work-photo{--work-grad:radial-gradient(80% 70% at 55% 50%,#FFFFFF 0%,#EFE9D6 65%,#E1D8BE 100%)}

/* End-of-stack: "See all works" link */
.work-stack-end{
  position:sticky;top:auto;
  display:flex;justify-content:center;
  padding:clamp(40px,5vw,80px) 0 0;
}

/* ════ Pin scroll — Selected Works ════════════════════════════ */
.pin{position:relative}
.pin-sticky{
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
.pin-head-wrap{padding:0 var(--pad-x);width:100%;max-width:var(--max);margin:0 auto;margin-bottom:clamp(34px,4vw,56px)}
.pin-track{display:flex;gap:32px;padding:0 var(--pad-x);will-change:transform}
.pin-indicator{
  position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  color:var(--ink-3);text-transform:uppercase;
}
.pin-indicator .bar{
  width:120px;height:1px;background:var(--line-2);position:relative;overflow:hidden;
}
.pin-indicator .bar::after{
  content:"";position:absolute;left:0;top:0;height:100%;width:var(--p,0%);
  background:var(--fde);transition:width .15s linear;
}

.proj{flex:0 0 min(62vw,680px);display:flex;flex-direction:column}
.proj-art{
  position:relative;aspect-ratio:4/5;
  border-radius:20px;overflow:hidden;
  background:#F4F0E5;border:1px solid var(--line);
  margin-bottom:26px;isolation:isolate;
  transition:transform .8s var(--ease),border-color .55s;
}
.proj:hover .proj-art{transform:scale(1.012);border-color:var(--line-2)}

/* Layer 1: placeholder gradient OR real photo via .proj-photo */
.proj-art::before{
  content:"";position:absolute;inset:0;
  background:var(--art-grad,linear-gradient(135deg,#ECE7DA,#F9F6EF));
}
.proj-photo{
  position:absolute;inset:0;z-index:1;
  background-size:cover;background-position:center;
  filter:contrast(1.04) saturate(.9);
}

/* Layer 2: subtle grain */
.proj-art::after{
  content:"";position:absolute;inset:0;z-index:2;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.35;mix-blend-mode:overlay;pointer-events:none;
}

/* Layer 3: bottom-to-top dark gradient for text legibility (Quanta cover) */
.proj-art .pscrim{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(180deg,transparent 35%,rgba(249,246,239,.72) 78%,rgba(249,246,239,.94) 100%);
}

/* Layer 4: top-left meta + bottom-center title block */
.proj-art .pinner{
  position:absolute;inset:0;z-index:4;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:clamp(24px,3vw,34px);
}
.proj-art .ptop{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-2);
}
.proj-art .ptop .pnum{color:var(--fde)}
.proj-art .pcover{
  text-align:center;
  padding:0 clamp(16px,3vw,40px) clamp(8px,1vw,16px);
}
.proj-art .ptype-pill{
  display:inline-block;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--fde);
  margin-bottom:14px;
}
.proj-art .ptitle{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.6rem,3.4vw,2.6rem);
  letter-spacing:.005em;text-transform:uppercase;color:var(--ink);
  line-height:1;margin-bottom:14px;
}
.proj-art .ptitle .reg{font-size:.5em;vertical-align:super;color:var(--fde);margin-left:2px;font-weight:500}
.proj-art .psub{
  color:rgba(20,17,13,.74);font-size:13.5px;line-height:1.5;
  max-width:42ch;margin:0 auto;
}

.proj.v1 .proj-art{--art-grad:radial-gradient(80% 60% at 50% 45%,#FFFFFF 0%,#1a140d 55%,#F9F6EF 100%)}
.proj.v2 .proj-art{--art-grad:radial-gradient(90% 70% at 50% 50%,#FFFFFF 0%,#F9F6EF 60%,#F9F6EF 100%)}
.proj.v3 .proj-art{--art-grad:radial-gradient(75% 55% at 50% 40%,#FBF8F1 0%,#F0ECDF 55%,#F9F6EF 100%)}
.proj.v4 .proj-art{--art-grad:radial-gradient(85% 65% at 50% 50%,#FBF8F1 0%,#F0ECDF 55%,#F9F6EF 100%)}
.proj.v5 .proj-art{--art-grad:radial-gradient(80% 60% at 50% 45%,#FBF8F1 0%,#F4F0E5 55%,#F9F6EF 100%)}
.proj.v6 .proj-art{--art-grad:radial-gradient(80% 60% at 50% 50%,#FFFFFF 0%,#EFEBE0 55%,#F9F6EF 100%)}

.proj-info{padding:0 4px}
.proj-tagline{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fde);margin-bottom:14px;
}
.proj-meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:10px}
.proj-meta h3{font-family:var(--display);font-weight:600;font-size:clamp(1.25rem,1.9vw,1.55rem);letter-spacing:-.015em;line-height:1.1}
.proj-meta .yr{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.1em;white-space:nowrap}
.proj-res{color:var(--ink-2);font-size:14.5px;line-height:1.5;max-width:42ch}

/* Project as a clickable card */
a.proj{cursor:pointer}
a.proj h3{transition:color .35s}
a.proj:hover h3{color:var(--fde)}

/* ════ Projects index grid (realisations.html) ════════════════ */
.proj-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:clamp(30px,4vw,60px);
}
.proj-grid .proj{flex:0 1 auto}
.proj-grid .proj-art{aspect-ratio:5/6}

.filter-bar{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-bottom:clamp(40px,5vw,60px);
}
.filter-bar button{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line);border-radius:100px;
  padding:9px 18px;transition:color .3s,border-color .3s,background .3s;
}
.filter-bar button.active,.filter-bar button:hover{
  color:var(--fde);border-color:var(--fde-deep);background:rgba(157,138,108,.04);
}

/* ════ Process / Steps ════════════════════════════════════════ */
.step{
  display:grid;grid-template-columns:90px 1fr;gap:30px;
  padding:clamp(38px,4.5vw,56px) 0;
  border-top:1px solid var(--line);
  transition:padding-left .55s var(--ease),background .55s;
  position:relative;
}
.step:last-child{border-bottom:1px solid var(--line)}
.step::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:1px;
  background:var(--fde);transform:scaleY(0);transform-origin:top;
  transition:transform .55s var(--ease);
}
.step:hover{padding-left:18px}
.step:hover::after{transform:scaleY(1)}
.step .sn{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--fde);padding-top:12px}
.step h3{font-family:var(--display);font-weight:600;font-size:clamp(1.5rem,2.4vw,2.1rem);letter-spacing:-.022em;margin-bottom:14px}
.step p{color:var(--ink-2);max-width:60ch;font-size:16px;line-height:1.6}

/* ════ Stats grid ═════════════════════════════════════════════ */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(20px,2.4vw,40px);
  border-top:1px solid var(--line);
}
.stat{
  padding:clamp(28px,3.4vw,46px) 0;
  border-right:1px solid var(--line);padding-right:24px;
}
.stat:last-child{border-right:0}
.stat .n{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.4rem,4.6vw,3.8rem);
  line-height:.95;letter-spacing:-.03em;color:var(--ink);
}
.stat .n .unit{font-size:.5em;color:var(--fde);font-weight:500}
.stat .l{margin-top:14px;font-size:13.5px;color:var(--ink-3);max-width:24ch;line-height:1.45}

/* ════ Photo marquee — Quanta floating polaroids ═══════════ */
.photo-marquee{
  position:relative;
  padding:clamp(80px,10vw,140px) 0 clamp(100px,12vw,160px);
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
}
.photo-marquee-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  flex-wrap:wrap;
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad-x) clamp(50px,6vw,80px);
}
.photo-marquee-head h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.7rem,3.2vw,2.6rem);
  letter-spacing:-.026em;line-height:1.1;
}
.photo-marquee-head h3 em{font-family:var(--display);font-style:normal;font-weight:800;letter-spacing:-.035em;color:var(--fde)}

.photo-track{
  display:flex;gap:clamp(28px,3.5vw,52px);width:max-content;
  align-items:center;
  animation:scrollx 80s linear infinite;
  padding:40px var(--pad-x);  /* room for rotations + shadows */
}
.photo-marquee:hover .photo-track{animation-play-state:paused}

.photo-card{
  position:relative;
  flex:0 0 clamp(280px,32vw,440px);
  aspect-ratio:3/4;
  border-radius:14px;
  overflow:hidden;
  background:var(--photo-grad,linear-gradient(155deg,#ECE7DA,#F9F6EF));
  isolation:isolate;
  box-shadow:
    0 24px 56px -22px rgba(20,17,13,.14),
    0 10px 28px -12px rgba(20,17,13,.10),
    0 0 0 1px rgba(255,255,255,.5) inset;
  will-change:transform;
  transition:transform 1.2s var(--ease);
}

/* Alternating tilts — polaroid feel */
.photo-card:nth-child(6n+1){transform:rotate(-2.4deg) translateY(8px)}
.photo-card:nth-child(6n+2){transform:rotate(1.6deg) translateY(-10px)}
.photo-card:nth-child(6n+3){transform:rotate(-1.2deg) translateY(4px)}
.photo-card:nth-child(6n+4){transform:rotate(2deg) translateY(-6px)}
.photo-card:nth-child(6n+5){transform:rotate(-1.8deg) translateY(2px)}
.photo-card:nth-child(6n+6){transform:rotate(.8deg) translateY(-4px)}

/* Subtle grain texture */
.photo-card::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .28 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.4;mix-blend-mode:overlay;
}

/* Real photo plugs in here */
.photo-card .pimg{
  position:absolute;inset:0;z-index:1;
  background-size:cover;background-position:center;
}

/* Tinted variants — light placeholders, replaced by real images later */
.photo-card.ph1{--photo-grad:radial-gradient(80% 70% at 50% 40%,#FFFFFF 0%,#F4EFE0 65%,#E6DEC8 100%)}
.photo-card.ph2{--photo-grad:radial-gradient(85% 70% at 55% 50%,#FBF7EE 0%,#EDE7D6 60%,#DED5BC 100%)}
.photo-card.ph3{--photo-grad:radial-gradient(75% 70% at 45% 45%,#FFFFFF 0%,#F1EBDA 55%,#E2D8BD 100%)}
.photo-card.ph4{--photo-grad:radial-gradient(80% 65% at 50% 50%,#FCF9F0 0%,#EAE3CF 60%,#DBD1B5 100%)}
.photo-card.ph5{--photo-grad:radial-gradient(75% 70% at 55% 45%,#FBF7EE 0%,#EFE9D6 55%,#E3DABE 100%)}
.photo-card.ph6{--photo-grad:radial-gradient(80% 70% at 50% 50%,#FFFFFF 0%,#EBE5D2 55%,#DDD3B8 100%)}
.photo-card.ph7{--photo-grad:radial-gradient(75% 65% at 50% 45%,#FFFFFF 0%,#F3EDDC 55%,#E5DCBE 100%)}
.photo-card.ph8{--photo-grad:radial-gradient(80% 70% at 50% 50%,#FBF7EE 0%,#ECE6D2 55%,#DED5B8 100%)}

/* ════ Reviews carousel ══════════════════════════════════════ */
.rev-wrap{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.rev-track{display:flex;gap:22px;width:max-content;animation:revx 55s linear infinite}
.rev-wrap:hover .rev-track{animation-play-state:paused}
@keyframes revx{to{transform:translateX(-50%)}}
.rev{
  flex:0 0 420px;
  border:1px solid var(--line);border-radius:18px;
  padding:32px;
  background:linear-gradient(180deg,#EFEBE0 0%,#F4F0E5 100%);
  display:flex;flex-direction:column;
  transition:border-color .4s,transform .55s var(--ease);
}
.rev:hover{border-color:var(--line-2);transform:translateY(-3px)}
.rev .stars{color:var(--fde);font-size:13px;letter-spacing:3px;margin-bottom:22px}
.rev .q{
  font-family:var(--display);font-weight:500;
  font-size:18px;line-height:1.45;letter-spacing:-.012em;color:var(--ink);flex:1;
}
.rev .who{
  display:flex;align-items:center;gap:14px;
  margin-top:28px;padding-top:22px;border-top:1px solid var(--line);
}
.rev .avi{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--fde-deep),var(--fde));
  display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:14px;color:#FBF8F1;
}
.rev .who b{display:block;font-family:var(--display);font-weight:600;font-size:14.5px}
.rev .who span{font-size:12px;color:var(--ink-3)}

.soon-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line-2);border-radius:100px;
  padding:7px 13px;display:inline-block;margin-top:18px;
}

/* ════ Blog grid ═════════════════════════════════════════════ */
.blog{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,36px)}
.post{display:flex;flex-direction:column;transition:transform .55s var(--ease)}
.post:hover{transform:translateY(-4px)}
.post-art{
  position:relative;aspect-ratio:4/3;
  border-radius:14px;overflow:hidden;
  border:1px solid var(--line);margin-bottom:22px;isolation:isolate;
}
.post-art::before{content:"";position:absolute;inset:0;background:var(--art,linear-gradient(135deg,#F4F0E5,#F9F6EF))}
.post-art::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.55;mix-blend-mode:overlay;
}
.post-art .ph{
  position:absolute;inset:auto 24px 24px 24px;
  font-family:var(--display);font-weight:600;
  font-size:1.6rem;letter-spacing:-.02em;line-height:1;color:var(--fde);
}
.post-art .pcat{
  position:absolute;top:20px;left:24px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);
}
.post.v1 .post-art{--art:linear-gradient(155deg,#ECE7DA 0%,#F9F6EF 90%)}
.post.v2 .post-art{--art:linear-gradient(135deg,#ECE7DA 0%,#F9F6EF 90%)}
.post.v3 .post-art{--art:linear-gradient(125deg,#F2EEE3 0%,#F9F6EF 90%)}
.post.v4 .post-art{--art:linear-gradient(145deg,#ECE7DA 0%,#F9F6EF 90%)}
.post.v5 .post-art{--art:linear-gradient(165deg,#ECE7DA 0%,#F9F6EF 90%)}
.post.v6 .post-art{--art:linear-gradient(125deg,#EFEBE0 0%,#F9F6EF 90%)}

.post .date{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.1em}
.post h3{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.15rem,1.7vw,1.4rem);
  letter-spacing:-.018em;margin:10px 0 8px;line-height:1.18;
  transition:color .35s;
}
.post:hover h3{color:var(--fde)}
.post p{color:var(--ink-2);font-size:14.5px;line-height:1.55}

.featured-post{
  display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(30px,5vw,70px);
  align-items:center;padding-bottom:clamp(50px,7vw,90px);
  border-bottom:1px solid var(--line);margin-bottom:clamp(50px,7vw,90px);
}
.featured-post .post-art{aspect-ratio:5/4;margin-bottom:0}
.featured-post .ftag{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--fde);margin-bottom:18px;display:inline-block;
}
.featured-post h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2rem,4vw,3.4rem);
  line-height:1.06;letter-spacing:-.028em;margin-bottom:20px;
}
.featured-post p{color:var(--ink-2);font-size:16px;line-height:1.6;margin-bottom:26px;max-width:48ch}

/* ════ Article body (long-form) ══════════════════════════════ */
.article-body{
  max-width:720px;margin:0 auto;
  font-size:17.5px;line-height:1.75;color:var(--ink-2);
}
.article-body > * + *{margin-top:1.5em}
.article-body h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.8rem,3vw,2.4rem);
  letter-spacing:-.025em;line-height:1.15;color:var(--ink);
  margin-top:2.4em;margin-bottom:.6em;
}
.article-body h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.3rem,2vw,1.7rem);
  letter-spacing:-.02em;line-height:1.2;color:var(--ink);
  margin-top:1.8em;margin-bottom:.4em;
}
.article-body p{margin-top:1.3em}
.article-body a{color:var(--fde);border-bottom:1px solid var(--fde-deep);transition:color .3s,border-color .3s}
.article-body a:hover{color:var(--fde-soft);border-color:var(--fde)}
.article-body em{color:var(--ink);font-style:italic}
.article-body strong{color:var(--ink);font-weight:500}
.article-body blockquote{
  border-left:2px solid var(--fde);
  padding:6px 0 6px 30px;margin:2em 0;
  font-family:var(--display);font-style:normal;font-weight:500;
  font-size:1.32em;line-height:1.32;letter-spacing:-.02em;color:var(--ink);
}
.article-body ul,.article-body ol{padding-left:28px;margin-top:1.3em}
.article-body li{margin-top:.6em}
.article-body figure{margin:2em 0}
.article-body figure img{width:100%;border-radius:14px;border:1px solid var(--line)}
.article-body figcaption{
  margin-top:14px;font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);
  text-align:center;
}
.article-body code{
  font-family:var(--code);font-size:.92em;
  background:rgba(20,17,13,.05);padding:2px 7px;border-radius:4px;color:var(--ink);
}
.article-body hr{border:0;border-top:1px solid var(--line);margin:3em 0}

.article-meta{
  display:flex;flex-wrap:wrap;gap:24px 40px;align-items:center;
  padding-top:30px;border-top:1px solid var(--line);
}
.article-meta .author{display:flex;align-items:center;gap:14px}
.article-meta .avi{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--fde-deep),var(--fde));
  display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:13px;color:#FBF8F1;
}
.article-meta .author b{display:block;font-size:14.5px;font-weight:500;font-family:var(--display)}
.article-meta .author span{font-size:12px;color:var(--ink-3)}
.article-meta .mono{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;color:var(--ink-3);text-transform:uppercase}

/* Author bio block (end of article) */
.author-bio{
  display:grid;grid-template-columns:120px 1fr;gap:30px;
  margin-top:80px;padding:40px;
  border:1px solid var(--line-2);border-radius:18px;
  background:linear-gradient(160deg,#EFEBE0,#F9F6EF);
}
.author-bio .av{
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(160deg,#ECE7DA,#F9F6EF);
  border:1px solid var(--line-2);
  display:grid;place-items:center;
  font-family:var(--display);font-weight:500;font-size:36px;color:var(--fde-soft);
}
.author-bio h4{
  font-family:var(--display);font-weight:600;font-size:1.2rem;
  letter-spacing:-.015em;margin-bottom:6px;
}
.author-bio .tt{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.author-bio p{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:54ch}
.author-bio a.btn{margin-top:20px}

/* ════ Case study (project detail) ═══════════════════════════ */
.case-cover{
  margin-top:40px;
  aspect-ratio:16/9;
  border-radius:24px;overflow:hidden;
  position:relative;isolation:isolate;
  border:1px solid var(--line-2);
  background:linear-gradient(155deg,#ECE7DA,#F9F6EF);
}
.case-cover::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px circle at 30% 30%,rgba(157,138,108,.15),transparent 55%),
    radial-gradient(600px circle at 75% 80%,rgba(157,138,108,.08),transparent 55%);
}
.case-cover::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .3 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.45;mix-blend-mode:overlay;
}
.case-cover .cinner{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(34px,5vw,70px);
  background:linear-gradient(to top,rgba(8,7,6,.84),rgba(8,7,6,.34) 46%,transparent 78%);
}
.case-cover .cinner .ct{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--fde-soft);margin-bottom:14px;
}
.case-cover .cinner h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2.4rem,6vw,5.4rem);
  line-height:.98;letter-spacing:-.035em;color:#F6F1E8;
}
.case-cover .cinner h2 em{font-family:var(--display);font-style:normal;font-weight:800;letter-spacing:-.035em;color:var(--fde-soft)}

.case-section{
  padding-top:clamp(60px,8vw,110px);padding-bottom:clamp(60px,8vw,110px);
  border-top:1px solid var(--line);
}
.case-2col{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);
}
.case-2col .left{position:sticky;top:120px;align-self:start}
.case-2col .left .num{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--fde);margin-bottom:18px;display:block;
}
.case-2col h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.7rem,3.4vw,2.6rem);
  letter-spacing:-.026em;line-height:1.08;
}
.case-2col .right p{color:var(--ink-2);font-size:16.5px;line-height:1.65;margin-bottom:1.2em}
.case-2col .right p:first-child{font-size:1.1rem;color:var(--ink)}

.case-gallery{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
.case-gallery .g{
  aspect-ratio:4/3;border-radius:14px;
  background:linear-gradient(155deg,#ECE7DA,#F9F6EF);
  border:1px solid var(--line);overflow:hidden;isolation:isolate;
  position:relative;
}
.case-gallery .g::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .3 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.45;mix-blend-mode:overlay;
}
.case-gallery .g.wide{grid-column:span 2;aspect-ratio:16/9}

.case-results{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.case-results .r{
  padding:clamp(40px,5vw,60px) clamp(24px,3vw,40px);
  border-right:1px solid var(--line);
}
.case-results .r:last-child{border-right:0}
.case-results .r .n{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.4rem,4.6vw,3.8rem);
  line-height:.9;letter-spacing:-.035em;color:var(--fde);
}
.case-results .r .l{margin-top:18px;color:var(--ink-2);font-size:15px;line-height:1.5}

.case-next{
  display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;
  padding:clamp(50px,7vw,90px) 0;border-top:1px solid var(--line);
}
.case-next .label{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:14px;display:block;
}
.case-next h3{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.026em;
}
.case-next a{display:contents;color:inherit}
.case-next a:hover h3{color:var(--fde);transition:color .35s}

/* ════ FAQ ════════════════════════════════════════════════════ */
.faq{border-top:1px solid var(--line)}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:grid;grid-template-columns:1fr 24px;gap:24px;align-items:center;
  padding:clamp(24px,3vw,34px) 0;
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.1rem,1.8vw,1.4rem);letter-spacing:-.018em;
  transition:color .3s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-family:var(--mono);font-weight:400;
  font-size:22px;color:var(--fde);
  transition:transform .35s var(--ease);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--fde-soft)}
.faq-item .a{padding:0 0 30px;color:var(--ink-2);font-size:15.5px;line-height:1.6;max-width:64ch}

/* ════ Form ═══════════════════════════════════════════════════ */
.form{
  display:grid;gap:24px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.field{display:flex;flex-direction:column;gap:10px}
.field label{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);
}
.field input,
.field textarea,
.field select{
  background:transparent;
  border:0;border-bottom:1px solid var(--line-2);
  padding:14px 0;
  font-size:16px;color:var(--ink);
  transition:border-color .3s;
}
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;border-bottom-color:var(--fde);
}
.field textarea{resize:vertical;min-height:120px}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}

.form-radios{display:flex;flex-wrap:wrap;gap:10px}
.form-radios label{
  cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--line-2);border-radius:100px;
  padding:10px 18px;transition:color .3s,border-color .3s,background .3s;
}
.form-radios input{position:absolute;opacity:0;pointer-events:none}
.form-radios input:checked + span{color:var(--fde)}
.form-radios label:has(input:checked){color:var(--fde);border-color:var(--fde);background:rgba(157,138,108,.04)}

.form-submit{
  display:flex;justify-content:space-between;align-items:center;
  gap:24px;flex-wrap:wrap;margin-top:18px;
  padding-top:30px;border-top:1px solid var(--line);
}
.form-note{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}

/* ════ Contact info block ═══════════════════════════════════ */
.contact-grid{
  display:grid;grid-template-columns:1.3fr 1fr;
  gap:clamp(40px,6vw,90px);align-items:start;
}
.contact-side{
  display:grid;gap:30px;
  padding:34px;border-radius:18px;
  border:1px solid var(--line-2);
  background:linear-gradient(160deg,#EFEBE0,#F9F6EF);
  position:sticky;top:120px;
}
.contact-block{padding-bottom:24px;border-bottom:1px solid var(--line)}
.contact-block:last-child{border-bottom:0;padding-bottom:0}
.contact-block .lab{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:12px;display:block;
}
.contact-block a,.contact-block p{
  font-family:var(--display);font-weight:500;font-size:1.1rem;
  letter-spacing:-.015em;color:var(--ink);line-height:1.3;
  transition:color .3s;
  overflow-wrap:anywhere;word-break:break-word;
}
.contact-block a:hover{color:var(--fde)}

/* ════ Final CTA ═════════════════════════════════════════════ */
.cta{
  position:relative;
  border-radius:24px;overflow:hidden;
  padding:clamp(60px,8vw,130px) clamp(34px,6vw,80px);
  border:1px solid var(--line-2);
  background:linear-gradient(160deg,#EFEBE0,#F9F6EF);text-align:center;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px circle at 50% -20%,rgba(157,138,108,.2),transparent 55%),
    radial-gradient(500px circle at 50% 120%,rgba(157,138,108,.08),transparent 60%);
  pointer-events:none;
}
.cta > *{position:relative}
.cta h2{margin:24px auto 22px;max-width:18ch}
.cta .lead{margin:0 auto 38px;text-align:center}
.cta .filter{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);margin-top:30px;
}

/* ════ Footer ════════════════════════════════════════════════ */
footer.site-footer{
  border-top:1px solid var(--line);
  padding:clamp(70px,9vw,110px) 0 36px;
  margin-top:60px;
}
.fgrid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:42px;
}
.fgrid h4{
  font-family:var(--mono);font-weight:400;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:22px;
}
.fgrid a{
  display:block;color:var(--ink-2);font-size:14.5px;
  padding:7px 0;transition:color .3s,padding .35s var(--ease);
}
.fgrid a:hover{color:var(--fde);padding-left:6px}
.fgrid p{color:var(--ink-2);font-size:14.5px;max-width:34ch;margin-top:14px;line-height:1.6}
.fbig{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.9rem,6.4vw,5rem);
  letter-spacing:-.03em;line-height:1.04;
  color:transparent;-webkit-text-stroke:1px var(--line-2);
  margin:clamp(44px,6vw,72px) 0 0;
}
.fbig em{font-family:var(--display);font-style:normal;font-weight:800;letter-spacing:-.02em;color:var(--fde);-webkit-text-stroke:0}
.fbot{
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  color:var(--ink-3);font-size:12.5px;
  padding-top:28px;margin-top:42px;border-top:1px solid var(--line);
}
.fbot .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-3)}

/* ════ Floating contact badge ════════════════════════════════ */
.badge{
  position:fixed;right:32px;bottom:32px;z-index:120;
  width:132px;height:132px;display:grid;place-items:center;cursor:pointer;
}
.badge::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:var(--fde);
  box-shadow:
    0 14px 36px -14px rgba(20,17,13,.18),
    0 0 0 1px rgba(255,255,255,.5) inset,
    0 0 60px -10px var(--halo);
  transition:transform .55s var(--ease),box-shadow .55s;
}
.badge:hover::before{
  transform:scale(1.04);
  box-shadow:
    0 18px 44px -14px rgba(20,17,13,.22),
    0 0 0 1px rgba(255,255,255,.4) inset,
    0 0 80px -8px var(--halo);
}
.badge svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 22s linear infinite;z-index:2}
.badge text{
  font-family:var(--mono);font-size:7.8px;letter-spacing:.18em;
  fill:#FBF8F1;text-transform:uppercase;font-weight:500;opacity:.92;
}
.badge .core{
  position:relative;z-index:3;
  width:54px;height:54px;border-radius:50%;
  background:var(--bg);border:1px solid var(--fde-deep);
  display:grid;place-items:center;
  color:var(--fde);font-size:18px;font-weight:600;
  transition:transform .45s var(--ease),color .35s,background .35s;
}
.badge:hover .core{
  transform:scale(1.06);
  background:var(--fde);color:var(--bg);border-color:var(--fde);
}
.badge:hover svg{animation-duration:9s}
@keyframes spin{to{transform:rotate(360deg)}}

/* ════ 404 ═══════════════════════════════════════════════════ */
.error-page{
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px var(--pad-x);
}
.error-page .code{
  font-family:var(--display);font-weight:500;
  font-size:clamp(8rem,22vw,18rem);
  line-height:.85;letter-spacing:-.05em;color:var(--fde);
}
.error-page h1{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.8rem,3.5vw,2.6rem);
  letter-spacing:-.025em;margin:30px 0 16px;
}

/* ════ Responsive ════════════════════════════════════════════ */
@media (max-width:980px){
  nav.nav,.hcta .btn,.lang{display:none}
  .burger{display:inline-flex}
  .shead{grid-template-columns:1fr}
  .manifest{grid-template-columns:1fr}
  .studio{grid-template-columns:1fr;gap:40px}
  .studio-portrait{position:static}
  .portrait-frame{aspect-ratio:1/1;max-width:420px}
  .portrait-frame.has-photo .portrait-photo{background-position:center 18%}
  .meta-cell{grid-template-columns:120px 1fr;gap:16px}
  .choice{grid-template-columns:36px 1fr;gap:14px}
  .choice .desc,.choice .tag{display:none}
  .svc{grid-template-columns:60px 1fr;gap:18px}
  .svc-num{font-size:1.6rem}
  .svc-num small{display:none}
  .svc-tags{display:none}
  .svc-body h3{font-size:1.4rem}
  .svc-detail{grid-template-columns:1fr;gap:40px}
  .svc-detail .left{position:static}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .stat-band{grid-template-columns:1fr}
  .blog{grid-template-columns:1fr}
  .featured-post{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:32px}
  .pin{height:auto!important}
  .pin-sticky{position:static;height:auto;padding:0}
  .pin-track{transform:none!important;overflow-x:auto;scroll-snap-type:x mandatory;padding:0 24px 12px;scroll-padding-left:24px;-webkit-overflow-scrolling:touch}
  .pin-indicator{display:none}
  .proj{flex-basis:82%;scroll-snap-align:start}

  /* Work stack on mobile: disable sticky, show overlay always */
  .work-item{position:static;top:auto}
  .work-card{aspect-ratio:4/5;max-height:none}
  .work-overlay{opacity:1;padding:28px}
  .work-overlay h3{font-size:1.4rem}
  .work-overlay p{font-size:14px;margin-bottom:18px}
  .work-overlay .work-cat,.work-overlay h3,.work-overlay p,.work-overlay .work-cta{transform:none}
  .work-num{font-size:10px;padding:6px 12px}
  .proj-grid{grid-template-columns:1fr}
  .rev{flex-basis:300px;padding:26px}
  .case-2col{grid-template-columns:1fr;gap:30px}
  .case-2col .left{position:static}
  .case-results{grid-template-columns:1fr}
  .case-results .r{border-right:0;border-bottom:1px solid var(--line)}
  .case-results .r:last-child{border-bottom:0}
  .case-gallery{grid-template-columns:1fr}
  .case-gallery .g.wide{grid-column:auto}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .contact-side{position:static}
  .form-row{grid-template-columns:1fr}
  .author-bio{grid-template-columns:1fr;gap:18px;padding:30px}
  .author-bio .av{width:64px;height:64px;font-size:22px}
  .badge{right:16px;bottom:16px;width:104px;height:104px}
  .badge .core{width:44px;height:44px;font-size:15px}
  .badge text{font-size:7px;letter-spacing:.16em}
}
@media (max-width:560px){
  body{font-size:16px}
  .fgrid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important;animation-iteration-count:1!important}
  .reveal > span{transform:none}
  .fade-up{opacity:1;transform:none}
}

/* ════ Polish pass : logo, boutons FDE, hero, espacements, aération ════ */
.brand-logo{width:36px;height:36px;border-radius:9px;display:block;object-fit:contain;flex:0 0 auto}
header.site-header.is-pill .brand-logo{width:30px;height:30px}
.btn-g:hover{border-color:var(--fde-deep);background:var(--fde-deep);color:#fff}
.btn-g:active{transform:translateY(0)}
.reveal{padding-top:.2em}
/* aération des gros blocs de texte */
.lead{line-height:1.72}
.manifest .big{line-height:1.36}
.case-2col .right p{line-height:1.74;margin-bottom:1.45em}
.case-2col .right p:first-child{line-height:1.62}
.svc-body p{line-height:1.7}
.choice .desc{line-height:1.7}
.mcard p,.eco .e p{line-height:1.62}
/* espacements de sections plus serrés */
:root{--sec-y:clamp(54px,6.8vw,94px);--sec-y-sm:clamp(40px,5vw,66px);--sec-y-lg:clamp(78px,9vw,126px)}
/* honeypot anti-spam (invisible) */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ════ Article : encart "en bref" (GEO) + cover image ════ */
.tldr{background:linear-gradient(165deg,#FBF8F1,#F2ECDE);border:1px solid var(--line-2);border-left:3px solid var(--fde);border-radius:14px;padding:clamp(22px,3vw,32px);margin:8px 0 38px}
.tldr .tldr-lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fde);display:block;margin-bottom:12px}
.tldr p{margin:0;font-size:1.06rem;line-height:1.6;color:var(--ink)}
.tldr ul{margin:12px 0 0;padding-left:18px}
.tldr li{margin:5px 0;color:var(--ink-2);font-size:15px}
.article-cover{position:relative;aspect-ratio:21/9;border-radius:24px;overflow:hidden;border:1px solid var(--line-2);margin-top:40px;isolation:isolate}
.article-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.article-cover .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,13,.1),rgba(20,17,13,.55));z-index:1}
.article-cover .cap{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(28px,4vw,52px);color:#fff}
.article-cover .cap .ct{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.article-cover .cap h2{color:#fff;font-family:var(--display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.8rem);line-height:1.05;margin-top:12px;letter-spacing:-.02em}
.faq-q{font-size:clamp(1.5rem,2.6vw,2rem)}

/* Marquee : défilement continu, jamais de pause (hover/scroll) */
.photo-marquee:hover .photo-track{animation-play-state:running!important}
.photo-track{animation:scrollx 80s linear infinite!important}

/* Cartes d'articles : vraie image de couverture + bloc auteur photo */
.post-art .pimg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.post-art .pimg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,16,12,.5),rgba(18,16,12,.16) 42%,rgba(18,16,12,.74))}
.post-art:has(.pimg)::before{opacity:0}
.post-art .ph,.post-art .pcat{z-index:2}
.post-art:has(.pimg) .ph{color:#fff}
.post-art:has(.pimg) .pcat{color:rgba(255,255,255,.92)}
.author-bio .av.has-photo{background-size:cover;background-position:center 28%;color:transparent}

/* ════ Home : cartes réalisations sticky, version sobre ════ */
.work-card .work-photo{filter:brightness(.46) blur(2px) saturate(.92)}
.work-card:hover .work-photo{filter:brightness(.52) blur(2px) saturate(.95);transform:scale(1.04)}
.work-overlay{opacity:1!important;justify-content:center!important;align-items:center!important;text-align:center!important;background:linear-gradient(180deg,rgba(8,7,6,.30),rgba(8,7,6,.52))!important;padding:clamp(28px,4vw,56px)!important}
.work-overlay .work-cat,.work-overlay h3,.work-overlay p,.work-overlay .work-cta{transform:none!important}
.work-overlay .work-cat{color:rgba(255,255,255,.82)!important;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.work-overlay h3{color:#fff!important;font-family:var(--display)!important;margin-top:12px}
.work-overlay h3 em{font-family:var(--display)!important;font-style:normal!important;color:#fff!important}
.work-overlay p{color:rgba(255,255,255,.9)!important;font-family:var(--display)!important;max-width:44ch;margin:14px auto 0;font-size:15px;line-height:1.5}
.work-overlay .work-cta{opacity:0;transition:opacity .45s var(--ease);margin-top:20px}
.work-card:hover .work-overlay .work-cta{opacity:1}

/* ════ Bandeau cookies (RGPD, sans captcha) ════ */
.cookie-banner{position:fixed;left:clamp(14px,3vw,28px);right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,24px);z-index:200;max-width:580px;margin:0 auto;background:rgba(249,246,239,.97);backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:16px;padding:18px 22px;box-shadow:0 24px 60px -22px rgba(20,17,13,.32);display:flex;flex-wrap:wrap;align-items:center;gap:14px;transform:translateY(160%);transition:transform .6s cubic-bezier(.16,1,.3,1)}
.cookie-banner.show{transform:none}
.cookie-banner p{flex:1 1 240px;font-size:13px;line-height:1.5;color:var(--ink-2);margin:0}
.cookie-banner p a{color:var(--fde);text-decoration:underline}
.cookie-banner .cb-actions{display:flex;gap:10px}
.cookie-banner button{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:10px 16px;border-radius:9px;cursor:pointer;border:1px solid var(--line-2);background:transparent;color:var(--ink);transition:.25s}
.cookie-banner button:hover{border-color:var(--ink)}
.cookie-banner button.cb-accept{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.cookie-banner button.cb-accept:hover{background:var(--fde-deep);border-color:var(--fde-deep)}

/* ════ Intro / écran d'entrée noir (défiler pour entrer) ════ */
html.intro-lock,body.intro-lock{overflow:hidden!important;height:100%}
.intro{
  position:fixed;inset:0;z-index:10000;
  background:#0E0C0A;color:#F4EFE6;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px;
  will-change:transform;
  transition:transform 1.05s cubic-bezier(.76,0,.18,1);
}
.intro.is-hidden{transform:translateY(-101%)}
.intro::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(880px 580px at 50% 26%,rgba(168,147,115,.16),transparent 60%),
    radial-gradient(600px 600px at 50% 120%,rgba(168,147,115,.06),transparent 60%);
}
.intro::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.06;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.intro-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:clamp(18px,2.4vw,30px)}
.intro-logo{
  width:clamp(78px,9vw,122px);height:auto;
  filter:drop-shadow(0 20px 44px rgba(0,0,0,.55));
  opacity:0;transform:translateY(16px) scale(.94);
  animation:introUp .9s var(--ease) .12s forwards;
}
.intro-word{
  font-family:var(--display);font-weight:800;letter-spacing:-.005em;text-transform:uppercase;
  font-size:clamp(1.8rem,5.9vw,4.1rem);line-height:1;
  opacity:0;transform:translateY(22px);
  animation:introUp 1s var(--ease) .28s forwards;
}
.intro-word .br{color:#A89373}
.intro-eye{
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(244,239,230,.5);
  opacity:0;transform:translateY(14px);
  animation:introUp 1s var(--ease) .46s forwards;
}
.intro-cue{
  position:absolute;left:0;right:0;bottom:clamp(24px,5vh,52px);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:rgba(244,239,230,.42);
  text-align:center;
  opacity:0;animation:introFade 1s var(--ease) .92s forwards;cursor:pointer;
}
.intro-cue .line{width:1px;height:36px;background:rgba(244,239,230,.16);position:relative;overflow:hidden}
.intro-cue .line::after{content:"";position:absolute;top:-36px;left:0;width:1px;height:36px;background:linear-gradient(to bottom,#A89373,transparent);animation:introScroll 1.9s cubic-bezier(.7,0,.3,1) infinite}
@keyframes introUp{to{opacity:1;transform:none}}
@keyframes introFade{to{opacity:1}}
@keyframes introScroll{0%{top:-36px}55%{top:36px}100%{top:36px}}
@media (prefers-reduced-motion:reduce){
  .intro-logo,.intro-word,.intro-eye,.intro-cue{animation:none;opacity:1;transform:none}
  .intro-cue .line::after{animation:none}
  .intro{transition-duration:.35s}
}

/* ════════════════════════════════════════════════════════════════
   Niveau supérieur : bandes sombres, process accordéon,
   services au survol, voile glassy, reveals enrichis.
   ════════════════════════════════════════════════════════════════ */

/* ---- Bandes pleine largeur sur fond noir chaud ---- */
.band-dark{position:relative;background:#0E0C0A;color:#F4EFE6;overflow:hidden}
.band-dark::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(900px 620px at 82% -12%,rgba(168,147,115,.16),transparent 60%),
    radial-gradient(720px 600px at 4% 112%,rgba(168,147,115,.09),transparent 60%);
}
.band-dark > .wrap{position:relative;z-index:1}
.band-dark h1,.band-dark h2,.band-dark h3,.band-dark h4{color:#F6F1E8}
.band-dark .lead{color:rgba(244,239,230,.74)}
.band-dark .shead .lbl{color:rgba(244,239,230,.5)}
.band-dark .shead .lbl b{color:#F6F1E8}
.band-dark .eye{color:rgba(244,239,230,.52)}
.band-dark .eye .dot{background:var(--fde-soft);box-shadow:0 0 10px 1px rgba(168,147,115,.45)}
.band-dark .tan,.band-dark .serif-it.tan{color:var(--fde-soft)}
.band-dark .stats{border-top-color:rgba(244,239,230,.16)}
.band-dark .stat{border-right-color:rgba(244,239,230,.16)}
.band-dark .stat .n{color:#F6F1E8}
.band-dark .stat .n .unit{color:var(--fde-soft)}
.band-dark .stat .l{color:rgba(244,239,230,.56)}
.band-dark .btn-p{background:var(--bg);color:var(--ink);box-shadow:0 12px 32px -14px rgba(0,0,0,.65)}
.band-dark .btn-p:hover{background:var(--fde-soft);color:#1b140b}
.band-dark .btn-g{border-color:rgba(244,239,230,.3);color:#F4EFE6}
.band-dark .btn-g:hover{background:#F4EFE6;border-color:#F4EFE6;color:var(--ink)}
.band-dark .filter{color:rgba(244,239,230,.5)}

/* CTA final dramatique (full-bleed sombre) */
.cta-dark{text-align:center;max-width:920px;margin:0 auto;position:relative;z-index:1}
.cta-dark .cta-h{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2.1rem,5.2vw,4.3rem);line-height:1;letter-spacing:-.02em;
  margin:22px auto 24px;max-width:18ch;
}
.cta-dark .lead{margin:0 auto 38px;max-width:54ch;text-align:center}
.cta-dark .hero-row{justify-content:center;margin-top:0}
.cta-dark .filter{margin-top:30px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}

/* ---- Process : accordéon interactif ---- */
.proc{border-top:1px solid var(--line)}
.proc-item{border-bottom:1px solid var(--line);position:relative}
.proc-item::after{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--fde);transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease)}
.proc-item.is-open::after{transform:scaleY(1)}
.proc-head{
  width:100%;display:grid;grid-template-columns:84px 1fr 40px;align-items:center;gap:22px;
  padding:clamp(26px,3.4vw,40px) 12px clamp(26px,3.4vw,40px) 28px;text-align:left;cursor:pointer;background:none;
  transition:padding-left .5s var(--ease);
}
.proc-item.is-open .proc-head,.proc-head:hover{padding-left:36px}
.proc-head .pn{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--fde)}
.proc-head .pt{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,2.4vw,2.1rem);letter-spacing:-.022em;color:var(--ink);transition:color .35s}
.proc-item.is-open .proc-head .pt{color:var(--fde)}
.proc-head .pi{justify-self:end;width:36px;height:36px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;font-size:19px;line-height:0;color:var(--fde);transition:transform .5s var(--ease),background .35s,color .35s,border-color .35s}
.proc-item.is-open .proc-head .pi{transform:rotate(45deg);background:var(--fde);color:#fff;border-color:var(--fde)}
.proc-panel{overflow:hidden;max-height:0;transition:max-height .6s var(--ease)}
.proc-inner{padding:0 12px clamp(30px,3.6vw,46px) 134px}
.proc-inner p{color:var(--ink-2);max-width:62ch;font-size:16px;line-height:1.65}
.proc-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.proc-tags span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line-2);border-radius:100px;padding:7px 14px;background:var(--surface-2)}
@media(max-width:760px){
  .proc-head{grid-template-columns:42px 1fr 32px;gap:12px;padding-left:22px}
  .proc-item.is-open .proc-head,.proc-head:hover{padding-left:28px}
  .proc-inner{padding-left:22px}
}

/* ---- Services : aperçu visuel au survol ---- */
.svc-preview{
  position:fixed;top:0;left:0;z-index:95;width:300px;height:208px;border-radius:14px;overflow:hidden;
  pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.92);
  transition:opacity .4s var(--ease),transform .4s var(--ease);
  box-shadow:0 34px 80px -28px rgba(20,17,13,.55);border:1px solid rgba(255,255,255,.45);
}
.svc-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.svc-preview img{width:100%;height:100%;object-fit:cover;display:block}
.svc-preview::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,13,0),rgba(20,17,13,.18))}
@media(hover:none),(max-width:980px){.svc-preview{display:none!important}}

/* ---- Voile glassy bas de page (frosté, adaptatif, invite au scroll) ---- */
.scroll-veil{
  position:fixed;left:0;right:0;bottom:0;height:clamp(110px,15vh,170px);z-index:90;pointer-events:none;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  -webkit-mask-image:linear-gradient(to top,#000 0%,#000 18%,rgba(0,0,0,.55) 52%,transparent 100%);
          mask-image:linear-gradient(to top,#000 0%,#000 18%,rgba(0,0,0,.55) 52%,transparent 100%);
  opacity:1;transition:opacity .55s var(--ease);
}
.scroll-veil.is-hidden{opacity:0}

/* ---- Parallax léger (images) ---- */
[data-parallax]{will-change:transform}
@media (prefers-reduced-motion:reduce){[data-parallax]{transform:none!important}}

/* ════════════════════════════════════════════════════════════════
   Monument Extended — titres + accents (corps reste en Geist).
   2 graisses : Regular (titres) mappée 100-600, Ultrabold (accents) 601-900.
   ════════════════════════════════════════════════════════════════ */
@font-face{
  font-family:"Monument Extended";
  src:url("fonts/MonumentExtended-Regular.woff2") format("woff2"),
      url("fonts/MonumentExtended-Regular.otf") format("opentype");
  font-weight:100 600;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Monument Extended";
  src:url("fonts/MonumentExtended-Ultrabold.woff2") format("woff2"),
      url("fonts/MonumentExtended-Ultrabold.otf") format("opentype");
  font-weight:601 900;font-style:normal;font-display:swap;
}

/* ════ Services : carrousel horizontal de cards (Apple-like) ════ */
.svc-marquee{
  position:relative;margin-top:clamp(40px,5vw,64px);overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent);
}
.svc-track{display:flex;width:max-content;will-change:transform;animation:svcScroll 46s linear infinite}
.svc-track:hover{animation-play-state:paused}
@keyframes svcScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.scard{
  flex:0 0 clamp(282px,29vw,356px);margin-right:24px;display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line-2);border-radius:26px;overflow:hidden;
  box-shadow:0 14px 40px -24px rgba(20,17,13,.28);
  transition:transform .55s var(--ease),box-shadow .55s var(--ease);
  text-decoration:none;color:inherit;
}
.scard:hover{transform:translateY(-8px);box-shadow:0 30px 64px -26px rgba(20,17,13,.42)}
.scard-media{position:relative;aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--bg-2)}
.scard-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,13,.06),rgba(20,17,13,.42))}
.scard-n{position:absolute;z-index:1;top:16px;left:18px;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.16em;color:#F4EFE6;opacity:.9}
.scard-body{padding:24px 24px 26px;display:flex;flex-direction:column;gap:13px;flex:1}
.scard-body h3{font-family:var(--display);font-weight:500;font-size:clamp(1.12rem,1.5vw,1.32rem);line-height:1.14;letter-spacing:-.018em;color:var(--ink)}
.scard-body p{color:var(--ink-2);font-size:14.5px;line-height:1.55;flex:1}
.scard-tags{display:flex;flex-wrap:wrap;gap:7px}
.scard-tags span{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--line-2);border-radius:100px;padding:5px 11px}
.scard-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fde);margin-top:2px}
.scard-cta span{display:inline-block;transition:transform .4s var(--ease)}
.scard:hover .scard-cta span{transform:translateX(5px)}
@media (prefers-reduced-motion:reduce){.svc-track{animation:none}}
@media(max-width:600px){.scard{flex-basis:78vw}}

/* ════ Services (home) : carrousel manuel + flèches premium ════ */
.svc-carousel{position:relative;margin-top:clamp(40px,5vw,64px)}
.svc-scroll{
  display:flex;gap:clamp(20px,2vw,28px);overflow-x:auto;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 16px;scrollbar-width:none;-ms-overflow-style:none;
  touch-action:pan-x;overscroll-behavior-x:contain;
}
.svc-scroll::-webkit-scrollbar{display:none}
.svc-scroll .scard{flex:0 0 clamp(290px,30vw,360px);margin-right:0;scroll-snap-align:start}
/* masque les doublons hérités de l'ancien marquee (cartes 5–8) */
.svc-carousel .scard:nth-child(n+5){display:none}
.svc-arrow{
  position:absolute;top:42%;transform:translateY(-50%);z-index:6;
  width:54px;height:54px;border-radius:50%;
  background:rgba(249,246,239,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--line-2);color:var(--ink);
  display:grid;place-items:center;font-size:19px;cursor:pointer;
  box-shadow:0 14px 34px -16px rgba(20,17,13,.45);
  transition:transform .45s var(--ease),background .35s,color .35s,opacity .35s,border-color .35s;
}
.svc-arrow.prev{left:6px}
.svc-arrow.next{right:6px}
.svc-arrow:hover{background:var(--ink);border-color:var(--ink);color:var(--bg);transform:translateY(-50%) scale(1.08)}
.svc-arrow[disabled]{opacity:0;pointer-events:none}

/* Pas de soulèvement des cartes au toucher (évite le "gigotement" au scroll) */
@media(hover:none){
  .post:hover,.scard:hover{transform:none}
}

/* ════ Boutons : finition premium — reflet qui balaie, glow chaud, flèche brass ════ */
.btn{
  background-repeat:no-repeat;will-change:transform;
  transition:transform .55s cubic-bezier(.16,1,.3,1),background-color .5s ease,
             background-position 1.45s cubic-bezier(.37,0,.24,1),color .45s ease,
             box-shadow .6s ease,border-color .45s ease;
}
.btn:hover{transform:scale(1.04)}
.btn:active{transform:scale(.985)}
.btn .arr{transition:transform .4s var(--ease),color .4s ease}
.btn:hover .arr{transform:translateX(5px);color:var(--fde-soft)}

/* Primaire (sombre) : reflet blanc qui glisse + glow brass */
.btn-p,.btn-p:hover{background-image:linear-gradient(108deg,transparent 18%,rgba(255,255,255,.10) 50%,transparent 82%);background-size:260% 100%}
.btn-p{background-color:var(--ink);color:var(--bg);background-position:165% 0;box-shadow:0 8px 24px -12px rgba(20,17,13,.4)}
.btn-p:hover{background-color:#000;color:#fff;background-position:-65% 0;box-shadow:0 18px 46px -12px rgba(20,17,13,.55),0 10px 34px -8px rgba(168,147,115,.45)}

/* Secondaire (ghost) : se remplit en noir + reflet au survol */
.btn-g,.btn-g:hover{background-image:linear-gradient(108deg,transparent 18%,rgba(255,255,255,.09) 50%,transparent 82%);background-size:260% 100%}
.btn-g{background-color:transparent;border-color:var(--line-3);color:var(--ink);background-position:165% 0}
.btn-g:hover{background-color:var(--ink);border-color:var(--ink);color:var(--bg);background-position:-65% 0;box-shadow:0 16px 42px -14px rgba(20,17,13,.5),0 8px 30px -8px rgba(168,147,115,.4)}

/* Sur fond sombre : boutons clairs, reflet brass, flèche brass */
.band-dark .btn-p,.band-dark .btn-p:hover{background-image:linear-gradient(108deg,transparent 18%,rgba(168,147,115,.30) 50%,transparent 82%);background-size:260% 100%}
.band-dark .btn-p{background-color:var(--bg);color:var(--ink);background-position:165% 0;box-shadow:0 12px 32px -14px rgba(0,0,0,.6)}
.band-dark .btn-p:hover{background-color:#fff;color:#14110D;background-position:-65% 0;box-shadow:0 18px 46px -12px rgba(0,0,0,.6),0 10px 30px -10px rgba(168,147,115,.5)}
.band-dark .btn-p:hover .arr{color:var(--fde)}
.band-dark .btn-g,.band-dark .btn-g:hover{background-image:linear-gradient(108deg,transparent 18%,rgba(244,239,230,.13) 50%,transparent 82%);background-size:260% 100%}
.band-dark .btn-g{background-color:transparent;border-color:rgba(244,239,230,.34);color:#F4EFE6;background-position:165% 0}
.band-dark .btn-g:hover{background-color:#F4EFE6;border-color:#F4EFE6;color:#14110D;background-position:-65% 0}
.band-dark .btn-g:hover .arr{color:var(--fde)}
@media (prefers-reduced-motion:reduce){.btn:hover,.btn:active{transform:none}.btn{transition:background-color .3s,color .3s,border-color .3s}}

/* ════ Menu mobile : overlay plein écran (le burger ouvrait dans le vide) ════ */
@media(max-width:980px){
  .nav.is-open{
    display:flex;flex-direction:column;justify-content:center;gap:2px;
    position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;z-index:90;
    padding:120px 32px 48px;
    background:var(--bg);
    animation:navFade .35s var(--ease);
  }
  .nav.is-open a{
    font-family:var(--display);font-weight:500;letter-spacing:-.02em;
    font-size:clamp(1.8rem,7.5vw,2.6rem);color:var(--ink);
    padding:14px 0;border-bottom:1px solid var(--line);transition:color .25s;
    opacity:0;transform:translateY(26px);
    animation:navLinkIn .6s var(--ease) forwards;
  }
  .nav.is-open a:nth-child(1){animation-delay:.10s}
  .nav.is-open a:nth-child(2){animation-delay:.17s}
  .nav.is-open a:nth-child(3){animation-delay:.24s}
  .nav.is-open a:nth-child(4){animation-delay:.31s}
  .nav.is-open a:nth-child(5){animation-delay:.38s}
  .nav.is-open a:hover,.nav.is-open a:active{color:var(--fde)}
  /* le logo et le burger restent au-dessus de l'overlay pour pouvoir fermer */
  header.site-header .brand,header.site-header .burger{position:relative;z-index:130}
}
@keyframes navFade{from{opacity:0}to{opacity:1}}
@keyframes navLinkIn{to{opacity:1;transform:none}}
/* Badge flottant masqué sur téléphone (il recouvrait le contenu) */
@media(max-width:600px){.badge{display:none}}

/* ════ Accessibilité : focus clavier visible (rien au clic souris) ════ */
:focus-visible{outline:2px solid var(--fde);outline-offset:3px;border-radius:3px}
.btn:focus-visible{outline:2px solid var(--fde);outline-offset:3px}
.band-dark :focus-visible,.intro :focus-visible{outline-color:var(--fde-soft)}
a:focus:not(:focus-visible),button:focus:not(:focus-visible){outline:none}

/* Indice de défilement masqué sur mobile (il collait aux boutons du hero) */
@media(max-width:760px){.scrollcue{display:none}}

/* ════ Smooth scroll (Lenis) ════ */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-smooth iframe{pointer-events:none}

/* ════ Carrousel blog (home) — flèches de chaque côté + swipe ════ */
.blog-carousel{position:relative;margin-top:clamp(36px,4vw,56px)}
.blog-track{
  display:flex;gap:clamp(18px,2vw,28px);overflow-x:auto;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:4px 2px 14px;scrollbar-width:none;-ms-overflow-style:none;
  touch-action:pan-x;overscroll-behavior-x:contain;
}
.blog-track::-webkit-scrollbar{display:none}
.blog-track .post{flex:0 0 clamp(280px,31vw,392px);scroll-snap-align:start}
.blog-arrow{
  position:absolute;top:32%;transform:translateY(-50%);z-index:6;
  width:54px;height:54px;border-radius:50%;
  background:rgba(249,246,239,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--line-2);color:var(--ink);
  display:grid;place-items:center;font-size:19px;cursor:pointer;
  box-shadow:0 14px 34px -16px rgba(20,17,13,.45);
  transition:transform .45s var(--ease),background .35s,color .35s,opacity .35s,border-color .35s;
}
.blog-arrow.prev{left:8px}
.blog-arrow.next{right:8px}
.blog-arrow:hover{background:var(--ink);border-color:var(--ink);color:var(--bg);transform:translateY(-50%) scale(1.08)}
.blog-arrow[disabled]{opacity:0;pointer-events:none}
@media(max-width:760px){
  .blog-arrow{display:none}
  .blog-track{scroll-snap-type:x proximity;gap:16px}
  .blog-track .post{flex-basis:80vw}
}

/* ════ Correctifs mobile : header, progress, carrousels, marquee ════ */
@media(max-width:760px){
  /* Le pill flotte avec des marges au lieu de prendre toute la largeur */
  header.site-header.is-pill .wrap{max-width:none;margin-left:14px;margin-right:14px;padding-left:18px;padding-right:8px}
  /* Barre de progression masquée sur mobile (inutile, gênait le texte) */
  .progress{display:none}
  /* Carrousel services : swipe plein écran, flèches masquées */
  .svc-arrow{display:none}
  .svc-scroll{scroll-snap-type:x proximity;gap:16px}
  .svc-scroll .scard{flex:0 0 82vw}
  /* Marquee mockups : défilement nettement plus rapide + grain coupé (perf) */
  .photo-track{animation:scrollx 34s linear infinite!important}
  .photo-card::before{display:none}
}

/* ════ Correctif mobile : page contact (débordement à droite) ════ */
@media(max-width:760px){
  /* La carte d'infos ne doit jamais dépasser la largeur de l'écran */
  .contact-grid{min-width:0}
  .contact-side{padding:24px;min-width:0;overflow:hidden}
  .contact-block{min-width:0}
  /* L'email et l'URL (police large Monument) réduits + coupés proprement */
  .contact-block a,.contact-block p{font-size:.98rem;letter-spacing:-.025em;hyphens:none}
  /* Les pastilles de choix restent dans le cadre */
  .form-radios{width:100%}
  .form-radios label{flex:0 1 auto}
}
