/* =====================================================================
   AC RENOV — Design system v2
   Monochrome : noir / blanc / gris.  Sobre, immersif, éditorial.
   Type : Bricolage Grotesque (display) + Space Grotesk (texte/UI)
   ===================================================================== */

:root{
  --bg:#08080A;          /* page */
  --bg-2:#0E0E11;
  --panel:#121216;
  --black:#040405;
  --white:#F5F4F1;
  --grey-1:#C7C7CB;
  --grey-2:#9A9A9F;      /* muted text */
  --grey-3:#6C6C72;
  --grey-4:#3A3A40;
  --line:rgba(245,244,241,.12);
  --line-2:rgba(245,244,241,.22);
  --line-soft:rgba(245,244,241,.07);

  --ink:#0A0A0B;         /* for light sections */
  --paper:#F3F2EE;

  --disp:'Bricolage Grotesque',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --sans:'Space Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;

  --maxw:1360px;
  --gut:clamp(20px,5vw,80px);
  --radius:4px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-inout:cubic-bezier(.76,0,.24,1);
  --h-nav:76px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
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}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--white);
  line-height:1.5;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;          /* clip (not hidden) so position:sticky still works */
}
html{overflow-x:clip}
img,canvas,video,svg{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
::selection{background:var(--white);color:var(--bg)}

/* ---------- Grain ---------- */
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Type ---------- */
.display,h1,h2,h3{font-family:var(--disp);font-weight:500;line-height:.98;letter-spacing:-.025em}
h1{font-size:clamp(2.9rem,8.5vw,8.5rem)}
h2{font-size:clamp(2.1rem,5.6vw,4.8rem)}
h3{font-size:clamp(1.35rem,2.3vw,2rem);line-height:1.04;letter-spacing:-.02em}
.thin{font-weight:400}
.italic{font-style:italic}
p{max-width:64ch}
strong{font-weight:600}

.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--grey-2);display:inline-flex;align-items:center;gap:.8em}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--grey-3);display:inline-block}
.eyebrow.no-line::before{display:none}
.lead{font-size:clamp(1.04rem,1.4vw,1.3rem);color:var(--grey-1);line-height:1.55;font-weight:400}
.muted{color:var(--grey-2)}
.section-index{font-family:var(--sans);font-size:.74rem;letter-spacing:.22em;color:var(--grey-3);font-weight:500;text-transform:uppercase}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(72px,11vw,160px);position:relative}
.section--tight{padding-block:clamp(48px,7vw,96px)}
.panel-light{background:var(--paper);color:var(--ink)}
.panel-light .muted{color:#5C5A54}
.panel-light .lead{color:#3A3833}
.panel-light .eyebrow{color:#5C5A54}
.panel-light .eyebrow::before{background:#A8A49A}
.panel-light .section-index{color:#8A867C}
.panel-light .hr{background:rgba(10,10,11,.12)}
.hr{height:1px;background:var(--line);border:0}

.grid{display:grid;gap:clamp(20px,3vw,48px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.7em;padding:1.05em 1.7em;border-radius:100px;
  font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.03em;
  background:var(--white);color:var(--black);overflow:hidden;isolation:isolate;
  transition:transform .55s var(--ease),color .4s var(--ease);will-change:transform}
.btn span{position:relative;z-index:2;display:inline-flex;align-items:center;gap:.6em}
.btn::after{content:"";position:absolute;inset:0;z-index:1;background:var(--grey-1);transform:translateY(101%);transition:transform .55s var(--ease)}
.btn:hover::after{transform:translateY(0)}
.btn .arr{transition:transform .5s var(--ease)}
.btn:hover .arr{transform:translate(4px,-4px)}
.btn--ghost{background:transparent;color:var(--white);border:1px solid var(--line-2)}
.btn--ghost::after{background:var(--white)}
.btn--ghost:hover{color:var(--black)}
.panel-light .btn{background:var(--ink);color:var(--paper)}
.panel-light .btn::after{background:#333}
.panel-light .btn--ghost{background:transparent;color:var(--ink);border-color:rgba(10,10,11,.25)}
.panel-light .btn--ghost::after{background:var(--ink)}
.panel-light .btn--ghost:hover{color:var(--paper)}
.btn--lg{padding:1.2em 2.1em;font-size:.9rem}

.link-underline{position:relative;font-weight:500;display:inline-flex;align-items:center;gap:.5em;padding-bottom:2px}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.link-underline:hover::after{transform:scaleX(1);transform-origin:left}
.link-underline .arr{transition:transform .4s var(--ease)}
.link-underline:hover .arr{transform:translateX(4px)}

/* ---------- Reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(30px)}
[data-reveal-line] .ln{display:block;overflow:hidden}
[data-reveal-line] .ln>*{display:block;transform:translateY(110%)}
.no-anim [data-reveal]{opacity:1;transform:none}
.no-anim [data-reveal-line] .ln>*{transform:none}
.reveal-media{position:relative;overflow:hidden}
.reveal-media img{transform:scale(1.16);will-change:transform}
.reveal-media .mask{position:absolute;inset:0;background:var(--bg);transform-origin:bottom;z-index:2}
.panel-light .reveal-media .mask{background:var(--paper)}

/* ---------- Cursor ---------- */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:difference}
.cursor{width:36px;height:36px;border:1px solid rgba(255,255,255,.85);transform:translate(-50%,-50%);transition:width .35s var(--ease),height .35s var(--ease),background .35s var(--ease),opacity .3s}
.cursor-dot{width:5px;height:5px;background:#fff;transform:translate(-50%,-50%)}
.cursor.is-hover{width:70px;height:70px;background:rgba(255,255,255,.1)}
.cursor.is-hidden{opacity:0}
@media(hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none}}

/* =====================================================================
   PRELOADER
   ===================================================================== */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--black);color:var(--white);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px}
.preloader__brand{display:flex;align-items:center;gap:13px;opacity:0}
.preloader__brand .mark{width:42px;height:42px}
.preloader__name{font-family:var(--disp);font-weight:600;font-size:1.5rem;letter-spacing:.02em}
.preloader__bar{width:min(240px,52vw);height:1px;background:rgba(245,244,241,.16);overflow:hidden}
.preloader__bar i{display:block;height:100%;width:0;background:var(--white)}
.preloader__pct{font-family:var(--sans);font-size:.74rem;letter-spacing:.28em;color:var(--grey-3)}
.preloader__count{position:absolute;bottom:5vh;right:var(--gut);font-family:var(--disp);font-weight:600;font-size:clamp(3rem,13vw,10rem);line-height:1;color:rgba(245,244,241,.06)}
body.loading{overflow:hidden}

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 var(--gut);height:var(--h-nav);transition:height .4s var(--ease)}
.header::before{content:"";position:absolute;inset:0;background:rgba(8,8,10,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);opacity:0;transition:opacity .5s var(--ease);z-index:-1;border-bottom:1px solid var(--line-soft)}
.header.scrolled::before{opacity:1}
.header.scrolled{height:62px}
.brand{display:flex;align-items:center;gap:11px;z-index:2}
.brand .mark{width:34px;height:34px;flex:none}
.brand__txt{font-family:var(--disp);font-weight:600;font-size:1.2rem;letter-spacing:.01em;line-height:1;color:var(--white)}
.brand__sub{display:block;font-family:var(--sans);font-weight:400;font-size:.54rem;letter-spacing:.32em;text-transform:uppercase;color:var(--grey-3);margin-top:4px}
.nav{display:flex;align-items:center;gap:clamp(16px,2.4vw,40px)}
.nav__links{display:flex;align-items:center;gap:clamp(16px,2vw,34px)}
.nav__link{font-family:var(--sans);font-size:.82rem;font-weight:500;position:relative;padding:6px 0;color:var(--grey-1)}
.nav__link::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--white);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.nav__link:hover{color:var(--white)}
.nav__link:hover::after,.nav__link.active::after{transform:scaleX(1);transform-origin:left}
.nav__phone{display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:.84rem;color:var(--white)}
.nav__phone svg{width:14px;height:14px;color:var(--white)}
.burger{display:none;width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);position:relative;z-index:1100;color:var(--white)}
.burger span{position:absolute;left:50%;top:50%;width:18px;height:1.4px;background:currentColor;transform:translate(-50%,-50%);transition:.4s var(--ease)}
.burger span:nth-child(1){margin-top:-4px}
.burger span:nth-child(2){margin-top:4px}
.menu-open .burger span:nth-child(1){margin-top:0;transform:translate(-50%,-50%) rotate(45deg)}
.menu-open .burger span:nth-child(2){margin-top:0;transform:translate(-50%,-50%) rotate(-45deg)}

.mobile-nav{position:fixed;inset:0;z-index:1050;background:var(--black);color:var(--white);display:flex;flex-direction:column;justify-content:center;padding:max(var(--gut),28px);clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease-inout);pointer-events:none}
.menu-open .mobile-nav{clip-path:inset(0 0 0 0);pointer-events:auto}
.mobile-nav a.m-link{font-family:var(--disp);font-weight:500;font-size:clamp(2.2rem,11vw,4rem);line-height:1.12;display:block;padding:.06em 0;opacity:0;transform:translateY(20px);letter-spacing:-.02em}
.menu-open .mobile-nav a.m-link{opacity:1;transform:none;transition:opacity .5s var(--ease) .25s,transform .6s var(--ease) .25s}
.menu-open .mobile-nav a.m-link:nth-child(2){transition-delay:.31s}
.menu-open .mobile-nav a.m-link:nth-child(3){transition-delay:.37s}
.menu-open .mobile-nav a.m-link:nth-child(4){transition-delay:.43s}
.menu-open .mobile-nav a.m-link:nth-child(5){transition-delay:.49s}
.mobile-nav__foot{margin-top:auto;padding-top:32px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:space-between;font-size:.95rem;color:var(--grey-2)}
@media(max-width:900px){.nav__links,.nav__phone,.nav .btn{display:none}.burger{display:block}}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(34px,6vh,70px);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.08);will-change:transform,opacity}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,10,.78) 0%,rgba(8,8,10,.34) 30%,rgba(8,8,10,.5) 64%,rgba(8,8,10,.94) 100%)}
.hero__top{position:absolute;top:calc(var(--h-nav) + 3.4vh);left:var(--gut);right:var(--gut);z-index:3;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.hero__inner{position:relative;z-index:3;width:100%}
.hero h1{max-width:15ch;text-wrap:balance}
.hero__meta{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:28px;margin-top:clamp(22px,3.4vw,40px)}
.hero__meta p{max-width:44ch}
.hero__scroll{display:inline-flex;align-items:center;gap:.7em;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--grey-2)}
.hero__scroll i{width:1px;height:32px;background:var(--grey-3);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--white);animation:scrolldn 1.8s var(--ease) infinite}
@keyframes scrolldn{to{top:100%}}
/* mobile hero: eyebrows in normal flow at top, content pinned to bottom — no overlap */
@media(max-width:680px){
  .hero{justify-content:space-between;padding-top:calc(var(--h-nav) + 2.4vh);padding-bottom:38px}
  .hero__top{position:static;left:auto;right:auto;top:auto;flex-direction:column;align-items:flex-start;gap:9px;margin-bottom:10px}
  .hero h1{font-size:clamp(2.5rem,11.5vw,3.4rem);max-width:100%}
  .hero__inner{margin-top:auto}
  .hero__meta{margin-top:18px;gap:18px}
  .hero__meta:last-child{margin-top:24px}
  .hero .flex-cta .btn{width:100%;justify-content:center}
}

