/* =========================================================
   OFF-SCRIPT MEDIA // GLOBAL STYLES
   Film-slate aesthetic. Brandbook 2026.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,700&family=Courier+Prime:wght@400;700&display=swap');

:root{
  --reel-black:#151515;
  --panel:#1b1b1b;
  --panel-2:#202020;
  --film-cream:#EDE5CE;
  --cut-red:#B5271F;
  --amber:#D4872A;
  --concrete:#6F6F6F;

  /* readable text tiers (no muddy low-contrast body) */
  --text:#EDE5CE;
  --text-2:rgba(237,229,206,.82);
  --text-3:rgba(237,229,206,.62);
  --hairline:rgba(237,229,206,.16);
  --hairline-soft:rgba(237,229,206,.09);

  --display:'Bebas Neue','Helvetica Neue',Arial,sans-serif;
  --body:'DM Sans','Helvetica Neue',Arial,sans-serif;
  --mono:'Courier Prime','Courier New',monospace;
  --logo:'Helvetica Neue',Arial,sans-serif;

  --pad:clamp(20px,5vw,84px);
  --maxw:1320px;
  --ease:cubic-bezier(.7,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--reel-black);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--cut-red);color:var(--film-cream)}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
button{font-family:inherit}

/* ---------- OVERLAYS ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  background-image:url('../img/grain.png');
  background-size:340px;
  mix-blend-mode:screen;opacity:.28;
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{background-position:0 0}20%{background-position:-60px 30px}
  40%{background-position:40px -50px}60%{background-position:-30px 20px}
  80%{background-position:50px 40px}100%{background-position:-20px -30px}
}
.vignette{position:fixed;inset:0;z-index:8000;pointer-events:none;
  background:radial-gradient(130% 120% at 50% 35%,transparent 58%,rgba(0,0,0,.5))}

/* scrub progress bar (timeline) */
.scrub{position:fixed;top:0;left:0;height:2px;width:0;background:var(--cut-red);z-index:9500;transition:width .1s linear}

/* timecode HUD */
.hud{position:fixed;bottom:16px;right:var(--pad);z-index:7000;pointer-events:none;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--concrete);
  display:flex;align-items:center;gap:8px}
.hud .rec{width:7px;height:7px;border-radius:50%;background:var(--cut-red);animation:blink 1.1s steps(2) infinite}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:.15}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  padding:15px 26px;border:1px solid var(--film-cream);color:var(--film-cream);
  background:transparent;cursor:pointer;position:relative;overflow:hidden;z-index:0;
  transition:color .35s var(--ease),border-color .35s var(--ease);white-space:nowrap;
}
.btn::after{content:"";position:absolute;inset:0;background:var(--cut-red);transform:translateY(101%);transition:transform .4s var(--ease);z-index:-1}
.btn:hover{border-color:var(--cut-red)}
.btn:hover::after{transform:translateY(0)}
.btn.solid{background:var(--cut-red);border-color:var(--cut-red)}
.btn.solid::after{background:var(--film-cream)}
.btn.solid:hover{color:var(--reel-black)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn:focus-visible{outline:2px solid var(--amber);outline-offset:3px}

/* ---------- HEADER ---------- */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:6000;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
  transition:transform .45s var(--ease),background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{background:rgba(21,21,21,.85);backdrop-filter:blur(12px);padding:13px var(--pad);border-bottom:1px solid var(--hairline)}
.site-head.hide{transform:translateY(-110%)}
.brand{display:flex;align-items:center;gap:12px;z-index:6100}
.brand img{height:52px;width:auto;display:block}
nav.nav-main{display:flex;align-items:center;gap:36px}
nav.nav-main a{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);transition:color .25s;position:relative;padding:4px 0}
nav.nav-main a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--cut-red);transition:width .3s var(--ease)}
nav.nav-main a:hover,nav.nav-main a.active{color:var(--film-cream)}
nav.nav-main a.active::after,nav.nav-main a:hover::after{width:100%}
.head-cta{display:flex;align-items:center;gap:18px}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;width:30px;height:24px;justify-content:center;background:none;border:0;cursor:pointer;z-index:6100}
.burger span{height:2px;width:100%;background:var(--film-cream);transition:transform .35s var(--ease),opacity .25s}
.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile overlay */
.mobile-nav{position:fixed;inset:0;z-index:6050;background:var(--reel-black);
  display:flex;flex-direction:column;justify-content:center;padding:var(--pad);
  transform:translateY(-100%);transition:transform .5s var(--ease);visibility:hidden}
