/* ============================================================
   SHAKE — cinematic site styles
   Type:  Excrallik (display / headers) + Futura (body)
   Color: deep navy #0a1238, purple accent #8964ce (tweakable)
   ============================================================ */

/* ---- Brand fonts ---- */
@font-face{
  font-family:"Excrallik";
  src:url("../fonts/Excrallik-Regular.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Excrallik";
  src:url("../fonts/Excrallik-Italic.otf") format("opentype");
  font-weight:400;font-style:italic;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-Light.ttf") format("truetype");
  font-weight:300;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-Book.ttf") format("truetype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-BookItalic.ttf") format("truetype");
  font-weight:400;font-style:italic;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-Medium.ttf") format("truetype");
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-Bold.ttf") format("truetype");
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Futura";
  src:url("../fonts/Futura-Heavy.ttf") format("truetype");
  font-weight:800;font-style:normal;font-display:swap;
}

:root{
  /* palette */
  --ink-deep:#060a22;
  --ink:#0a1238;
  --ink-soft:#111a40;
  --ink-card:#0f1738;
  --royal:#002e8c;

  --accent:#c39b67;            /* sand gold (brand) */
  --accent-rgb:195,155,103;

  --paper:#ffffff;
  --text:#eef0f7;
  --text-dim:rgba(238,240,247,.62);
  --text-faint:rgba(238,240,247,.38);
  --line:rgba(238,240,247,.12);
  --line-soft:rgba(238,240,247,.07);

  /* type */
  --serif:"Excrallik", Georgia, serif;
  --sans:"Futura", "Futura PT", system-ui, -apple-system, sans-serif;

  /* layout */
  --pad:clamp(20px,5vw,72px);
  --maxw:1480px;
  --nav-h:78px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ink-deep);
  color:var(--text);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:rgba(var(--accent-rgb),.4);color:#fff}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:12px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-faint);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{
  content:"";width:30px;height:0;border-top:1.5px dashed var(--accent);display:inline-block;
}
.eyebrow.no-rule::before{display:none}

.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:.98;
  letter-spacing:-.015em;
  font-optical-sizing:auto;
  text-wrap:balance;
}
.serif-italic{font-style:italic;font-weight:500}

.section{padding:clamp(80px,11vh,150px) var(--pad);position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;width:100%}
.tone-deep{background:var(--ink-deep)}
.tone-ink{background:var(--ink)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--accent);--fg:#0a0d22;
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-weight:700;font-size:14px;
  letter-spacing:.01em;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.7,.3,1),background .3s,color .3s,border-color .3s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn .ico{transition:transform .35s cubic-bezier(.2,.7,.3,1)}
.btn:hover .ico{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--text);background:rgba(255,255,255,.04)}
.btn--light{background:var(--paper);color:var(--ink)}

.txtlink{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:600;font-size:14px;letter-spacing:.02em;
  padding-bottom:3px;border-bottom:1px solid var(--line);
  transition:border-color .3s,color .3s;
}
.txtlink:hover{border-color:var(--accent);color:#fff}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);
  transition:background .4s,backdrop-filter .4s,border-color .4s,height .4s;
  border-bottom:1px solid transparent;
}
.nav.solid{
  background:rgba(6,10,34,.72);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--line-soft);
  height:64px;
}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:38px;width:auto}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{
  font-size:14px;font-weight:500;color:var(--text-dim);
  letter-spacing:.01em;position:relative;transition:color .25s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--accent);transition:width .3s cubic-bezier(.2,.7,.3,1);
}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:18px}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:1.5px;background:var(--text);display:block}

/* ============================================================
   HERO  (3 directions via [data-hero])
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:grid;
  overflow:hidden;
  background:var(--ink-deep);
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media image-slot{width:100%;height:100%}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero__media::after{
  /* film grain / vignette */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 30%,transparent 40%,rgba(6,10,34,.55) 100%);
}
.hero__scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(6,10,34,calc(.28 * var(--scrim,1))) 0%,
    rgba(6,10,34,calc(.38 * var(--scrim,1))) 40%,
    rgba(6,10,34,calc(.72 * var(--scrim,1))) 72%,
    rgba(6,10,34,1) 100%);
}
.hero__inner{
  position:relative;z-index:3;
  max-width:var(--maxw);margin:0 auto;width:100%;
  padding:0 var(--pad);
  align-self:center;
  padding-top:var(--nav-h);
}
.hero__eyebrow{margin:0 0 26px;color:rgba(238,240,247,.8)}
.hero__title{
  margin:0;
  font-size:clamp(3rem,9vw,8.2rem);
  color:#fff;
}
.hero__sub{
  margin:30px 0 0;max-width:46ch;
  font-size:clamp(16px,1.4vw,20px);color:rgba(238,240,247,.78);
  line-height:1.55;
}
/* centre the animated slide-in headline that can be injected into .hero__sub
   (overrides its inline width / text-align:start so it stays page-centred) */