/* =====================================================================
   CIPHER CHOREO  (image small -> moves -> fullscreen)
   ===================================================================== */
.seq{position:relative;height:440vh;background:var(--bg)}
.seq__stage{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.seq__img{position:absolute;left:50%;top:50%;width:32vw;height:42vh;transform:translate(-50%,-50%);overflow:hidden;will-change:transform;border-radius:var(--radius)}
.seq__img.js-seq{transform:none}  /* GSAP owns centering via xPercent/yPercent */
.seq__img img{width:100%;height:100%;object-fit:cover;will-change:transform}
.seq__txt{position:absolute;top:50%;transform:translateY(-50%);max-width:min(34ch,30vw);z-index:4;opacity:0;will-change:opacity,transform}
.seq__txt--r{right:var(--gut);text-align:left}
.seq__txt--l{left:var(--gut)}
.seq__txt .eyebrow{margin-bottom:16px}
.seq__txt p{color:var(--grey-1)}
.seq__final{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;text-align:center;opacity:0;pointer-events:none;padding:var(--gut)}
.seq__final::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,4,5,.3),rgba(4,4,5,.55))}
.seq__final h2{position:relative;max-width:18ch;color:var(--white);text-shadow:0 2px 40px rgba(0,0,0,.5)}
.seq__count{position:absolute;left:var(--gut);bottom:34px;z-index:6;font-family:var(--disp);font-weight:600;font-size:.9rem;color:var(--grey-3)}
@media(max-width:820px){
  .seq{height:380vh}
  .seq__img{width:74vw;height:46vh}
  .seq__txt{position:absolute;max-width:80vw;left:var(--gut);right:var(--gut);text-align:left;top:auto}
  .seq__txt--r{bottom:9vh;top:auto;transform:none;right:var(--gut)}
  .seq__txt--l{top:13vh;bottom:auto;transform:none}
}

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding-block:16px;white-space:nowrap}
.panel-light .marquee{border-color:rgba(10,10,11,.14)}
.marquee__row{display:inline-flex;gap:42px;align-items:center;will-change:transform}
.marquee__row span{font-family:var(--disp);font-weight:500;font-size:clamp(1.2rem,2.4vw,2rem);display:inline-flex;align-items:center;gap:42px;color:var(--grey-2);letter-spacing:-.01em}
.marquee__row .dot{width:6px;height:6px;border-radius:50%;background:var(--grey-3);flex:none}

