/* ============================================================
   COLORBLAST FILMS — cinematic black & white system
   The only color in the world is the brand's "blast".
   ============================================================ */

:root{
  /* ink + paper */
  --ink:#16181a;
  --ink-2:#1d2023;
  --paper:#f3f1ec;
  --paper-2:#e8e5dd;
  --smoke:#8a8c8d;
  --smoke-2:#5a5d5f;
  --line:rgba(243,241,236,.14);
  --line-ink:rgba(22,24,26,.12);

  /* the Colorblast brand spectrum — canonical brand sheet values */
  --clementine:#eead1a;
  --taffy:#db3e79;
  --aqua:#0ce8e6;
  --azure:#005b95;
  --grass:#3daa4b;

  --spectrum:linear-gradient(90deg,var(--clementine),var(--aqua),var(--taffy),var(--azure),var(--grass));

  --ff-display:"Archivo",-apple-system,"Helvetica Neue",sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;

  --ease:cubic-bezier(.22,1,.36,1);
  --gut:clamp(20px,4.5vw,90px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--ff-display);
  background:var(--ink);
  color:var(--paper);
  overflow-x:hidden;
  line-height:1.1;
}
body.no-scroll{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--taffy);color:#fff}

/* ---------- film grain + vignette overlays ---------- */
.grain{
  position:fixed;inset:-50%;z-index:9000;pointer-events:none;
  opacity:.05;mix-blend-mode:screen;
  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='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.1s steps(4) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}25%{transform:translate(-4%,3%)}
  50%{transform:translate(3%,-5%)}75%{transform:translate(-5%,2%)}100%{transform:translate(2%,4%)}
}
.vignette{
  position:fixed;inset:0;z-index:8999;pointer-events:none;
  box-shadow:inset 0 0 280px 40px rgba(0,0,0,.7);
}

/* ---------- type primitives ---------- */
.kicker{
  font-family:var(--ff-mono);
  font-size:clamp(10px,.78vw,12px);
  letter-spacing:.34em;text-transform:uppercase;
  color:var(--smoke);font-weight:500;
}
.display{
  font-weight:800;line-height:.92;letter-spacing:-.02em;
  text-transform:uppercase;font-stretch:expanded;
}
.huge{font-size:clamp(50px,10.5vw,172px)}
.mega{font-size:clamp(40px,8vw,150px)}
.big{font-size:clamp(34px,5.4vw,92px)}

/* reveal animation hooks */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.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}
.reveal[data-d="4"]{transition-delay:.32s}