.hero__sub .preSlide{width:auto !important;max-width:100% !important;text-align:center !important;margin-inline:auto !important}
.hero__sub .preSlide span{text-align:center !important}
.hero__cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap;align-items:center}

.hero__foot{
  position:absolute;z-index:3;bottom:34px;left:var(--pad);right:var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);
}
.hero__scroll{display:inline-flex;align-items:center;gap:12px}
.hero__scroll .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);
  animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}

.hero__play{
  position:absolute;z-index:3;
  display:inline-flex;align-items:center;gap:14px;
  background:none;border:0;cursor:pointer;color:#fff;
}
.hero__play .ring{
  width:78px;height:78px;border-radius:50%;
  border:1px solid rgba(255,255,255,.45);
  display:grid;place-items:center;
  transition:background .35s,border-color .35s,transform .35s;
  backdrop-filter:blur(2px);
}
.hero__play:hover .ring{background:var(--accent);border-color:var(--accent);transform:scale(1.06)}
.hero__play .ring svg{margin-left:3px}
.hero__play .lbl{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* --- direction A: centered statement --- */
.hero[data-hero="a"] .hero__inner{text-align:center;display:flex;flex-direction:column;align-items:center}
.hero[data-hero="a"] .hero__sub{margin-left:auto;margin-right:auto}
.hero[data-hero="a"] .hero__cta{justify-content:center}
.hero[data-hero="a"] .hero__play{left:50%;bottom:34px;transform:translateX(-50%);flex-direction:column;gap:10px}
.hero[data-hero="a"] .hero__foot{display:none}

/* --- direction B: bottom-left asymmetric --- */
.hero[data-hero="b"]{grid-template-rows:1fr auto}
.hero[data-hero="b"] .hero__inner{align-self:end;padding-bottom:120px;max-width:var(--maxw)}
.hero[data-hero="b"] .hero__title{font-size:clamp(3rem,10vw,9rem)}
.hero[data-hero="b"] .hero__play{right:var(--pad);bottom:130px;flex-direction:column;gap:12px}
.hero[data-hero="b"] .hero__foot{bottom:40px}

/* --- direction C: split, type-forward --- */
.hero[data-hero="c"]{grid-template-columns:1fr;}
.hero[data-hero="c"] .hero__media{left:auto;width:48vw}
.hero[data-hero="c"] .hero__media::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(90deg,var(--ink-deep) 0%,transparent 22%);
}
.hero[data-hero="c"] .hero__scrim{background:linear-gradient(90deg,
  rgba(6,10,34,calc(.5*var(--scrim,1))),rgba(6,10,34,calc(.2*var(--scrim,1))))}
.hero[data-hero="c"] .hero__inner{max-width:var(--maxw)}
.hero[data-hero="c"] .hero__title{max-width:11ch;font-size:clamp(3rem,7.5vw,7rem)}
.hero[data-hero="c"] .hero__mono{
  position:absolute;z-index:1;left:-2vw;bottom:-6vh;width:42vw;opacity:.05;pointer-events:none;
}
.hero[data-hero="c"] .hero__play{left:var(--pad);bottom:40px}
.hero[data-hero="c"] .hero__foot{justify-content:flex-end;right:var(--pad);left:auto;width:48vw}
.hero[data-hero="a"] .hero__mono,.hero[data-hero="b"] .hero__mono{display:none}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{padding:46px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);overflow:hidden}
.trust__lbl{text-align:center;margin:0 0 30px;color:#fff;
  font-size:14px;letter-spacing:.2em;text-transform:uppercase}
.marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:64px;padding-right:64px;animation:scroll-x 76s linear infinite;flex-shrink:0}
.trust:hover .marquee__track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(-100%)}}
.crest{
  display:flex;align-items:center;gap:16px;flex-shrink:0;opacity:.78;transition:opacity .3s;
}
.crest:hover{opacity:1}
.crest__mark{width:48px;height:48px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--serif);font-size:21px;color:#fff}
.crest__logo{width:66px;height:66px;border-radius:50% 42% 54% 44%;flex-shrink:0;object-fit:contain}
.crest__name{font-family:var(--serif);font-size:30px;font-style:italic;color:#fff;white-space:nowrap}

/* ============================================================
   STATEMENT
   ============================================================ */
.statement{text-align:left}
.statement__big{
  font-size:clamp(1.8rem,4.4vw,3.6rem);
  line-height:1.16;font-weight:420;letter-spacing:-.01em;
  max-width:24ch;color:var(--text);
}
.statement__big .accent{color:var(--accent);font-family:var(--serif);font-style:italic;font-weight:500}
.statement__row{display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;flex-wrap:wrap;margin-top:60px}
.statement__note{max-width:42ch;color:var(--text-dim);font-size:16px}

/* ============================================================
   WORK GRID
   ============================================================ */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:54px}
.sec-head h2{margin:14px 0 0;font-size:clamp(2.2rem,5vw,4rem);color:#fff}
.sec-head__r{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:13px;color:var(--text-dim);padding:8px 16px;border:1px solid var(--line);
  border-radius:999px;cursor:pointer;transition:.25s}
.chip:hover,.chip.on{color:#fff;border-color:var(--accent);background:rgba(var(--accent-rgb),.14)}

.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:26px}
.work{position:relative;grid-column:span 6;cursor:pointer;display:block}
.work.tall{grid-column:span 6}
.work.wide{grid-column:span 12}
.work__media{position:relative;border-radius:42px 14px 38px 14px;overflow:hidden;aspect-ratio:16/10;background:var(--ink-soft);
  transition:border-radius .6s cubic-bezier(.2,.7,.3,1)}
.work-grid .work:nth-child(even) .work__media{border-radius:14px 42px 14px 38px}
.work.wide .work__media{aspect-ratio:21/9;border-radius:56px 18px 52px 18px}
.work:hover .work__media{border-radius:26px}
.work__media image-slot{width:100%;height:100%;transition:transform .9s cubic-bezier(.2,.7,.3,1)}
.work__thumb{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.3,1)}
.work:hover .work__thumb{transform:scale(1.04)}
.work:hover .work__media image-slot{transform:scale(1.04)}
.work__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,10,34,.55));pointer-events:none;opacity:0;transition:opacity .4s}
.work:hover .work__media::after{opacity:1}
.work-foot{margin-top:54px;display:flex;justify-content:space-between;align-items:center;gap:24px 50px;flex-wrap:wrap}
.alt-cta{display:inline-flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:18px 26px;border-radius:18px 6px 18px 6px;
  background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.45);
  transition:background .3s,border-color .3s,transform .35s cubic-bezier(.2,.7,.3,1),box-shadow .3s}
.alt-cta:hover{background:rgba(var(--accent-rgb),.2);border-color:var(--accent);transform:translateY(-2px);
  box-shadow:0 14px 34px -18px rgba(var(--accent-rgb),.7)}
.alt-cta__tag{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--accent);white-space:nowrap}
.alt-cta__txt{font-size:15px;color:var(--text);max-width:26ch}
.alt-cta__go{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:14px;
  letter-spacing:.01em;color:var(--accent);white-space:nowrap}
.alt-cta__go span{transition:transform .35s cubic-bezier(.2,.7,.3,1)}
.alt-cta:hover .alt-cta__go span{transform:translateX(4px)}
@media(max-width:560px){.alt-cta{width:100%}}
.work__play{position:absolute;top:18px;right:18px;z-index:2;width:46px;height:46px;border-radius:50%;
  background:rgba(6,10,34,.5);border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;
  backdrop-filter:blur(4px);transition:.35s;transform:scale(.9);opacity:0}
.work:hover .work__play{opacity:1;transform:scale(1);background:var(--accent);border-color:var(--accent)}
.work__meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-top:18px}
.work__title{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:500;color:#fff}
.work__tag{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);white-space:nowrap}
.work__cat{font-size:14px;color:var(--accent);margin-top:4px}