/* =====================================================================
   SECTION HEAD
   ===================================================================== */
.sec-head{margin-bottom:clamp(40px,6vw,84px)}
.sec-head__top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.sec-head h2{max-width:18ch}
.sec-head .lead{max-width:46ch}

/* MANIFESTO */
.manifesto__big{font-family:var(--disp);font-weight:500;font-size:clamp(1.7rem,4.2vw,3.4rem);line-height:1.1;letter-spacing:-.025em;max-width:24ch}
.manifesto__big .muted{color:var(--grey-3)}
.manifesto__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);border-top:1px solid var(--line);padding-top:34px;margin-top:clamp(40px,5vw,70px)}
.manifesto__cols h3{font-size:1.1rem;font-family:var(--sans);font-weight:600;letter-spacing:0;margin-bottom:10px}
@media(max-width:760px){.manifesto__cols{grid-template-columns:1fr;gap:30px}}

/* =====================================================================
   VIDEO SCRUB
   ===================================================================== */
.scrub{position:relative;height:600vh;background:var(--black)}
.scrub__sticky{position:sticky;top:0;height:100svh;overflow:hidden;background:var(--black)}
.scrub canvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.scrub__shade{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(4,4,5,.55) 0%,transparent 24%,transparent 54%,rgba(4,4,5,.9) 100%)}
.scrub__progress{position:absolute;left:var(--gut);right:var(--gut);bottom:28px;z-index:5;height:1px;background:rgba(245,244,241,.16)}
.scrub__progress i{display:block;height:100%;width:0;background:var(--white)}
.scrub__step{position:absolute;left:var(--gut);max-width:min(620px,82vw);opacity:0;transform:translateY(26px);will-change:opacity,transform;z-index:3}
.scrub__step::before{content:"";position:absolute;left:-8vw;right:-12vw;top:-12vh;bottom:-12vh;z-index:-1;
  background:radial-gradient(120% 120% at 18% 50%,rgba(4,4,5,.82) 0%,rgba(4,4,5,.55) 38%,transparent 72%);pointer-events:none}