/* line-by-line clip reveal */
.lineMask{overflow:hidden;display:block}
.lineMask > span{display:block;transform:translateY(105%);transition:transform 1.1s var(--ease)}
.lineMask.in > span{transform:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gut);
  mix-blend-mode:difference;
}
.nav__logo{height:26px;width:auto}
.nav__right{display:flex;align-items:center;gap:clamp(18px,2.4vw,40px)}
.nav__links{display:flex;gap:clamp(16px,2vw,34px)}
.nav__links a{
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;position:relative;padding:4px 0;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:#fff;
  transition:width .4s var(--ease);
}
.nav__links a:hover::after{width:100%}
.nav__cta{
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid #fff;color:#fff;padding:9px 16px;border-radius:40px;
  transition:background .35s var(--ease),color .35s var(--ease);white-space:nowrap;
}
.nav__cta:hover{background:#fff;color:#000}
.nav__menu{display:none;font-family:var(--ff-mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;background:none;border:0;cursor:pointer;padding:8px 0;text-align:right}
.nav__menu[aria-expanded="true"]{letter-spacing:.18em}
.mobile-nav{
  position:fixed;inset:0;z-index:990;opacity:0;pointer-events:none;overflow-y:auto;
  padding:calc(88px + env(safe-area-inset-top)) var(--gut) calc(28px + env(safe-area-inset-bottom));
  background:
    radial-gradient(80% 52% at 100% 0%,rgba(12,232,230,.11),transparent 58%),
    linear-gradient(180deg,rgba(22,24,26,.98),rgba(12,13,14,.99));
  transform:translateY(-12px);transition:opacity .32s var(--ease),transform .32s var(--ease);
}
.mobile-nav::before{
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.22;
  background:linear-gradient(90deg,transparent 0,transparent calc(50% - 1px),rgba(243,241,236,.08) 50%,transparent calc(50% + 1px));
}
.mobile-nav.show{opacity:1;pointer-events:auto;transform:none}
.mobile-nav__inner{
  position:relative;z-index:1;min-height:calc(100dvh - 116px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  display:flex;flex-direction:column;gap:30px;border-top:1px solid rgba(243,241,236,.18);
  padding-top:24px;
}
.mobile-nav__panel{display:grid;gap:18px}
.mobile-nav__eyebrow{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--aqua);font-weight:500;
}
.mobile-nav__links{display:flex;flex-direction:column;border-top:1px solid rgba(243,241,236,.12)}
.mobile-nav__links a{
  display:grid;grid-template-columns:42px minmax(0,1fr) 24px;align-items:center;gap:12px;
  min-height:66px;border-bottom:1px solid rgba(243,241,236,.12);color:rgba(243,241,236,.82);
  transition:color .28s var(--ease),padding .28s var(--ease),background .28s var(--ease);
}
.mobile-nav__num,.mobile-nav__mark{
  font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--smoke);font-weight:500;
}
.mobile-nav__label{
  display:block;font-weight:800;text-transform:uppercase;font-size:44px;line-height:.92;
  letter-spacing:0;overflow-wrap:anywhere;
}
.mobile-nav__mark{justify-self:end;font-size:16px;line-height:1;color:var(--accent)}
.mobile-nav__links a.cur{color:var(--paper)}
.mobile-nav__links a.cur .mobile-nav__num{color:var(--accent)}
.mobile-nav__links a.cur .mobile-nav__label{color:var(--accent)}
.mobile-nav__links a:hover,.mobile-nav__links a:focus-visible{
  color:var(--paper);background:rgba(255,255,255,.035);padding-left:8px;outline:0;
}
.mobile-nav__links a:hover .mobile-nav__label,.mobile-nav__links a:focus-visible .mobile-nav__label{color:var(--accent)}
.mobile-nav__bottom{margin-top:auto;display:grid;gap:18px;padding-top:8px}
.mobile-nav__cta{
  justify-self:start;font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink);background:var(--paper);border-radius:40px;
  padding:14px 20px;box-shadow:0 18px 42px rgba(0,0,0,.28);
}
.mobile-nav__contact{
  display:grid;border-top:1px solid rgba(243,241,236,.14);border-bottom:1px solid rgba(243,241,236,.14);
}
.mobile-nav__contact a{
  display:grid;grid-template-columns:82px minmax(0,1fr);gap:14px;padding:13px 0;
  border-bottom:1px solid rgba(243,241,236,.1);align-items:center;
}
.mobile-nav__contact a:last-child{border-bottom:0}
.mobile-nav__contact span,.mobile-nav__note{
  font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke);
}
.mobile-nav__contact b{font-size:15px;line-height:1.2;color:var(--paper);font-weight:600;text-align:right;overflow-wrap:anywhere}
.mobile-nav__note{color:var(--smoke-2)}
body.mobile-menu-open{overflow:hidden}
body.mobile-menu-open .nav{mix-blend-mode:normal}
@media(max-width:860px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__menu{display:block}
}
@media(min-width:861px){.mobile-nav{display:none}}
@media(max-width:390px){
  .mobile-nav__label{font-size:38px}
  .mobile-nav__links a{min-height:60px;grid-template-columns:36px minmax(0,1fr) 20px}
  .mobile-nav__contact a{grid-template-columns:70px minmax(0,1fr)}
  .mobile-nav__contact b{font-size:14px}
}
@media(max-height:720px){
  .mobile-nav{padding-top:calc(78px + env(safe-area-inset-top))}
  .mobile-nav__inner{gap:22px;padding-top:18px}
  .mobile-nav__panel{gap:14px}
  .mobile-nav__links a{min-height:54px}
  .mobile-nav__label{font-size:34px}
  .mobile-nav__bottom{gap:14px}
  .mobile-nav__contact a{padding:10px 0}
}