.menu-open .mobile-nav{transform:translateY(0);visibility:visible}
.mobile-nav a{font-family:var(--display);font-size:clamp(40px,11vw,72px);line-height:1.04;letter-spacing:.02em;text-transform:uppercase;color:var(--film-cream);padding:6px 0;transition:color .25s,padding-left .35s var(--ease)}
.mobile-nav a:hover{color:var(--amber);padding-left:14px}
.mobile-nav .m-index{font-family:var(--mono);font-size:12px;color:var(--cut-red);margin-right:14px}
.mobile-nav .m-foot{margin-top:48px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--concrete);line-height:2}

/* ---------- LAYOUT ---------- */
main{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative}
.section{padding:clamp(72px,10vw,150px) 0}
.eyebrow{font-family:var(--mono);font-size:13.5px;letter-spacing:.22em;text-transform:uppercase;color:#949494;display:flex;align-items:center;gap:13px;margin-bottom:28px}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--cut-red)}
.eyebrow .ix{color:var(--cut-red)}

h1,h2,h3{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:.012em;line-height:.92}
.h-hero{font-size:clamp(50px,8.4vw,150px);line-height:.84}
.h1{font-size:clamp(44px,7vw,116px)}
.h2{font-size:clamp(34px,4.6vw,76px)}
.red{color:var(--cut-red)}
.lead{font-size:clamp(17px,1.55vw,21px);color:var(--text-2);max-width:54ch;line-height:1.55}
p{color:var(--text-2)}
.muted{color:var(--text-3)}

/* film perforation divider */
.perf{height:26px;background:var(--reel-black);position:relative;overflow:hidden;border-top:1px solid var(--hairline-soft);border-bottom:1px solid var(--hairline-soft)}
.perf::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent 0 18px,rgba(237,229,206,.14) 18px 30px);background-size:30px 100%;opacity:.5}

/* ---------- HERO (generic) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-top:clamp(104px,14vh,150px);padding-bottom:clamp(56px,9vh,110px)}
.hero .bg{position:absolute;inset:0;z-index:-3;background-size:cover;background-position:center;filter:grayscale(.2) contrast(1.05)}
.hero .scrim{position:absolute;inset:0;z-index:-2;background:linear-gradient(95deg,rgba(21,21,21,.94) 12%,rgba(21,21,21,.6) 52%,rgba(21,21,21,.4) 100%)}
.hero .scrim-b{position:absolute;inset:0;z-index:-2;background:linear-gradient(0deg,var(--reel-black) 2%,transparent 38%)}
.hero::before,.hero::after{content:"";position:absolute;left:0;right:0;height:38px;background:var(--reel-black);z-index:1;opacity:.92}
.hero::before{top:0}.hero::after{bottom:0}
.hero .wrap{position:relative;z-index:2;width:100%}
.slate{font-family:var(--mono);font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--text-3);margin-bottom:24px;display:flex;flex-wrap:wrap;gap:5px 13px;align-items:center}
.slate .d{color:var(--cut-red)}
.hero .lead{margin:26px 0 34px}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

/* page hero (shorter, for sub-pages) */
.phero{position:relative;padding:calc(clamp(110px,16vh,180px)) 0 clamp(40px,7vw,80px);overflow:hidden}
.phero .bg{position:absolute;inset:0;z-index:-3;background-size:cover;background-position:center;filter:grayscale(.25) contrast(1.05) brightness(.7)}
.phero .scrim{position:absolute;inset:0;z-index:-2;background:linear-gradient(0deg,var(--reel-black),rgba(21,21,21,.55))}
.phero .wrap{position:relative;z-index:2}