.scrub__step.top{top:clamp(96px,16vh,160px)}
.scrub__step.bottom{bottom:clamp(64px,13vh,118px)}
.scrub__step .eyebrow{margin-bottom:14px}
.scrub__step h2{color:var(--white);max-width:15ch;text-shadow:0 2px 30px rgba(0,0,0,.45)}
.scrub__step .lead{color:#EDEAE3;margin-top:16px;max-width:44ch;text-shadow:0 1px 24px rgba(0,0,0,.7)}
.scrub__step .eyebrow{text-shadow:0 1px 20px rgba(0,0,0,.6)}
.scrub__hint{position:absolute;top:calc(var(--h-nav) + 14px);left:50%;transform:translateX(-50%);z-index:4;color:var(--grey-2);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;transition:opacity .5s var(--ease)}
.scrub__loading{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;background:var(--black);color:var(--grey-3);font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;transition:opacity .6s var(--ease)}
.scrub__loading.hide{opacity:0;pointer-events:none}

/* =====================================================================
   SERVICES
   ===================================================================== */
.svc{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,1.6vw,22px)}
@media(max-width:760px){.svc{grid-template-columns:1fr}}
.svc__card{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--panel);color:var(--white);min-height:clamp(360px,44vw,520px);display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(26px,3vw,44px);isolation:isolate;border:1px solid var(--line-soft)}
.svc__card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.2s var(--ease),filter 1.2s var(--ease);transform:scale(1.05);filter:grayscale(.4) brightness(.78)}
.svc__card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(4,4,5,.92) 4%,rgba(4,4,5,.35) 52%,rgba(4,4,5,.5) 100%)}
.svc__card:hover img{transform:scale(1.1);filter:grayscale(0) brightness(.92)}
.svc__num{position:absolute;top:clamp(22px,3vw,40px);left:clamp(26px,3vw,44px);font-family:var(--disp);font-weight:600;font-size:1.05rem;color:var(--grey-1)}
.svc__tag{position:absolute;top:clamp(22px,3vw,40px);right:clamp(26px,3vw,44px);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--grey-1);border:1px solid var(--line-2);padding:5px 11px;border-radius:100px}
.svc__card h3{font-size:clamp(1.5rem,2.4vw,2.1rem);margin-bottom:12px}
.svc__card p{color:var(--grey-1);font-size:.98rem;max-width:42ch}
.svc__list{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.svc__list li{font-size:.74rem;letter-spacing:.01em;color:var(--grey-1);border:1px solid var(--line);padding:6px 12px;border-radius:100px;background:rgba(245,244,241,.03)}
.svc__more{margin-top:22px;display:inline-flex;align-items:center;gap:.55em;font-size:.82rem;font-weight:600;color:var(--white)}
.svc__more .arr{transition:transform .45s var(--ease)}
.svc__card:hover .svc__more .arr{transform:translate(4px,-4px)}

/* =====================================================================
   PRODUX MOSAIC  (tiles assemble)
   ===================================================================== */
.mosaic{position:relative;height:300vh;background:var(--bg)}
.mosaic__stage{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;justify-content:center;perspective:1400px}
.mosaic__grid{position:relative;width:min(880px,86vw);aspect-ratio:16/10;transform-style:preserve-3d}
.mosaic__t{position:absolute;overflow:hidden;border-radius:3px;will-change:transform,opacity;backface-visibility:hidden}
.mosaic__t img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2)}
.mosaic__cap{position:absolute;z-index:6;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center;mix-blend-mode:difference;pointer-events:none;opacity:0}
.mosaic__cap h2{color:#fff;font-size:clamp(2.4rem,9vw,7rem)}

/* =====================================================================
   GALLERY (bento)
   ===================================================================== */
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(116px,auto);gap:clamp(10px,1.2vw,18px)}
.bento figure{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--panel)}
.bento figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease),filter 1.1s var(--ease);filter:grayscale(.3)}
.bento figure:hover img{transform:scale(1.05);filter:grayscale(0)}
.bento figcaption{position:absolute;left:0;bottom:0;z-index:2;padding:16px 18px;color:var(--white);font-size:.78rem;background:linear-gradient(to top,rgba(4,4,5,.82),transparent);width:100%;opacity:0;transform:translateY(8px);transition:.45s var(--ease)}
.bento figcaption b{font-family:var(--disp);font-weight:500;font-size:1rem;display:block;letter-spacing:-.01em}
.bento figcaption span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey-1)}
.bento figure:hover figcaption{opacity:1;transform:none}
.b-tall{grid-column:span 4;grid-row:span 3}
.b-wide{grid-column:span 8;grid-row:span 2}
.b-sq{grid-column:span 4;grid-row:span 2}
.b-md{grid-column:span 6;grid-row:span 2}
@media(max-width:760px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-tall,.b-sq,.b-md{grid-column:span 1;grid-row:span 1;aspect-ratio:4/5}
  .b-wide{grid-column:span 2;aspect-ratio:16/10}
}