/* ============================================================
   HERO (3 directions, toggled by body[data-hero])
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:space-between;gap:clamp(32px,6vh,64px);padding:clamp(118px,17vh,176px) var(--gut) clamp(40px,6vh,72px);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__media{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 70% 10%,rgba(255,255,255,.06),transparent 55%),
    repeating-linear-gradient(115deg,#1c1f22 0 2px,#16181a 2px 9px);
  filter:contrast(1.05);
}
.hero__video{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.08) brightness(.78)}
.hero__media::after{
  content:"";
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.3em;color:rgba(255,255,255,.13);
}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.1) 35%,rgba(0,0,0,.85))}
.hero__inner{position:relative;z-index:2;width:100%}
.hero__top{
  position:relative;z-index:2;width:100%;
  display:flex;justify-content:space-between;align-items:flex-start;gap:24px 40px;flex-wrap:wrap;
}
.hero__meta{max-width:330px}
.hero__meta p{font-family:var(--ff-mono);font-size:clamp(12px,.95vw,14px);
  line-height:1.6;color:var(--smoke);letter-spacing:.02em}
.hero__meta p b{color:var(--paper);font-weight:500}
.hero__loc{font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--smoke);text-align:right;line-height:2}

.hero__title{margin-bottom:clamp(18px,3vh,34px)}
.hero__title .line{display:block}
.hero__title em{font-style:normal;position:relative}
.hero__title .blast{
  -webkit-text-fill-color:transparent;background:var(--spectrum);
  -webkit-background-clip:text;background-clip:text;
}
.hero__foot{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.hero__lede{max-width:440px;font-size:clamp(16px,1.5vw,21px);line-height:1.45;
  font-weight:500;color:var(--paper);letter-spacing:-.01em}
.hero__lede b{color:#fff}
.scrollcue{display:flex;align-items:center;gap:12px;font-family:var(--ff-mono);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--smoke)}
.scrollcue .dot{width:7px;height:7px;border-radius:50%;background:var(--paper);animation:pulse 1.8s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}

/* hero variant B — centered stack, big mark */
body[data-hero="B"] .hero{justify-content:center;text-align:center;align-items:center}
body[data-hero="B"] .hero__top{position:static;margin-bottom:auto}
body[data-hero="B"] .hero__mark{width:clamp(64px,7vw,108px);margin:0 auto clamp(20px,3vh,40px);opacity:.95}
body[data-hero="B"] .hero__foot{justify-content:center;flex-direction:column;align-items:center;margin-top:clamp(24px,4vh,48px)}
body[data-hero="B"] .hero__lede{text-align:center}
body[data-hero="B"] .hero__media{background:
  radial-gradient(60% 60% at 50% 45%,rgba(255,255,255,.08),transparent 60%),
  repeating-linear-gradient(90deg,#1b1e21 0 2px,#16181a 2px 11px)}
.hero__mark{display:none}
body[data-hero="B"] .hero__mark{display:block}

/* hero variant C — split / index style */
body[data-hero="C"] .hero{justify-content:center}
body[data-hero="C"] .hero__index{
  position:absolute;top:0;right:var(--gut);bottom:0;display:flex;align-items:center;
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.2em;color:var(--smoke);
  writing-mode:vertical-rl;text-transform:uppercase;gap:20px;
}
.hero__index{display:none}
body[data-hero="C"] .hero__index{display:flex}
body[data-hero="C"] .hero__media{background:
  linear-gradient(90deg,#16181a 0 50%,#1b1e21 50% 100%),
  repeating-linear-gradient(0deg,rgba(255,255,255,.02) 0 1px,transparent 1px 60px)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:18px 0;background:var(--ink-2)}
.marquee__track{display:flex;gap:48px;width:max-content;animation:slide 34s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(20px,2.4vw,34px);letter-spacing:.01em;color:var(--smoke-2);
  display:flex;align-items:center;gap:48px;white-space:nowrap}
.marquee__track span::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--spectrum);
  background-size:300% 100%}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{position:relative}
.sec{padding:clamp(80px,12vh,170px) var(--gut)}
.sec--paper{background:var(--paper);color:var(--ink)}
.sec__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;
  flex-wrap:wrap;margin-bottom:clamp(40px,6vh,80px)}
.sec__head .idx{font-family:var(--ff-mono);font-size:12px;letter-spacing:.2em;color:var(--smoke)}
.sec__title{max-width:14ch}

/* ============================================================
   WORK
   ============================================================ */
.work{padding-top:clamp(70px,10vh,140px)}
.work__filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.chip{font-family:var(--ff-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--smoke);border:1px solid var(--line);border-radius:40px;padding:8px 15px;cursor:pointer;
  background:none;transition:.3s var(--ease)}