/* ---------- RHYTHM MARQUEE ---------- */
.rhythm{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);background:var(--panel);overflow:hidden;padding:14px 0}
.rhythm .track{display:flex;width:max-content;white-space:nowrap;animation:marq 34s linear infinite}
.rhythm span{font-family:var(--mono);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--text-3);padding:0 24px;position:relative}
.rhythm span.beat{color:var(--cut-red);font-weight:700}
.rhythm span::after{content:"·";position:absolute;right:-3px;color:var(--hairline)}
@keyframes marq{to{transform:translateX(-50%)}}
.rhythm:hover .track{animation-play-state:paused}

/* ---------- REEL / VIDEO ---------- */
.reel{background:var(--reel-black)}
.video-frame{position:relative;border:1px solid var(--hairline);background:#000;aspect-ratio:16/9;overflow:hidden;cursor:pointer}
.video-frame.sprocket{margin:0 22px}
.video-frame.sprocket::before,.video-frame.sprocket::after{content:"";position:absolute;top:0;bottom:0;width:14px;z-index:4;background-image:repeating-linear-gradient(0deg,transparent 0 10px,rgba(237,229,206,.18) 10px 20px);background-size:100% 20px}
.video-frame.sprocket::before{left:-22px}.video-frame.sprocket::after{right:-22px}
.video-frame .poster{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .9s var(--ease),filter .5s;filter:grayscale(.3) brightness(.7)}
.video-frame img.poster{width:100%;height:100%;object-fit:cover}
.video-frame:hover .poster{transform:scale(1.04);filter:grayscale(0) brightness(.85)}
.video-frame .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;width:84px;height:84px;border-radius:50%;border:1.5px solid var(--film-cream);display:grid;place-items:center;transition:background .35s,transform .35s,border-color .35s;background:rgba(21,21,21,.25);backdrop-filter:blur(2px)}
.video-frame .play::after{content:"";margin-left:6px;border-left:20px solid var(--film-cream);border-top:13px solid transparent;border-bottom:13px solid transparent;transition:border-left-color .35s}
.video-frame:hover .play{background:var(--cut-red);border-color:var(--cut-red);transform:translate(-50%,-50%) scale(1.07)}
.video-frame .tclabel{position:absolute;left:16px;bottom:14px;z-index:5;font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--film-cream);text-transform:uppercase}
.video-frame .rec{position:absolute;top:16px;right:16px;z-index:5;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--film-cream);display:flex;align-items:center;gap:7px}
.video-frame .rec b{width:7px;height:7px;border-radius:50%;background:var(--cut-red);animation:blink 1.1s steps(2) infinite}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:6}

/* ---------- STATEMENT ---------- */
.statement .h1{max-width:17ch}
.statement p{margin-top:32px;max-width:50ch;font-size:clamp(17px,1.4vw,20px)}

/* ---------- SERVICES ---------- */
.svc-list{border-top:1px solid var(--hairline)}
.svc{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(16px,4vw,56px);align-items:center;
  padding:clamp(26px,3.6vw,46px) 0;border-bottom:1px solid var(--hairline);position:relative;transition:padding-left .4s var(--ease)}
.svc .num{font-family:var(--mono);font-size:13px;color:var(--cut-red);letter-spacing:.1em}
.svc .name{font-family:var(--display);font-size:clamp(32px,5vw,70px);line-height:.95;text-transform:uppercase;transition:color .3s}
.svc .desc{font-size:15px;color:var(--text-3);max-width:36ch;justify-self:start}
.svc .go{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--text-3);text-transform:uppercase;transition:color .3s}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--cut-red);transition:width .35s var(--ease)}
.svc:hover{padding-left:24px}
.svc:hover::before{width:4px}
.svc:hover .name{color:var(--amber)}
.svc:hover .go{color:var(--film-cream)}
@media(max-width:780px){.svc{grid-template-columns:auto 1fr;row-gap:8px}.svc .desc{grid-column:1/-1}.svc .go{display:none}}