/* ============================================================
   SERVICES
   ============================================================ */
.svc-feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,80px);align-items:center;margin-bottom:90px}
.svc-feature__text{position:relative}
/* full-section background video */
#services{overflow:hidden}
#services > .wrap{position:relative;z-index:2}
.svc-bgvideo{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.svc-bgvideo video{width:100%;height:100%;object-fit:cover;opacity:.32}
.svc-bgvideo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,var(--ink) 0%,rgba(10,18,56,.55) 38%,rgba(10,18,56,.55) 62%,var(--ink) 100%)}
.svc-feature__media{position:relative;border-radius:52px 16px 56px 18px;overflow:hidden;aspect-ratio:4/3}
.svc-feature__media image-slot{width:100%;height:100%}
.svc-feature__img{width:100%;height:100%;object-fit:cover;object-position:60% center;display:block}
.svc-feature h3{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.2vw,3.4rem);margin:18px 0 0;line-height:1.04;color:#fff}
.svc-feature p{color:var(--text-dim);margin:22px 0 30px;max-width:46ch}
.svc-list{position:relative;display:flex;flex-direction:column;gap:22px}
/* dotted squiggle path (drawn through the number-nodes by JS, hugging the left gutter so it never crosses text) */
.svc-squiggle{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;overflow:visible}
.svc-squiggle path{fill:none;stroke:rgba(var(--accent-rgb),.6);stroke-width:2;stroke-linecap:round;stroke-dasharray:2 9}
.svc-item{position:relative;z-index:0;width:100%;display:grid;grid-template-columns:64px 1fr auto;gap:24px;align-items:center;
  padding:26px 32px;border:1px solid var(--line);background:rgba(19,28,68,.4);
  transition:transform .45s cubic-bezier(.2,.7,.3,1),background .35s,border-color .35s;cursor:default}
/* organic: each box a different size & offset so the row feels hand-placed */
@media (min-width:861px){
  .svc-item:nth-of-type(1){width:58%;margin-left:0}
  .svc-item:nth-of-type(2){width:72%;margin-left:78px}
  .svc-item:nth-of-type(3){width:54%;margin-left:30px}
  .svc-item:nth-of-type(4){width:67%;margin-left:118px}
}
.svc-list .svc-item:nth-of-type(odd){border-radius:42px 16px 38px 16px}
.svc-list .svc-item:nth-of-type(even){border-radius:16px 42px 16px 38px}
.svc-item:hover{transform:translateX(10px);background:rgba(20,30,74,.7);border-color:rgba(var(--accent-rgb),.4)}
.svc-item__no{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;
  border-radius:50% 46% 52% 48%;border:1px solid rgba(var(--accent-rgb),.5);background:var(--ink-card);
  font-family:var(--serif);font-size:18px;color:var(--accent);font-style:italic}