.chip:hover{color:var(--paper);border-color:var(--paper)}
.chip.active{background:var(--paper);color:var(--ink);border-color:var(--paper)}

.grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:clamp(10px,1vw,16px)}
.tile{position:relative;overflow:hidden;cursor:pointer;background:var(--ink-2);
  grid-column:span 4;aspect-ratio:16/9;display:block;color:var(--paper);text-align:left}
.tile.w6,.tile.w8,.tile.w12,.tile.tall{grid-column:span 4;aspect-ratio:16/9}
@media(max-width:980px){.tile,.tile.w6,.tile.w8,.tile.w12,.tile.tall{grid-column:span 6 !important}}
@media(max-width:600px){.tile{grid-column:span 12 !important}}

.tile__img{position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,#1d2023 0 2px,#16181a 2px 10px);
  filter:grayscale(1) contrast(1.05);transition:transform 1.1s var(--ease),filter .6s var(--ease)}
.tile__poster{width:100%;height:100%;object-fit:cover;display:block}
.tile:hover .tile__img{transform:scale(1.06)}
.tile__num{position:absolute;top:14px;left:16px;z-index:3;font-family:var(--ff-mono);
  font-size:11px;letter-spacing:.15em;color:rgba(255,255,255,.55)}
.tile__blast{position:absolute;inset:0;z-index:2;opacity:0;mix-blend-mode:normal;
  transition:opacity .5s var(--ease)}
.tile:hover .tile__blast{opacity:.58}
.tile__play{position:absolute;top:50%;left:50%;z-index:4;width:58px;height:58px;border:1px solid rgba(255,255,255,.72);
  border-radius:50%;display:grid;place-items:center;background:rgba(0,0,0,.28);backdrop-filter:blur(8px);
  transform:translate(-50%,-50%) scale(.86);opacity:0;transition:.45s var(--ease)}
.tile__play span{display:block;width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;
  border-left:14px solid var(--paper);margin-left:4px}
.tile:hover .tile__play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.tile__cap{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:16px 18px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:12px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82));
  transform:translateY(12px);opacity:0;transition:.5s var(--ease)}
.tile:hover .tile__cap{transform:none;opacity:1}
.tile__name{font-weight:800;text-transform:uppercase;font-size:clamp(15px,1.5vw,22px);letter-spacing:0;line-height:1.02;
  max-width:32ch;overflow-wrap:anywhere}
.tile__tag{font-family:var(--ff-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke);white-space:nowrap}
.tile__ph{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;
  font-family:var(--ff-mono);font-size:10px;letter-spacing:.25em;color:rgba(255,255,255,.1);text-transform:uppercase}

.work__more{display:flex;justify-content:center;margin-top:48px}
.btn-line{font-family:var(--ff-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:40px;padding:14px 26px;cursor:pointer;background:none;color:var(--paper);
  transition:.35s var(--ease)}
.btn-line:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

body.modal-open{overflow:hidden}
.video-modal{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:clamp(18px,4vw,54px);
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.video-modal.show{opacity:1;pointer-events:auto}
.video-modal__shade{position:absolute;inset:0;background:rgba(0,0,0,.86);backdrop-filter:blur(10px)}
.video-modal__dialog{position:relative;z-index:1;width:min(1120px,100%);color:var(--paper)}
.video-modal__frame{aspect-ratio:16/9;background:#050505;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.video-modal__frame iframe{width:100%;height:100%;display:block}
.video-modal__close{position:absolute;right:0;top:-52px;font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--paper);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);
  border-radius:40px;padding:11px 17px;cursor:pointer;transition:.3s var(--ease)}
.video-modal__close:hover{background:var(--paper);color:var(--ink)}
.video-modal__meta{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-top:18px}
.video-modal__eyebrow{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke)}
.video-modal__title{font-weight:800;text-transform:uppercase;font-size:clamp(24px,4vw,58px);letter-spacing:0;line-height:.96;
  margin-top:8px;max-width:18ch;overflow-wrap:anywhere}
.video-modal__link{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);
  border-bottom:1px solid rgba(255,255,255,.45);padding-bottom:4px;white-space:nowrap}