/* ---------- WORK GRID ---------- */
.work-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:46px}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:38px}
.filters button{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);background:transparent;border:1px solid var(--hairline);padding:9px 16px;cursor:pointer;transition:all .25s}
.filters button:hover{color:var(--film-cream);border-color:var(--text-3)}
.filters button.active{background:var(--film-cream);color:var(--reel-black);border-color:var(--film-cream)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:920px){.work-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.work-grid{grid-template-columns:1fr}}
.work-item{transition:opacity .45s,transform .45s}
.work-item.hide{display:none}
.work-item .tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-top:14px}
.work-item .ttl{font-family:var(--display);font-size:clamp(22px,2.3vw,30px);text-transform:uppercase;letter-spacing:.02em;margin-top:6px;color:var(--film-cream)}
.work-item .meta{font-size:14px;color:var(--text-3);margin-top:4px}

/* ---------- PROOF ---------- */
.proof{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.trusted{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.trusted .lab{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--concrete)}
.trusted .names{display:flex;gap:clamp(18px,3.6vw,52px);flex-wrap:wrap}
.trusted .names span{font-family:var(--display);font-size:clamp(20px,2.3vw,30px);letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);transition:color .3s}
.trusted .names span:hover{color:var(--film-cream)}
.quote{max-width:32ch;margin-top:60px}
.quote p{font-family:var(--display);font-size:clamp(28px,3.8vw,52px);line-height:1.04;text-transform:uppercase;color:var(--film-cream)}
.quote .src{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--concrete);margin-top:18px;text-transform:uppercase}
.quote .ph{color:var(--cut-red)}

/* ---------- SCENE GRID (how it works short) ---------- */
.scenes{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);margin-bottom:44px}
@media(max-width:780px){.scenes{grid-template-columns:1fr}}
.scene{background:var(--reel-black);padding:clamp(28px,3vw,42px);min-height:230px;display:flex;flex-direction:column;transition:background .35s}
.scene:hover{background:var(--panel)}
.scene .code{font-family:var(--mono);font-size:13.5px;letter-spacing:.14em;color:var(--cut-red);margin-bottom:auto}
.scene h3{font-size:clamp(28px,3vw,44px);margin:34px 0 12px}
.scene p{font-size:15px;color:var(--text-3);max-width:34ch}

/* ---------- PROCESS TIMELINE ---------- */
.timeline{position:relative;margin-top:20px}
.timeline .spine{position:absolute;left:18px;top:0;bottom:0;width:2px;background:var(--hairline)}
.timeline .spine .fill{position:absolute;top:0;left:0;width:100%;height:0;background:var(--cut-red);transition:height .15s linear}
.phase{position:relative;padding:0 0 clamp(48px,6vw,84px) 58px}
.phase .dot{position:absolute;left:11px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--reel-black);border:2px solid var(--concrete);z-index:2;transition:border-color .4s,background .4s}
.phase.lit .dot{border-color:var(--cut-red);background:var(--cut-red)}
.phase .code{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--cut-red);text-transform:uppercase}
.phase h3{font-size:clamp(30px,4vw,58px);margin:10px 0 14px}
.phase .body{max-width:60ch}
.phase .body p{font-size:16px;color:var(--text-2)}
.phase .cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:22px;max-width:62ch}
@media(max-width:640px){.phase .cols{grid-template-columns:1fr}}
.phase .col h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--concrete);margin-bottom:10px}
.phase .col ul{list-style:none}
.phase .col li{font-size:14.5px;color:var(--text-2);padding-left:16px;position:relative;margin-bottom:7px}
.phase .col li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;background:var(--amber)}

/* ---------- AVOID LIST (brand flex) ---------- */
.avoid-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);margin-top:36px}
@media(max-width:680px){.avoid-grid{grid-template-columns:1fr}}
.avoid{background:var(--reel-black);padding:clamp(22px,2.6vw,34px)}
.avoid .x{font-family:var(--display);font-size:24px;color:var(--cut-red);line-height:1}
.avoid h4{font-family:var(--display);font-size:clamp(22px,2.4vw,30px);text-transform:uppercase;margin:12px 0 8px;color:var(--film-cream)}
.avoid p{font-size:14.5px;color:var(--text-3)}