.svc-item__main h4{margin:0;font-family:var(--serif);font-weight:500;font-size:clamp(1.4rem,2.6vw,2rem);color:#fff}
.svc-item__main p{margin:8px 0 0;color:var(--text-dim);font-size:15px;max-width:60ch}
.svc-item__arrow{color:var(--text-faint);transition:transform .35s,color .35s}
.svc-item:hover .svc-item__arrow{color:var(--accent);transform:translateX(6px)}

/* ============================================================
   APPROACH
   ============================================================ */
.approach-flow{position:relative;display:grid;grid-template-columns:repeat(4,1fr);
  align-items:start;gap:clamp(16px,2vw,30px);padding:30px 0 64px}
.approach-flow__line{position:absolute;left:2%;top:50%;transform:translateY(-50%);
  width:96%;height:240px;z-index:0;pointer-events:none}
.step{position:relative;z-index:1;display:flex;flex-direction:column;gap:18px;
  padding:30px 28px 32px;background:rgba(19,28,68,.7);
  border:1px solid var(--line);transition:transform .4s ease,background .35s,border-color .35s}
/* organic, asymmetric blob corners — different per card so the row feels hand-placed */
.approach-flow .step:nth-child(2){border-radius:54px 22px 50px 20px}
.approach-flow .step:nth-child(3){border-radius:22px 52px 20px 48px}
.approach-flow .step:nth-child(4){border-radius:48px 24px 56px 20px}
.approach-flow .step:nth-child(5){border-radius:24px 50px 22px 54px}
/* gentle wave: offset alternating cards with margin so .reveal's transform is free */
.step--down{margin-top:60px}
.step--up{margin-top:0}
.step:hover{transform:translateY(-8px);background:rgba(20,30,74,.78);border-color:rgba(198,160,90,.45)}
.step__node{display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50% 46% 52% 48%;
  border:1px solid rgba(198,160,90,.5);color:var(--accent);
  font-family:var(--serif);font-style:italic;font-size:20px;background:rgba(198,160,90,.08)}
.step__no{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--accent);margin:0 0 8px}
.step h4{font-family:var(--serif);font-weight:500;font-size:1.7rem;margin:0 0 10px;color:#fff}
.step p:last-child{margin:0;color:var(--text-dim);font-size:15px}

.pricing{margin-top:34px;display:grid;grid-template-columns:1.2fr .8fr;gap:0;
  border:1px solid var(--line);border-radius:54px 20px 54px 20px;overflow:hidden}
.pricing__l{padding:clamp(34px,4vw,56px);background:var(--ink)}
.pricing__r{padding:clamp(34px,4vw,56px);background:linear-gradient(160deg,var(--ink-soft),var(--ink));
  display:flex;flex-direction:column;justify-content:center;gap:18px;border-left:1px solid var(--line)}
.pricing h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);margin:14px 0 16px;color:#fff}
.pricing p{color:var(--text-dim);max-width:48ch;margin:0 0 18px}
.pricing__modes{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.mode{flex:1;min-width:180px;border:1px solid var(--line);padding:20px}
.pricing__modes .mode:nth-child(odd){border-radius:30px 12px 28px 12px}
.pricing__modes .mode:nth-child(even){border-radius:12px 30px 12px 28px}
.mode h5{margin:0 0 6px;font-size:14px;letter-spacing:.04em;color:#fff}
.mode span{font-size:14px;color:var(--text-dim)}
.pricing__r .pdf{display:flex;align-items:center;gap:14px}
.pdf__ico{width:46px;height:46px;border-radius:50% 44% 52% 46%;border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);flex-shrink:0}

/* ============================================================
   STATS
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{padding-top:26px}
/* dashed connector threading the metrics (reuses the site flow motif) */
.flow-line{display:block;width:100%;height:54px;margin-bottom:34px;pointer-events:none;overflow:visible}
.flow-line path{fill:none;stroke:var(--accent);stroke-width:1.4;stroke-linecap:round;stroke-dasharray:2 9;opacity:.5}
.stat__n{font-family:var(--serif);font-weight:500;font-size:clamp(3rem,6vw,5rem);line-height:1;color:#fff;letter-spacing:-.02em}
.stat__n .accent{color:var(--accent)}
.stat__l{margin-top:14px;color:var(--text-dim);font-size:15px;max-width:22ch}

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.quote{max-width:1100px;margin:0 auto;text-align:center}
.quote__mark{font-family:var(--serif);font-size:7rem;line-height:.6;color:var(--accent);height:48px;display:block}
.quote blockquote{margin:0;font-family:var(--serif);font-weight:500;font-style:italic;
  font-size:clamp(1.6rem,3.6vw,3rem);line-height:1.28;color:#fff;letter-spacing:-.01em}
.quote figcaption{margin-top:40px;font-size:14px;color:var(--text-dim);letter-spacing:.02em}
.quote figcaption b{color:#fff;font-weight:600}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{position:relative;text-align:center;overflow:hidden}
.cta__inner{position:relative;z-index:2}
.cta h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,7vw,6rem);line-height:1.02;margin:0 0 36px;color:#fff;letter-spacing:-.02em}
.cta__glow{position:absolute;z-index:0;left:50%;top:50%;transform:translate(-50%,-50%);
  width:80vw;height:80vw;max-width:900px;max-height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(var(--accent-rgb),.22),transparent 60%);filter:blur(20px)}
.cta__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink-deep);border-top:1px solid var(--line-soft);padding:80px var(--pad) 40px}
.footer__top{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px;max-width:var(--maxw);margin:0 auto}
.footer__brand img{height:30px;margin-bottom:22px}
.footer__brand p{color:var(--text-dim);max-width:32ch;font-size:15px}
.footer col,.fcol{display:flex;flex-direction:column;gap:14px}
.fcol h5{margin:0 0 6px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
.fcol a{color:var(--text-dim);font-size:15px;transition:color .25s}
.fcol a:hover{color:#fff}
.footer__bottom{max-width:var(--maxw);margin:60px auto 0;padding-top:26px;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--text-faint)}
.footer__ack{max-width:60ch;margin:30px auto 0;max-width:var(--maxw);font-size:13px;color:var(--text-faint);line-height:1.6}

/* ============================================================
   VIDEO LIGHTBOX
   ============================================================ */
.vbox{position:fixed;inset:0;z-index:2200;display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,56px)}
.vbox.open{display:flex}
.vbox__backdrop{position:absolute;inset:0;background:rgba(4,7,22,.9);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fade .35s ease}
.vbox__inner{position:relative;z-index:2;width:min(1180px,100%);animation:pop .42s cubic-bezier(.2,.7,.3,1)}
.vbox__x{position:absolute;top:-44px;right:0;background:none;border:0;color:#fff;font-size:22px;cursor:pointer;
  width:40px;height:40px;border-radius:50%;transition:.25s;line-height:1}