@media(max-width:680px){
  .tile__play{opacity:1;transform:translate(-50%,-50%) scale(.9)}
  .tile__cap{opacity:1;transform:none}
  .video-modal{align-items:start;padding-top:80px}
  .video-modal__close{top:-46px}
  .video-modal__meta{display:block}
  .video-modal__link{display:inline-block;margin-top:16px}
}

/* ============================================================
   SERVICES
   ============================================================ */
.svc{border-top:1px solid var(--line-ink)}
.svc__row{display:grid;grid-template-columns:90px 1fr auto;gap:24px;align-items:center;
  padding:clamp(26px,4vh,46px) 0;border-bottom:1px solid var(--line-ink);cursor:default;
  transition:padding .4s var(--ease)}
.svc__row:hover{padding-left:18px}
.svc__n{font-family:var(--ff-mono);font-size:13px;color:var(--smoke-2)}
.svc__name{font-weight:800;text-transform:uppercase;font-size:clamp(26px,4vw,64px);
  letter-spacing:-.02em;line-height:.95;transition:color .35s var(--ease)}
.svc__row:hover .svc__name{color:var(--smoke-2)}
.svc__desc{max-width:34ch;font-size:clamp(13px,1vw,15px);line-height:1.5;color:var(--smoke-2);
  justify-self:end;text-align:right}
@media(max-width:760px){.svc__row{grid-template-columns:50px 1fr}.svc__desc{display:none}}

/* ============================================================
   ABOUT
   ============================================================ */
.about__lead{font-weight:700;font-size:clamp(26px,3.6vw,58px);line-height:1.04;letter-spacing:-.02em;
  max-width:18ch}
.about__lead .blast{-webkit-text-fill-color:transparent;background:var(--spectrum);
  -webkit-background-clip:text;background-clip:text}
.about__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(30px,6vw,90px);margin-top:clamp(40px,6vh,80px);align-items:start}
.about__copy p{font-size:clamp(15px,1.15vw,18px);line-height:1.6;color:var(--smoke-2);margin-bottom:18px;max-width:46ch}
.about__stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-ink);border:1px solid var(--line-ink)}
.stat{background:var(--paper);color:var(--ink);padding:clamp(20px,3vw,34px)}
.stat .n{font-weight:800;font-size:clamp(34px,4.5vw,66px);letter-spacing:-.03em;line-height:1}
.stat .l{font-family:var(--ff-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--smoke-2);margin-top:10px}
@media(max-width:760px){.about__grid{grid-template-columns:1fr}}

/* ============================================================
   PROCESS
   ============================================================ */
.proc__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.proc__cell{background:var(--ink);padding:clamp(24px,3vw,40px);min-height:clamp(220px,30vh,320px);
  display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;transition:background .4s var(--ease)}
.proc__cell:hover{background:var(--ink-2)}
.proc__cell .pn{font-family:var(--ff-mono);font-size:12px;letter-spacing:.2em;color:var(--smoke)}
.proc__cell h3{font-weight:800;text-transform:uppercase;font-size:clamp(20px,1.9vw,30px);letter-spacing:-.01em;line-height:1}
.proc__cell p{font-size:13px;line-height:1.5;color:var(--smoke);margin-top:12px}
.proc__cell .bar{position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--spectrum);transition:width .6s var(--ease)}
.proc__cell:hover .bar{width:100%}
@media(max-width:980px){.proc__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.proc__grid{grid-template-columns:1fr}}

/* ============================================================
   CLIENTS
   ============================================================ */
.clients__grid{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line-ink);border-left:1px solid var(--line-ink)}
.client{border-right:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);
  aspect-ratio:2/1;display:flex;align-items:center;justify-content:center;padding:20px;
  color:rgba(22,24,26,.45);transition:color .35s var(--ease),background .35s var(--ease)}
.client:hover{color:var(--ink);background:var(--paper-2)}
.client__logo{height:48px;min-width:120px;display:flex;align-items:center;justify-content:center;gap:10px;
  filter:grayscale(1);opacity:.82;transition:opacity .35s var(--ease),transform .35s var(--ease)}