/* ---------- ABOUT BLOCKS ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,80px);align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:34px}}
.split.rev>div:first-child{order:2}
@media(max-width:880px){.split.rev>div:first-child{order:0}}
.media{position:relative;overflow:hidden;border:1px solid var(--hairline)}
.media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) contrast(1.05)}
.media .cap{position:absolute;left:14px;bottom:12px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--film-cream);text-transform:uppercase;background:rgba(21,21,21,.55);padding:5px 9px;backdrop-filter:blur(3px)}
.namecard h3{font-size:clamp(30px,3.4vw,52px)}
.namecard .role{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:18px}
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);margin-top:40px}
@media(max-width:860px){.values{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.values{grid-template-columns:1fr}}
.value{background:var(--reel-black);padding:26px 22px;min-height:150px}
.value .n{font-family:var(--mono);font-size:11px;color:var(--cut-red);letter-spacing:.16em}
.value h4{font-family:var(--display);font-size:26px;text-transform:uppercase;margin:14px 0 8px;color:var(--film-cream)}
.value p{font-size:13.5px;color:var(--text-3)}

/* ---------- CTA BAND ---------- */
.cta-band{position:relative;background:var(--cut-red);color:var(--film-cream);text-align:center;padding:clamp(70px,11vw,150px) var(--pad);overflow:hidden}
.cta-band .bgimg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.16;mix-blend-mode:multiply;filter:grayscale(1)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:clamp(54px,10vw,150px);line-height:.88}
.cta-band p{font-size:clamp(17px,1.5vw,20px);max-width:44ch;margin:20px auto 38px;color:rgba(237,229,206,.92)}
.btn.oncream{border-color:var(--film-cream);color:var(--film-cream)}
.btn.oncream::after{background:var(--reel-black)}
.btn.oncream:hover{color:var(--film-cream);border-color:var(--reel-black)}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,6vw,90px)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--concrete);margin-bottom:9px}
.field input,.field textarea,.field select{width:100%;background:var(--panel);border:1px solid var(--hairline);color:var(--film-cream);font-family:var(--body);font-size:16px;padding:14px 16px;transition:border-color .25s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--amber)}
.field textarea{min-height:140px;resize:vertical}
.contact-aside .row{padding:18px 0;border-bottom:1px solid var(--hairline)}
.contact-aside .row:first-child{border-top:1px solid var(--hairline)}
.contact-aside .k{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--concrete);margin-bottom:6px}
.contact-aside .v{font-size:17px;color:var(--film-cream)}
.contact-aside .v a:hover{color:var(--amber)}

/* ---------- FOOTER ---------- */
.site-foot{padding:clamp(56px,7vw,100px) 0 38px;border-top:1px solid var(--hairline);background:var(--reel-black)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}
.foot-brand img{height:96px;width:auto;margin-bottom:14px;display:block}
.foot-brand .tag{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--concrete)}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--concrete);margin-bottom:18px}
.foot-col a,.foot-col p{display:block;font-size:14.5px;color:var(--text-3);margin-bottom:9px;transition:color .25s}
.foot-col a:hover{color:var(--film-cream)}
.foot-bottom{margin-top:54px;padding-top:22px;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--concrete);text-transform:uppercase}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.stagger.in>*{opacity:1;transform:none}

/* ---------- RESPONSIVE NAV ---------- */
@media(max-width:900px){
  nav.nav-main{display:none}
  .head-cta .btn{display:none}
  .burger{display:flex}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  html{scroll-behavior:auto}
  .reveal,.stagger>*{opacity:1!important;transform:none!important;transition:none!important}
}

/* =========================================================
   v2 ADDITIONS
   ========================================================= */

/* shared plus/minus toggle */
.pm{width:36px;height:36px;border:1px solid var(--hairline);border-radius:50%;display:grid;place-items:center;position:relative;flex:none;transition:border-color .3s,background .3s}
.pm::before,.pm::after{content:"";position:absolute;background:var(--film-cream);transition:transform .35s var(--ease)}
.pm::before{width:13px;height:1.5px}
.pm::after{width:1.5px;height:13px}
.open>.step-head .pm,.open>.q-head .pm{background:var(--cut-red);border-color:var(--cut-red)}
.open>.step-head .pm::after,.open>.q-head .pm::after{transform:scaleY(0)}