/* =====================================================================
   PROCESS
   ===================================================================== */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,30px)}
@media(max-width:900px){.proc{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.proc{grid-template-columns:1fr}}
.proc__item{position:relative;padding-top:32px;border-top:1px solid var(--line)}
.proc__n{font-family:var(--disp);font-weight:600;font-size:2.2rem;color:var(--white);line-height:1;margin-bottom:18px}
.proc__item h3{font-family:var(--sans);font-weight:600;font-size:1.14rem;letter-spacing:0;margin-bottom:10px}
.proc__item p{font-size:.95rem}

/* =====================================================================
   TRUST
   ===================================================================== */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,34px)}
@media(max-width:900px){.trust{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.trust{grid-template-columns:1fr}}
.trust__item{display:flex;flex-direction:column;gap:8px}
.trust__item .ic{width:32px;height:32px;color:var(--white)}
.panel-light .trust__item .ic{color:var(--ink)}
.trust__item b{font-family:var(--disp);font-weight:500;font-size:1.6rem;line-height:1.05;letter-spacing:-.01em}
.trust__item span{font-size:.92rem;color:var(--grey-2)}
.panel-light .trust__item span{color:#5C5A54}

/* =====================================================================
   CTA / CONTACT
   ===================================================================== */
.cta-big h2{font-size:clamp(2.6rem,8vw,7rem);max-width:15ch}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.contact-cards{display:flex;flex-direction:column;gap:12px}
.contact-card{display:flex;align-items:center;gap:18px;padding:20px 22px;border:1px solid var(--line);border-radius:var(--radius);transition:border-color .4s var(--ease),background .4s var(--ease)}
.contact-card:hover{border-color:var(--line-2);background:rgba(245,244,241,.03)}
.contact-card .ic{width:40px;height:40px;flex:none;border-radius:50%;display:grid;place-items:center;background:rgba(245,244,241,.07);color:var(--white)}
.contact-card .ic svg{width:18px;height:18px}
.contact-card small{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--grey-3);margin-bottom:4px}
.contact-card b{font-family:var(--disp);font-weight:500;font-size:1.28rem;letter-spacing:-.01em}
.contact-card .arr{margin-left:auto;color:var(--grey-3);transition:transform .4s var(--ease),color .4s var(--ease)}
.contact-card:hover .arr{transform:translate(4px,-4px);color:var(--white)}

.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:520px){.form .row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column}
.field label{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-3);margin-bottom:8px}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:1rem;color:var(--white);background:transparent;border:0;border-bottom:1px solid var(--line);padding:12px 0;transition:border-color .4s var(--ease)}
.field input::placeholder,.field textarea::placeholder{color:var(--grey-3)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--white)}
.field select{appearance:none;cursor:pointer}
.field select option{color:#111}
.field textarea{resize:vertical;min-height:96px}
.form__foot{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:6px}
.form__note{font-size:.8rem;color:var(--grey-3);max-width:34ch}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--black);color:var(--white);padding-top:clamp(60px,8vw,110px)}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(30px,4vw,60px);padding-bottom:56px;border-bottom:1px solid var(--line)}
@media(max-width:820px){.footer__top{grid-template-columns:1fr 1fr}.footer__brandcol{grid-column:1/-1}}
@media(max-width:520px){.footer__top{grid-template-columns:1fr}}
.footer__brandcol .brand__txt{font-size:1.6rem}
.footer__brandcol p{color:var(--grey-2);margin-top:18px;max-width:38ch}
.footer h4{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--grey-3);margin-bottom:20px;font-weight:600}
.footer ul li{margin-bottom:12px}
.footer ul a{color:var(--grey-1);transition:color .35s}
.footer ul a:hover{color:var(--white)}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-block:26px;font-size:.8rem;color:var(--grey-3)}
.footer__bottom a:hover{color:var(--white)}
.footer__huge{font-family:var(--disp);font-weight:600;font-size:clamp(3.2rem,19vw,16rem);line-height:.82;letter-spacing:-.03em;color:rgba(245,244,241,.05);padding-block:clamp(20px,4vw,56px);text-align:center;user-select:none}