.client:hover .client__logo{opacity:1;transform:translateY(-2px)}
.logo-word{font-family:var(--ff-display);font-weight:800;line-height:1;white-space:nowrap;color:currentColor}
.logo-word--nestle{font-size:clamp(24px,2.3vw,36px);letter-spacing:-.05em;text-transform:uppercase}
.logo-word--netmeds{font-size:clamp(22px,2vw,32px);letter-spacing:-.04em;text-transform:lowercase}
.logo-plus{font-family:var(--ff-mono);font-size:28px;font-weight:700;line-height:1;color:currentColor}
.logo-word--nescafe{font-size:clamp(24px,2.2vw,35px);letter-spacing:-.03em;text-transform:uppercase;position:relative}
.logo-word--nescafe::before{content:"";position:absolute;left:.08em;right:.08em;top:-9px;height:2px;background:currentColor;transform:skewX(-24deg)}
.logo-circles{position:relative;width:52px;height:32px;display:inline-block;flex:0 0 auto}
.logo-circles i{position:absolute;top:0;width:32px;height:32px;border:3px solid currentColor;border-radius:50%}
.logo-circles i:first-child{left:0}.logo-circles i:last-child{right:0}
.logo-word--mastercard{font-size:clamp(16px,1.45vw,22px);letter-spacing:-.04em;text-transform:lowercase}
.logo-word--huggies{font-size:clamp(24px,2.2vw,34px);font-weight:900;letter-spacing:.01em}
.logo-word--mckinsey{font-family:Georgia,"Times New Roman",serif;font-size:clamp(22px,2vw,32px);font-weight:700;letter-spacing:-.04em}
.logo-word--cadbury{font-family:"Snell Roundhand","Brush Script MT",cursive;font-size:clamp(34px,3.2vw,52px);font-weight:600;letter-spacing:-.06em;text-transform:none}
.logo-word--britannia{font-size:clamp(20px,1.8vw,28px);letter-spacing:.08em;text-transform:uppercase;border:2px solid currentColor;border-radius:999px;padding:8px 16px}
.logo-bus{position:relative;width:46px;height:24px;border:3px solid currentColor;border-radius:12px 12px 6px 6px;display:inline-block;flex:0 0 auto}
.logo-bus i{position:absolute;bottom:-8px;width:8px;height:8px;border-radius:50%;background:currentColor}
.logo-bus i:first-child{left:9px}.logo-bus i:last-child{right:9px}
.logo-word--magicbus{font-size:clamp(19px,1.8vw,28px);letter-spacing:-.04em}
.logo-dotgrid{display:grid;grid-template-columns:repeat(2,8px);gap:5px;flex:0 0 auto}
.logo-dotgrid i{width:8px;height:8px;border-radius:50%;background:currentColor}
.logo-word--dasra{font-size:clamp(24px,2.1vw,34px);letter-spacing:.08em;text-transform:uppercase}
@media(max-width:760px){.clients__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.client{aspect-ratio:1.55/1;padding:14px}.client__logo{min-width:0;transform:scale(.86)}.client:hover .client__logo{transform:scale(.86)}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.quote{background:var(--ink);padding:clamp(28px,4vw,56px);display:flex;flex-direction:column;justify-content:space-between;gap:30px}
.quote blockquote{font-weight:600;font-size:clamp(19px,1.9vw,30px);line-height:1.28;letter-spacing:-.01em}
.quote blockquote .mk{background:var(--spectrum);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.quote__by{display:flex;align-items:center;gap:14px}
.quote__av{width:40px;height:40px;border-radius:50%;background:repeating-linear-gradient(135deg,#23262a 0 2px,#16181a 2px 8px);flex:0 0 auto}
.quote__by .nm{font-weight:700;font-size:14px}
.quote__by .rl{font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;color:var(--smoke);margin-top:3px}
@media(max-width:760px){.quotes{grid-template-columns:1fr}}

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.cta{background:var(--paper);color:var(--ink);padding:clamp(90px,16vh,200px) var(--gut);text-align:center;position:relative;overflow:hidden}
.cta .kicker{color:var(--smoke-2)}
.cta__title{font-weight:800;text-transform:uppercase;line-height:.9;letter-spacing:-.03em;
  font-size:clamp(48px,11vw,200px);margin:18px 0 30px}
.cta__title .blast{-webkit-text-fill-color:transparent;background:var(--spectrum);-webkit-background-clip:text;background-clip:text}
.cta__btn{display:inline-flex;align-items:center;gap:14px;background:var(--ink);color:var(--paper);
  font-family:var(--ff-mono);font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  padding:20px 34px;border-radius:50px;transition:.4s var(--ease)}
.cta__btn:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.25)}
.cta__sub{margin-top:22px;font-family:var(--ff-mono);font-size:13px;color:var(--smoke-2);letter-spacing:.04em}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--ink);padding:clamp(60px,9vh,110px) var(--gut) 40px}
.foot__top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.foot__brand img{height:30px;margin-bottom:22px}
.foot__brand p{font-family:var(--ff-mono);font-size:13px;line-height:1.7;color:var(--smoke);max-width:30ch}
.foot__col h4{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke-2);margin-bottom:18px}
.foot__col a{display:block;font-size:15px;color:var(--paper);padding:6px 0;transition:color .3s var(--ease)}
.foot__col a:hover{color:var(--smoke)}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:30px;flex-wrap:wrap}
.foot__bottom span{font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;color:var(--smoke-2)}
.foot__legal{display:flex;gap:18px}
.foot__legal a{color:inherit;opacity:.72;transition:opacity .25s var(--ease)}
.foot__legal a:hover{opacity:1}
.foot__spectrum{height:3px;width:100%;background:var(--spectrum);margin-top:30px;border-radius:3px}
@media(max-width:760px){.foot__top{grid-template-columns:1fr 1fr}.foot__brand{grid-column:1/-1}}