/* ---------- PROCESS ACCORDION ---------- */
.proc{border-top:1px solid var(--hairline);margin-top:14px}
.step{border-bottom:1px solid var(--hairline)}
.step-head{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(14px,3vw,44px);align-items:center;padding:clamp(22px,2.5vw,32px) 0;cursor:pointer;transition:padding-left .35s var(--ease)}
.step:hover .step-head{padding-left:14px}
.step-head .num{font-family:var(--mono);font-size:13px;color:var(--cut-red);letter-spacing:.08em}
.step-head .t{font-family:var(--display);font-size:clamp(26px,3.4vw,48px);text-transform:uppercase;line-height:.95;transition:color .3s}
.step:hover .step-head .t{color:var(--amber)}
.step-head .sum{font-size:14.5px;color:var(--text-3);max-width:42ch;justify-self:start}
.step-body{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.step-body .inner{padding:2px 0 30px;max-width:66ch}
.step-body .inner>p{font-size:16px;color:var(--text-2);margin-bottom:20px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cols .col h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--concrete);margin-bottom:11px}
.cols .col ul{list-style:none}
.cols .col li{font-size:14.5px;color:var(--text-2);padding-left:16px;position:relative;margin-bottom:7px}
.cols .col li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;background:var(--amber)}
@media(max-width:760px){.step-head{grid-template-columns:auto 1fr auto}.step-head .sum{display:none}.cols{grid-template-columns:1fr;gap:18px}}

/* ---------- TESTIMONIALS ---------- */
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--hairline);border:1px solid var(--hairline);margin-top:8px}
@media(max-width:760px){.testi-grid{grid-template-columns:1fr}}
.testi{background:var(--reel-black);padding:clamp(28px,3.4vw,48px);display:flex;flex-direction:column}
.testi .mk{font-family:var(--display);font-size:64px;color:var(--cut-red);line-height:.5;height:30px}
.testi p{font-size:clamp(17px,1.55vw,21px);color:var(--text);line-height:1.5;margin:14px 0 auto;font-weight:400}
.testi .who{margin-top:28px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--concrete);text-transform:uppercase;line-height:1.7}
.testi .who b{color:var(--film-cream);font-weight:700;display:block}

/* ---------- STATS / CREDIBILITY ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline)}
@media(max-width:680px){.stats{grid-template-columns:1fr 1fr}}
.stat{background:var(--reel-black);padding:clamp(24px,2.6vw,38px) clamp(18px,2vw,28px)}
.stat{background:var(--reel-black);padding:clamp(24px,2.6vw,38px) clamp(18px,2vw,28px);border-top:2px solid rgba(181,39,31,.55)}
.stat .big{font-family:var(--display);font-size:clamp(38px,4.4vw,62px);line-height:.9;color:var(--film-cream)}
.stat .lab{font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#9a9a9a;margin-top:12px;line-height:1.5;max-width:22ch}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--hairline);max-width:920px;margin-top:8px}
.faq .q{border-bottom:1px solid var(--hairline)}
.q-head{display:flex;justify-content:space-between;gap:22px;align-items:center;padding:22px 0;cursor:pointer}
.q-head h4{font-family:var(--display);font-size:clamp(20px,2.3vw,30px);text-transform:uppercase;letter-spacing:.02em;color:var(--film-cream);transition:color .3s}
.q:hover .q-head h4{color:var(--amber)}
.q-body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.q-body p{padding:0 0 24px;max-width:64ch;font-size:16px;color:var(--text-2)}

/* ---------- FEATURE FILM SECTION ---------- */
.feature .cap-row{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-top:20px}
.feature .cap-row .meta{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--concrete);text-transform:uppercase}

/* poster zoom on hover (used with JS flipbook preview) */
.video-frame .poster{will-change:transform}
.video-frame:hover .poster{transform:scale(1.05)}
.video-frame .scrub-mini{position:absolute;left:0;right:0;bottom:0;height:3px;background:rgba(237,229,206,.18);z-index:5;opacity:0;transition:opacity .3s}
.video-frame .scrub-mini i{display:block;height:100%;width:0;background:var(--cut-red);transition:width .12s linear}
.video-frame.previewing .scrub-mini{opacity:1}