/* =====================================================================
   SUB-PAGES
   ===================================================================== */
.page-hero{padding-top:calc(var(--h-nav) + clamp(50px,9vw,120px));padding-bottom:clamp(40px,6vw,80px);position:relative}
.page-hero h1{max-width:16ch}
.page-hero .lead{margin-top:24px;max-width:56ch}
.crumb{display:flex;gap:10px;align-items:center;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-3);margin-bottom:26px}
.crumb a:hover{color:var(--white)}
.crumb .sep{opacity:.5}

.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,70px);align-items:center;padding-block:clamp(40px,6vw,84px);border-top:1px solid var(--line)}
.svc-row:nth-child(even) .svc-row__media{order:2}
@media(max-width:820px){.svc-row{grid-template-columns:1fr;gap:26px}.svc-row:nth-child(even) .svc-row__media{order:0}}
.svc-row__media{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:5/4}
.svc-row__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25)}
.svc-row__n{font-family:var(--disp);font-weight:600;font-size:clamp(2.4rem,5vw,4rem);color:var(--grey-3);line-height:1;margin-bottom:18px}
.svc-row ul{margin-top:22px;display:grid;gap:11px}
.svc-row ul li{display:flex;gap:12px;align-items:flex-start;font-size:.98rem;color:var(--grey-1)}
.svc-row ul li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--white);margin-top:9px;flex:none}

.filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filter button{padding:9px 18px;border:1px solid var(--line);border-radius:100px;font-size:.82rem;font-weight:500;color:var(--grey-1);transition:.35s var(--ease)}
.filter button.active,.filter button:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.masonry{columns:3;column-gap:clamp(10px,1.2vw,18px)}
@media(max-width:900px){.masonry{columns:2}}
@media(max-width:560px){.masonry{columns:1}}
.masonry figure{break-inside:avoid;margin-bottom:clamp(10px,1.2vw,18px);position:relative;overflow:hidden;border-radius:var(--radius)}
.masonry figure img{width:100%;transition:transform 1s var(--ease),filter 1s var(--ease);filter:grayscale(.3)}
.masonry figure:hover img{transform:scale(1.04);filter:grayscale(0)}
.masonry figcaption{position:absolute;left:0;bottom:0;width:100%;padding:16px;color:var(--white);background:linear-gradient(to top,rgba(4,4,5,.82),transparent);opacity:0;transition:.4s var(--ease)}
.masonry figure:hover figcaption{opacity:1}
.masonry figcaption b{font-family:var(--disp);font-weight:500;display:block}
.masonry figcaption span{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-1)}
.is-hidden-item{display:none}

.values{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.2vw,36px)}
@media(max-width:680px){.values{grid-template-columns:1fr}}
.value{padding:30px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
.value .ic{width:30px;height:30px;color:var(--white);margin-bottom:18px}
.value h3{font-family:var(--sans);font-weight:600;font-size:1.16rem;letter-spacing:0;margin-bottom:10px}
.value p{font-size:.96rem;color:var(--grey-2)}

.legal-body{max-width:760px}
.legal-body h2{font-size:clamp(1.4rem,2.6vw,2rem);margin:46px 0 16px}
.legal-body h3{font-family:var(--sans);font-weight:600;font-size:1.05rem;margin:26px 0 8px;letter-spacing:0}
.legal-body p,.legal-body li{color:var(--grey-2);font-size:.98rem;margin-bottom:10px}
.legal-body ul{padding-left:20px;list-style:disc}
.legal-body a{color:var(--white);text-decoration:underline}

/* utilities */
.center{text-align:center}
.mt-s{margin-top:18px}.mt-m{margin-top:32px}.mt-l{margin-top:54px}
.flex-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.nowrap{white-space:nowrap}

/* clickable affordance on gallery images */
.bento figure[data-lb],.masonry figure[data-lb]{cursor:pointer}
.lb-badge{position:absolute;top:14px;right:14px;z-index:3;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:rgba(8,8,10,.55);border:1px solid var(--line-2);color:var(--white);opacity:0;transform:scale(.8);transition:.4s var(--ease);backdrop-filter:blur(4px)}
.bento figure:hover .lb-badge,.masonry figure:hover .lb-badge{opacity:1;transform:scale(1)}
.lb-badge svg{width:15px;height:15px}

/* =====================================================================
   LIGHTBOX
   ===================================================================== */
.lightbox{position:fixed;inset:0;z-index:9990;display:flex;align-items:center;justify-content:center;
  background:rgba(4,4,5,.94);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .45s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox__stage{position:relative;width:min(1200px,92vw);height:min(82vh,900px);display:flex;align-items:center;justify-content:center}
.lightbox__img{max-width:100%;max-height:100%;object-fit:contain;border-radius:3px;opacity:0;transform:scale(.97);transition:opacity .4s var(--ease),transform .5s var(--ease);box-shadow:0 40px 120px -30px rgba(0,0,0,.8)}
.lightbox.show-img .lightbox__img{opacity:1;transform:scale(1)}
.lightbox__cap{position:absolute;left:0;bottom:-42px;width:100%;display:flex;justify-content:space-between;gap:16px;color:var(--grey-1);font-size:.86rem}
.lightbox__cap b{font-family:var(--disp);font-weight:500;color:var(--white)}
.lightbox__cap span{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey-3)}
.lb-btn{position:absolute;z-index:2;width:54px;height:54px;border-radius:50%;border:1px solid var(--line-2);color:var(--white);display:grid;place-items:center;background:rgba(20,20,24,.5);transition:.35s var(--ease)}
.lb-btn:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.lb-btn svg{width:20px;height:20px}
.lb-prev{left:max(12px,2vw);top:50%;transform:translateY(-50%)}
.lb-next{right:max(12px,2vw);top:50%;transform:translateY(-50%)}
.lb-close{top:max(18px,3vh);right:max(18px,3vw);width:48px;height:48px}
.lb-count{position:absolute;top:max(22px,3vh);left:max(18px,3vw);color:var(--grey-2);font-size:.8rem;letter-spacing:.1em}
@media(max-width:680px){.lb-prev{left:8px}.lb-next{right:8px}.lb-btn{width:46px;height:46px}.lightbox__cap{bottom:-38px;font-size:.78rem}}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .seq,.scrub,.mosaic{height:auto}
  .seq__stage,.scrub__sticky,.mosaic__stage{position:relative;height:auto;min-height:60vh}
}