/* ============================================================
   MULTI-PAGE: transition wipe, page headers, featured, contact
   ============================================================ */
/* page wipe overlay */
.pagewipe{position:fixed;inset:0;z-index:9500;background:var(--ink);transform:translateY(100%);
  pointer-events:none;display:flex;align-items:center;justify-content:center}
.pagewipe img{width:clamp(54px,7vw,92px);opacity:0;transition:opacity .3s var(--ease)}
.pagewipe.show{transform:translateY(0);transition:transform .55s var(--ease)}
.pagewipe.show img{opacity:1}
.pagewipe.hide{transform:translateY(-100%);transition:transform .55s var(--ease)}
/* entry reveal */
.pagewipe.intro{transform:translateY(0)}
.pagewipe.intro img{opacity:1}
.pagewipe.intro.lift{transform:translateY(-100%);transition:transform .7s var(--ease)}

/* nav active state */
.nav__links a.cur::after{width:100%}

/* INNER PAGE HEADER */
.phead{position:relative;padding:clamp(124px,18vh,190px) var(--gut) clamp(50px,8vh,90px);
  border-bottom:1px solid var(--line);overflow:hidden}
.phead__crumb{position:relative;z-index:1;font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke);margin-bottom:24px;display:flex;gap:10px;align-items:center}
.phead__crumb a{color:var(--smoke)}
.phead__crumb a:hover{color:var(--paper)}
.phead__title{position:relative;z-index:1;font-weight:800;text-transform:uppercase;line-height:.88;letter-spacing:-.03em;
  font-size:clamp(54px,11vw,168px)}
.phead__title .blast{-webkit-text-fill-color:transparent;background:var(--spectrum);-webkit-background-clip:text;background-clip:text}
.phead__lede{position:relative;z-index:1;margin-top:30px;max-width:54ch;font-size:clamp(16px,1.5vw,21px);line-height:1.5;color:var(--smoke-2);font-weight:500}
.phead__mark{position:absolute;right:var(--gut);bottom:clamp(36px,7vh,72px);width:clamp(58px,6vw,104px);opacity:.32;pointer-events:none;z-index:0}
@media(max-width:1024px){.phead__mark{display:none}}

/* FEATURED WORK (home) */
.feat__foot{display:flex;justify-content:center;margin-top:54px}

/* HOME services teaser */
.home-svc{background:var(--paper);color:var(--ink)}