/* ---------- MOBILE REFINEMENTS ---------- */
@media(max-width:600px){
  .brand img{height:44px}
  .foot-brand img{height:78px}
  .hero{min-height:92svh}
  .video-frame.sprocket{margin:0 18px}
  .video-frame .play{width:64px;height:64px}
  .video-frame .play::after{border-left-width:16px;border-top-width:10px;border-bottom-width:10px}
  .hud{display:none}
}

/* ---------- WOW: viewfinder cursor ---------- */
.viewfinder{position:fixed;top:0;left:0;z-index:7500;pointer-events:none;width:116px;height:116px;
  transform:translate(-50%,-50%) scale(.78);opacity:0;transition:opacity .18s,transform .18s}
.viewfinder.on{opacity:1;transform:translate(-50%,-50%) scale(1)}
.viewfinder .br{position:absolute;width:18px;height:18px;border:2px solid var(--film-cream);filter:drop-shadow(0 0 2px rgba(0,0,0,.6))}
.viewfinder .br.tl{top:0;left:0;border-right:0;border-bottom:0}
.viewfinder .br.tr{top:0;right:0;border-left:0;border-bottom:0}
.viewfinder .br.bl{bottom:0;left:0;border-right:0;border-top:0}
.viewfinder .br.br2{bottom:0;right:0;border-left:0;border-top:0}
.viewfinder .ch{position:absolute;top:50%;left:50%;width:2px;height:13px;background:var(--film-cream);transform:translate(-50%,-50%);filter:drop-shadow(0 0 2px rgba(0,0,0,.6))}
.viewfinder .ch.ch2{width:13px;height:2px}
.viewfinder .rec{position:absolute;top:-15px;left:0;font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:#ff3b30;display:flex;gap:5px;align-items:center}
.viewfinder .rec b{width:6px;height:6px;border-radius:50%;background:#ff3b30;animation:blink 1.1s steps(2) infinite}
@media(pointer:coarse){.viewfinder{display:none}}

/* ---------- LEGAL PAGES ---------- */
.legal{max-width:760px}
.legal h2{font-family:var(--display);font-size:clamp(22px,2.4vw,30px);text-transform:uppercase;letter-spacing:.02em;color:var(--film-cream);margin:38px 0 12px}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{font-size:16px;color:var(--text-2);line-height:1.7;margin-bottom:14px}
.legal ul{list-style:none;padding-left:0}
.legal li{padding-left:18px;position:relative}
.legal li::before{content:"";position:absolute;left:0;top:11px;width:5px;height:5px;background:var(--amber)}
.legal a{color:var(--amber)}
.legal .updated{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--concrete);text-transform:uppercase;margin-bottom:30px}
.legal .note{border:1px solid var(--hairline);border-left:2px solid var(--cut-red);padding:16px 18px;font-size:14px;color:var(--text-3);margin-bottom:30px}

/* ---------- LIGHTBOX (work videos expand on click) ---------- */
.lightbox{position:fixed;inset:0;z-index:9000;background:rgba(8,8,8,.94);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .3s var(--ease)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox .lb-inner{position:relative;width:min(92vw,1180px);aspect-ratio:16/9;background:#000;border:1px solid var(--hairline)}
.lightbox iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lightbox .lb-close{position:absolute;top:-46px;right:0;background:none;border:1px solid var(--hairline);color:var(--film-cream);font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:9px 16px;cursor:pointer;transition:border-color .3s,color .3s}
.lightbox .lb-close:hover{border-color:var(--cut-red);color:var(--cut-red)}
@media(max-width:600px){.lightbox .lb-close{top:-40px}}

/* ---------- PULLQUOTE (about, the name) ---------- */
.name-intro{max-width:880px}
.name-intro .big-lead{font-family:var(--display);font-size:clamp(30px,4.4vw,58px);line-height:1.02;text-transform:uppercase;color:var(--film-cream);margin-bottom:28px;max-width:18ch}
.name-intro p{font-size:clamp(16px,1.5vw,18.5px);color:var(--text-2);line-height:1.7;max-width:60ch}
.pullquote{margin-top:34px;border-left:2px solid var(--cut-red);padding-left:22px;font-family:var(--mono);font-size:clamp(13px,1.3vw,15px);letter-spacing:.06em;color:var(--amber);text-transform:uppercase}