.vbox__x:hover{background:rgba(255,255,255,.12)}
.vbox__frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:32px 14px 32px 14px;overflow:hidden;
  background:#000;box-shadow:0 40px 120px rgba(0,0,0,.6)}
.vbox__embed,.vbox__embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vbox__cap{margin:18px 2px 0;color:var(--text-dim);font-size:14px;letter-spacing:.04em;text-align:center}
@media (max-width:560px){.vbox__x{top:-40px}}

/* ============================================================
   PDF GATE MODAL
   ============================================================ */
.modal{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(4,7,22,.78);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fade .35s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal__card{position:relative;z-index:2;width:min(880px,100%);max-height:92svh;overflow:auto;
  background:var(--ink);border:1px solid var(--line);border-radius:36px 16px 36px 16px;
  box-shadow:0 40px 120px rgba(0,0,0,.6);animation:pop .4s cubic-bezier(.2,.7,.3,1)}
@keyframes pop{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.modal__x{position:absolute;top:16px;right:18px;z-index:5;background:none;border:0;color:var(--text-dim);
  font-size:18px;cursor:pointer;width:36px;height:36px;border-radius:50%;transition:.25s;line-height:1}
.modal__x:hover{color:#fff;background:rgba(255,255,255,.07)}
.modal__grid{display:grid;grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr)}
.modal__aside{position:relative;background:linear-gradient(160deg,var(--ink-soft),var(--ink-deep));
  border-right:1px solid var(--line);padding:34px;display:flex;flex-direction:column;justify-content:space-between;min-height:480px;overflow:hidden}
.modal__mono{width:120px;opacity:.12;position:absolute;top:-10px;right:-20px}
.modal__aside-foot .display{font-size:2.2rem;line-height:1.02;margin:0 0 12px;color:#fff}
.modal__aside-foot span{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint)}
.modal__body{padding:clamp(30px,4vw,48px);min-width:0}
.modal__body .eyebrow{margin-bottom:16px}
.modal__body h3{font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 14px;color:#fff;font-weight:500}
.modal__lead{color:var(--text-dim);font-size:15px;margin:0 0 26px;max-width:44ch}
.modal__form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field>span{font-size:13px;letter-spacing:.04em;color:var(--text);font-weight:500}
.field>span i{color:var(--text-faint);font-style:normal;font-weight:400}
.field input{background:var(--ink-deep);border:1px solid var(--line);border-radius:14px 8px 14px 8px;
  padding:14px 16px;color:#fff;font-family:var(--sans);font-size:15px;transition:border-color .25s,box-shadow .25s}
.field input::placeholder{color:var(--text-faint)}
.field input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.18)}
.field__err{font-size:12.5px;color:#ff8a8a;font-style:normal;display:none}
.field.invalid input{border-color:#ff6b6b}
.field.invalid .field__err{display:block}
.modal__fine{font-size:12px;color:var(--text-faint);margin:2px 0 0;line-height:1.5}
.modal__done{text-align:center;padding:30px 0}
.modal__check{width:62px;height:62px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;
  background:rgba(var(--accent-rgb),.16);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.4)}
.modal__done h3{margin-bottom:10px}
.modal__done a{color:var(--accent);border-bottom:1px solid rgba(var(--accent-rgb),.4)}
@media (max-width:680px){
  .modal__grid{grid-template-columns:1fr}
  .modal__aside{display:none}
}

/* ---- Project briefing modal extras ---- */
.brief__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field__select,.field__area{background:var(--ink-deep);border:1px solid var(--line);border-radius:14px 8px 14px 8px;
  padding:14px 16px;color:#fff;font-family:var(--sans);font-size:15px;transition:border-color .25s,box-shadow .25s;width:100%}
.field__area{resize:vertical;min-height:84px;line-height:1.5}
.field__area::placeholder{color:var(--text-faint)}
.field__select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%239aa3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.field__select option{background:var(--ink-deep);color:#fff}
.field__select:focus,.field__area:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.18)}
.brief__chips{display:flex;flex-wrap:wrap;gap:9px}
.coffee__dates{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.coffee__date{display:flex;flex-direction:column;gap:7px;min-width:0}
.coffee__date-no{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--accent)}
.coffee__date input{background:var(--ink-deep);border:1px solid var(--line);border-radius:14px 8px 14px 8px;
  padding:13px 14px;color:#fff;font-family:var(--sans);font-size:14px;width:100%;min-width:0;box-sizing:border-box;
  transition:border-color .25s,box-shadow .25s;color-scheme:dark}
.coffee__date input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.18)}
.coffee__date .field__err{display:none}
.coffee__date.invalid input{border-color:#ff6b6b}
.coffee__date.invalid .field__err{display:block}
.brief__chip{font-family:var(--sans);font-size:13.5px;color:var(--text-dim);cursor:pointer;
  background:var(--ink-deep);border:1px solid var(--line);border-radius:999px;padding:9px 16px;transition:.22s}
.brief__chip:hover{color:#fff;border-color:rgba(var(--accent-rgb),.5)}
.brief__chip[aria-pressed="true"]{color:var(--ink);background:var(--accent);border-color:var(--accent);font-weight:600}
.brief__aside-steps{position:relative;z-index:1}
.brief__steps{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.brief__steps li{display:flex;align-items:baseline;gap:12px;color:var(--text-dim);font-size:14.5px;line-height:1.35}
.brief__steps li span{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:15px;min-width:22px}
@media (max-width:680px){
  .brief__row{grid-template-columns:1fr}
  .coffee__dates{grid-template-columns:1fr}
}

/* ============================================================
   REVEAL ANIM
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.3,1),transform .9s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .footer__top{grid-template-columns:1fr 1fr}
  .pricing{grid-template-columns:1fr}
  .pricing__r{border-left:0;border-top:1px solid var(--line)}
}
@media (max-width:860px){
  body{font-size:16px}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__right .btn{display:none}
  .svc-feature{grid-template-columns:1fr}
  .approach-flow{grid-template-columns:repeat(2,1fr);row-gap:30px}
  .approach-flow__line{display:none}
  .approach-flow .step--up,.approach-flow .step--down{margin-top:0}
  .stats{grid-template-columns:repeat(2,1fr)}
  .work,.work.tall{grid-column:span 12}
  .hero[data-hero="c"] .hero__media{width:100%;opacity:.5}
  .hero[data-hero="c"] .hero__foot{width:auto;left:var(--pad)}
  .hero[data-hero="c"] .hero__title{max-width:none}
  .hero__foot{font-size:11px}
}
@media (max-width:520px){
  .approach-flow{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .statement__big{font-size:1.7rem}
  .hero__play .ring{width:64px;height:64px}
  .hero__title{font-size:13vw;overflow-wrap:break-word}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:1500;background:var(--ink-deep);
  display:flex;flex-direction:column;padding:90px var(--pad) 40px;gap:8px;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.4,0,.1,1);visibility:hidden}
.mobile-menu.open{transform:none;visibility:visible}
.mobile-menu a{font-family:var(--serif);font-size:2rem;color:var(--text);padding:14px 0;border-bottom:1px solid var(--line-soft)}
.mobile-menu .btn{margin-top:24px;align-self:flex-start}
.mm-close{position:absolute;top:22px;right:var(--pad);background:none;border:0;color:var(--text);font-size:26px;cursor:pointer}