/* CONTACT PAGE */
.contact{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,7vw,110px);padding:clamp(70px,10vh,130px) var(--gut)}
@media(max-width:860px){.contact{grid-template-columns:1fr;gap:50px}}
.contact__big{font-weight:800;text-transform:uppercase;font-size:clamp(34px,5vw,80px);line-height:.92;letter-spacing:-.02em;margin-bottom:34px}
.contact__big .blast{-webkit-text-fill-color:transparent;background:var(--spectrum);-webkit-background-clip:text;background-clip:text}
.contact__row{display:flex;flex-direction:column;gap:4px;padding:22px 0;border-top:1px solid var(--line)}
.contact__row .k{font-family:var(--ff-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke)}
.contact__row a,.contact__row span{font-weight:600;font-size:clamp(18px,1.8vw,26px);letter-spacing:-.01em}
.contact__row a:hover{color:var(--smoke)}
.form{display:flex;flex-direction:column;gap:18px}
.form label{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--smoke);margin-bottom:8px;display:block}
.form input,.form textarea,.form select{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  color:var(--paper);font-family:var(--ff-display);font-size:18px;padding:12px 0;outline:none;transition:border-color .3s var(--ease)}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--paper)}
.form textarea{resize:vertical;min-height:90px}
.form select option{background:var(--ink)}
.form__submit{margin-top:14px;align-self:flex-start;background:var(--paper);color:var(--ink);
  font-family:var(--ff-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:0;border-radius:50px;
  padding:16px 30px;cursor:pointer;transition:.35s var(--ease)}
.form__submit:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(0,0,0,.4)}
.form__ok{font-family:var(--ff-mono);font-size:13px;color:var(--grass);margin-top:6px;display:none}
.form__ok.show{display:block}

/* services detail page */
.svc-detail{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc-card{background:var(--ink);padding:clamp(30px,4vw,56px);display:flex;flex-direction:column;gap:18px;min-height:clamp(260px,34vh,360px);position:relative;overflow:hidden}
.svc-card .sn{font-family:var(--ff-mono);font-size:12px;letter-spacing:.2em;color:var(--smoke)}
.svc-card h3{font-weight:800;text-transform:uppercase;font-size:clamp(26px,3vw,46px);letter-spacing:-.02em;line-height:.95;margin-top:auto}
.svc-card p{font-size:15px;line-height:1.6;color:var(--smoke-2);max-width:42ch}
.svc-card .tags{display:flex;gap:8px;flex-wrap:wrap}
.svc-card .tags span{font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--smoke);border:1px solid var(--line);border-radius:30px;padding:6px 11px}
.svc-card .bar{position:absolute;left:0;top:0;width:3px;height:0;background:var(--spectrum);transition:height .6s var(--ease)}
.svc-card:hover .bar{height:100%}
@media(max-width:760px){.svc-detail{grid-template-columns:1fr}}

/* ============================================================
   TWEAK MODES — expressive, reshape the whole feel
   ============================================================ */
/* COLOR BLAST: how much of the brand spectrum shows */
body[data-blast="mono"]{--spectrum:linear-gradient(90deg,#9a9c9d,#c9c7c1)}
body[data-blast="mono"] .tile__blast{display:none}
body[data-blast="mono"] .hero__mark,
body[data-blast="mono"] .quote__av{filter:grayscale(1) brightness(1.2)}
body[data-blast="mono"] .foot__spectrum,
body[data-blast="mono"] .marquee__track span::after{filter:grayscale(1)}

body[data-blast="always"] .tile__blast{opacity:.28}
body[data-blast="always"] .tile:hover .tile__blast{opacity:.58}
body[data-blast="always"] .marquee__track span::after{background-size:100% 100%}

/* FILM GRADE: the cinematic mood */
body[data-grade="noir"]{--ink:#0b0c0d;--ink-2:#131517}
body[data-grade="noir"] .grain{opacity:.095}
body[data-grade="noir"] .vignette{box-shadow:inset 0 0 320px 70px rgba(0,0,0,.88)}
body[data-grade="noir"] .hero__media,body[data-grade="noir"] .tile__img{filter:grayscale(1) contrast(1.22)}

body[data-grade="faded"]{--ink:#1f2123;--ink-2:#282a2d;--paper:#ece9e2}
body[data-grade="faded"] .grain{opacity:.028}
body[data-grade="faded"] .vignette{box-shadow:inset 0 0 200px 6px rgba(0,0,0,.34)}
body[data-grade="faded"] .hero__media{filter:contrast(.9) brightness(1.12)}
body[data-grade="faded"] .tile__img{filter:grayscale(1) contrast(.92) brightness(1.1)}

/* ============================================================
   LAYOUT HYGIENE — alignment & overflow guards
   ============================================================ */
.hero__meta,.hero__lede{min-width:0}
@media(max-width:600px){
  .hero__loc{text-align:left}
  .hero__foot{gap:18px}
}
/* keep the page-wipe mark from overflowing on short viewports */
.pagewipe img{max-height:60vh}
