/* ============================================================
   ATTENTION CREATIVE — shared stylesheet
   Brand system: deep blue-black + single signal blue.
   Premium through control, not spectacle.
============================================================ */
:root{
  /* core */
  --ink-navy:#0B1322; --midnight:#070B14; --eclipse:#0A0F1C;
  --signal:#38BDF8; --sky:#46C6F5; --deep-cyan:#0E7FB8;
  /* neutrals */
  --paper:#EEF2F8; --mist:#9AA3B2; --steel:#42506A; --amber:#D98A3D;
  /* text-on-dark (brand rule: Paper on dark, never Steel/Mist) */
  --text-strong:#EEF2F8; --text-muted:rgba(238,242,248,0.66);
  --text-faint:rgba(238,242,248,0.42);
  --hairline:rgba(238,242,248,0.10); --hairline-soft:rgba(238,242,248,0.06);

  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;

  --maxw:1180px; --pad:clamp(20px,5vw,44px); --section-y:clamp(80px,11vw,150px);

  --ac-gradient:
    radial-gradient(1200px 600px at 78% 18%, rgba(56,189,248,0.18), transparent 60%),
    radial-gradient(900px 500px at 12% 92%, rgba(56,189,248,0.07), transparent 55%),
    linear-gradient(160deg,#070B14 0%,#0B1322 55%,#0A0F1C 100%);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--ink-navy);color:var(--text-strong);font-family:var(--body);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
::selection{background:rgba(56,189,248,0.28);}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}

/* kicker / labels */
.kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--sky);display:flex;align-items:center;gap:14px;margin:0 0 22px;}
.kicker::before{content:"";width:30px;height:1px;background:var(--signal);display:inline-block;flex:none;}

h1,h2,h3{font-family:var(--display);font-weight:500;letter-spacing:-.018em;margin:0;}

/* header */
.site-header{position:sticky;top:0;z-index:50;border-bottom:1px solid transparent;
  transition:background .35s ease,border-color .35s ease,backdrop-filter .35s ease;}
.site-header.scrolled{background:rgba(7,11,20,0.72);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--hairline);}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;}
.brand{font-family:var(--display);font-weight:600;font-size:1.02rem;letter-spacing:.16em;
  color:var(--paper);white-space:nowrap;}
.brand .dot{color:var(--signal);}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-size:.86rem;letter-spacing:.02em;color:var(--text-muted);transition:color .2s ease;}
.nav-links a:hover{color:var(--paper);}
.nav-links a[aria-current="page"]{color:var(--paper);}
.btn{font-family:var(--body);font-size:.86rem;font-weight:500;letter-spacing:.01em;padding:11px 20px;
  border-radius:2px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:9px;
  transition:background .25s ease,border-color .25s ease,color .25s ease,transform .15s ease;}
.btn-primary{background:var(--signal);color:var(--midnight);font-weight:600;}
.btn-primary:hover{background:var(--sky);}
.btn-ghost{border-color:var(--hairline);color:var(--paper);background:transparent;}
.btn-ghost:hover{border-color:var(--signal);color:var(--sky);}
.btn:focus-visible,a:focus-visible{outline:2px solid var(--sky);outline-offset:3px;}
.nav-toggle{display:none;background:none;border:0;color:var(--paper);cursor:pointer;padding:8px;}

/* hero (home) */
.hero{background:var(--ac-gradient);position:relative;overflow:hidden;
  padding-top:clamp(70px,12vw,150px);padding-bottom:clamp(80px,13vw,170px);
  border-bottom:1px solid var(--hairline-soft);}
.hero .wrap{max-width:980px;}
.hero h1{font-size:clamp(2.7rem,6.2vw,5.1rem);line-height:1.02;font-weight:500;max-width:15ch;}
.hero h1 em{font-style:normal;color:var(--signal);}
.hero-sub{margin:30px 0 0;max-width:60ch;font-size:clamp(1.04rem,1.5vw,1.22rem);
  color:var(--text-muted);line-height:1.6;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:42px;}
.hero-meta{margin-top:64px;display:flex;flex-wrap:wrap;gap:10px 34px;font-family:var(--mono);
  font-size:.74rem;letter-spacing:.08em;color:var(--text-faint);text-transform:uppercase;}
.hero-meta span{display:flex;align-items:center;gap:10px;}
.hero-meta span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--signal);}

/* inner-page hero (smaller) */
.subhero{background:var(--ac-gradient);border-bottom:1px solid var(--hairline-soft);
  padding-top:clamp(60px,9vw,110px);padding-bottom:clamp(56px,8vw,96px);}
.subhero h1{font-size:clamp(2.3rem,5vw,3.9rem);line-height:1.04;max-width:18ch;}
.subhero p{margin:26px 0 0;max-width:58ch;font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--text-muted);}

/* trust */
.trust{border-bottom:1px solid var(--hairline);background:var(--eclipse);}
.trust .wrap{padding-block:34px;display:flex;flex-wrap:wrap;align-items:center;gap:18px 48px;}
.trust-label{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-faint);white-space:nowrap;}
.marquee{flex:1 1 280px;min-width:0;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);}
.marquee-track{display:flex;width:max-content;animation:trustscroll 38s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.trust-names{display:flex;align-items:center;gap:0;margin:0;padding:0;flex:none;}
.trust-names li{list-style:none;font-family:var(--display);font-weight:500;font-size:1.05rem;
  letter-spacing:.01em;color:var(--text-muted);white-space:nowrap;}
.trust-names li::after{content:"·";color:var(--signal);margin:0 24px;font-weight:500;}
@keyframes trustscroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;}.marquee{overflow-x:auto;}}

/* generic section */
.section{padding-block:var(--section-y);border-bottom:1px solid var(--hairline-soft);}
.section.alt{background:var(--eclipse);}
.section-head{max-width:760px;}
.section-head h2{font-size:clamp(1.95rem,3.7vw,3.05rem);line-height:1.08;}
.section-head p{color:var(--text-muted);margin:22px 0 0;font-size:1.08rem;max-width:62ch;}
.section-link{display:inline-flex;margin-top:34px;font-family:var(--mono);font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--sky);}
.section-link:hover{color:var(--paper);}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:60px;
  background:var(--hairline);border:1px solid var(--hairline);border-radius:3px;overflow:hidden;}
.pillar{background:var(--ink-navy);padding:38px 32px;}
.section.alt .pillar{background:var(--eclipse);}
.pillar .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--signal);text-transform:uppercase;}
.pillar h3{font-size:1.28rem;margin:20px 0 12px;font-weight:500;}
.pillar p{margin:0;color:var(--text-muted);font-size:.98rem;line-height:1.6;}

/* capabilities list */
.caps{margin-top:56px;border-top:1px solid var(--hairline);}
.cap{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:baseline;padding:26px 4px;
  border-bottom:1px solid var(--hairline);transition:padding-left .3s ease;}
.cap:hover{padding-left:14px;}
.cap h3{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:500;}
.cap:hover h3{color:var(--sky);}
.cap p{margin:0;color:var(--text-muted);font-size:.96rem;max-width:46ch;text-align:right;}

/* service detail (capabilities page) */
.service{padding-block:40px;border-bottom:1px solid var(--hairline);display:grid;
  grid-template-columns:0.9fr 1.1fr;gap:40px;align-items:start;}
.service:first-child{border-top:1px solid var(--hairline);}
.service h3{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:500;line-height:1.1;}
.service .s-kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;color:var(--sky);
  text-transform:uppercase;margin-bottom:14px;}
.service p{margin:0;color:var(--text-muted);}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.chip{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;color:var(--text-faint);
  border:1px solid var(--hairline);border-radius:2px;padding:6px 11px;text-transform:uppercase;}

/* work frames */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px;}
.work-grid.wide{grid-template-columns:repeat(2,1fr);gap:24px;}
.frame{position:relative;border:1px solid var(--hairline);border-radius:3px;overflow:hidden;
  aspect-ratio:4/3;background:var(--ac-gradient);display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;cursor:pointer;transition:border-color .3s ease,transform .3s ease;}
.work-grid.wide .frame{aspect-ratio:16/10;padding:30px;}
.frame:hover{border-color:var(--signal);transform:translateY(-3px);}
.frame::before{content:"";position:absolute;inset:0;
  background:radial-gradient(600px 360px at 80% 12%, rgba(56,189,248,0.20), transparent 62%);
  opacity:0;transition:opacity .4s ease;}
.frame:hover::before{opacity:1;}
.frame .slate{position:absolute;top:18px;left:20px;font-family:var(--mono);font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);}
.frame .sector{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sky);margin-bottom:10px;position:relative;}
.frame h3{font-size:1.18rem;font-weight:500;position:relative;line-height:1.25;}
.work-grid.wide .frame h3{font-size:1.5rem;}
.frame .meta{position:relative;margin-top:8px;color:var(--text-muted);font-size:.9rem;}
/* thumbnail behind work tiles — subtle by default, revealed on hover */
.frame::before{z-index:1;}
.frame .slate,.frame .sector,.frame h3,.frame .meta{z-index:2;}
.frame.has-thumb{background:var(--ink-navy);}
.frame.has-thumb::after{content:"";position:absolute;inset:0;z-index:0;
  background-image:linear-gradient(180deg,rgba(7,11,20,0.40),rgba(7,11,20,0.50) 45%,rgba(7,11,20,0.88)),var(--thumb);
  background-size:cover;background-position:center;opacity:.5;transition:opacity .45s ease;}
.frame.has-thumb:hover::after{opacity:.92;}
.thumb-jupiter{--thumb:url('https://i.vimeocdn.com/video/2082858507-1fcd103c890c5816a6667c4154770ceda1c2afaa273b1a63c2f6e3df0aed8bf9-d_1280?region=us');}
.thumb-oya{--thumb:url('https://i.vimeocdn.com/video/2167673313-2a0ce87a6e7653666f0e7f8f99fd2383fb533f5b85b1b5eaedcd3b00789b9039-d_1280?region=us');}
.thumb-bv{--thumb:url('https://i.vimeocdn.com/video/2167657281-5ba291c16246b8b1776e3386814d6f9deda436d26b46905dfbf4eaba1ae9b7a3-d_1280?region=us');}
.thumb-fpl{--thumb:url('https://i.vimeocdn.com/video/817506945-6ae7fcc788b414b3345f90bd008f2a200d3db4ac5ae227822674b4c95180293f-d_1280?region=us');}
.thumb-maritime{--thumb:url('https://i.vimeocdn.com/video/1721488168-2a80ff9e99b9e21958036e249e7445fe2feb9906487a2dd5dbda01d10536b15c-d_1280?region=us');}

/* studios */
.studios{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:56px;background:var(--hairline);
  border:1px solid var(--hairline);border-radius:3px;overflow:hidden;}
.studio{background:var(--eclipse);padding:42px 36px;display:block;transition:background .3s ease;}
a.studio:hover{background:#0c1422;}
.studio .city{font-family:var(--display);font-weight:600;font-size:1.6rem;letter-spacing:.01em;}
.studio .region{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--sky);margin-top:8px;}
.studio .coords{font-family:var(--mono);font-size:.8rem;color:var(--text-faint);margin-top:26px;}
.studio .go{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-muted);margin-top:18px;display:inline-block;}
a.studio:hover .go{color:var(--sky);}
.ne-pill{display:inline-flex;align-items:center;gap:9px;margin-top:20px;border:1px solid rgba(217,138,61,0.45);
  color:var(--amber);font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 13px;border-radius:2px;}
.ne-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);}

/* about — leadership + collaborators */
.lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:56px;}
.lead{display:grid;grid-template-columns:140px 1fr;gap:26px;align-items:start;}
.avatar{aspect-ratio:1/1;background:var(--ac-gradient);border:1px solid var(--hairline);border-radius:3px;
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;
  font-size:1.3rem;letter-spacing:.08em;color:var(--signal);}
.lead .name{font-family:var(--display);font-weight:600;font-size:1.35rem;}
.lead .role{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--sky);margin:7px 0 16px;}
.lead .bio{color:var(--text-muted);font-size:.97rem;margin:0;}
/* founders band (About) — B&W portraits, color on hover */
.founders-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px;}
.founder-shot{aspect-ratio:3/4;border:1px solid var(--hairline);border-radius:3px;background-size:cover;
  background-position:center;filter:grayscale(1) contrast(1.03);
  transition:filter .55s ease,border-color .35s ease,transform .35s ease;}
.founder-shot:hover{filter:grayscale(0) contrast(1);border-color:var(--signal);transform:translateY(-4px);}
.fs1{background-image:url('img/founders-1.jpg');}
.fs2{background-image:url('img/founders-2.jpg');}
.fs3{background-image:url('img/founders-3.jpg');}
.founders-bios{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:38px;}
.founder-bio .name{font-family:var(--display);font-weight:600;font-size:1.35rem;}
.founder-bio .role{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--sky);margin:7px 0 14px;}
.founder-bio .bio{color:var(--text-muted);font-size:.97rem;margin:0;line-height:1.6;}
@media (max-width:880px){.founders-bios{grid-template-columns:1fr;gap:30px;}}
.collab-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;}
.collab{display:grid;grid-template-columns:84px 1fr;gap:20px;align-items:start;
  border:1px solid var(--hairline);border-radius:3px;padding:26px;background:var(--eclipse);}
.collab .avatar{font-size:1rem;}
.collab .name{font-family:var(--display);font-weight:600;font-size:1.12rem;}
.collab .role{font-family:var(--mono);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--sky);margin:6px 0 12px;}
.collab .bio{color:var(--text-muted);font-size:.92rem;margin:0;}
.stat-row{display:flex;flex-wrap:wrap;gap:32px 56px;margin-top:50px;}
.stat .n{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,4vw,3rem);color:var(--paper);line-height:1;}
.stat .l{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-faint);margin-top:10px;}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-top:10px;align-items:start;}
.contact-block h2{font-size:clamp(1.9rem,3.4vw,2.8rem);line-height:1.08;}
.contact-block p{color:var(--text-muted);margin:22px 0 0;max-width:46ch;}
.contact-mail{display:inline-block;margin-top:30px;font-family:var(--display);font-weight:500;
  font-size:clamp(1.15rem,2vw,1.5rem);color:var(--signal);}
.contact-mail:hover{color:var(--sky);}
.contact-detail{border-top:1px solid var(--hairline);padding-top:30px;}
.contact-detail h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-faint);font-weight:400;margin:0 0 14px;}
.contact-detail p{color:var(--text-muted);margin:0 0 28px;font-size:.96rem;}
.contact-detail .coords{font-family:var(--mono);font-size:.78rem;color:var(--text-faint);}

/* contact form */
.contact-form{margin-top:34px;display:grid;gap:20px;max-width:34rem;}
.field{display:grid;gap:9px;}
.field label{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sky);}
.field label .opt{color:var(--text-faint);letter-spacing:.1em;}
.contact-form input,.contact-form textarea{font-family:var(--body);font-size:1rem;color:var(--text-strong);
  background:rgba(238,242,248,0.03);border:1px solid var(--hairline);border-radius:2px;padding:13px 15px;width:100%;
  transition:border-color .2s ease,background .2s ease;}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-faint);}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--signal);
  background:rgba(56,189,248,0.04);}
.contact-form textarea{resize:vertical;min-height:128px;line-height:1.55;}
.contact-form .btn-primary{justify-self:start;margin-top:4px;}
.contact-form .btn-primary:disabled{opacity:.6;cursor:default;}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-alt{margin-top:26px;color:var(--text-muted);font-size:.95rem;max-width:46ch;}
.form-alt a{color:var(--sky);border-bottom:1px solid var(--hairline);transition:color .2s ease,border-color .2s ease;}
.form-alt a:hover{color:var(--paper);border-color:var(--signal);}
.form-success{margin-top:34px;border:1px solid var(--hairline);border-left:2px solid var(--signal);border-radius:2px;
  padding:28px 30px;background:rgba(56,189,248,0.04);max-width:34rem;}
.form-success h3{font-family:var(--display);font-weight:500;font-size:1.5rem;}
.form-success p{color:var(--text-muted);margin:12px 0 0;}
.form-success a{color:var(--sky);}

/* case study */
.back-link{color:var(--sky);border-bottom:1px solid var(--hairline);}
.back-link:hover{color:var(--paper);border-color:var(--signal);}
.case-wrap{max-width:1000px;}
.video-embed{position:relative;padding-top:56.25%;border:1px solid var(--hairline);border-radius:3px;
  overflow:hidden;background:var(--midnight);}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.video-caption{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-faint);margin:16px 0 0;}
.case-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;
  background:var(--hairline);border:1px solid var(--hairline);border-radius:3px;overflow:hidden;margin-top:54px;}
.case-facts .fact{background:var(--ink-navy);padding:22px 24px;}
.case-facts dt{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--sky);margin:0 0 9px;}
.case-facts dd{margin:0;color:var(--text-strong);font-size:.95rem;line-height:1.45;}
.case-body{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:60px;}
.case-block h2{font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sky);}
.case-block p{color:var(--text-muted);margin:16px 0 0;font-size:1rem;line-height:1.62;}
.pullquote{margin:64px 0 0;border-left:2px solid var(--signal);padding:8px 0 8px 32px;}
.pullquote blockquote{margin:0;font-family:var(--display);font-weight:500;letter-spacing:-.015em;
  font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.18;color:var(--text-strong);}
.pullquote figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-faint);margin-top:22px;}
.case-films{margin-top:64px;}
.films-head{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:500;}
.films-sub{color:var(--text-muted);margin:14px 0 0;max-width:52ch;}
.film-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:34px;}
.film{margin:0;}
.film-play{position:relative;display:block;width:100%;padding:0;padding-top:56.25%;border:1px solid var(--hairline);
  border-radius:3px;overflow:hidden;cursor:pointer;background-color:var(--midnight);background-size:cover;
  background-position:center;transition:border-color .3s ease,transform .3s ease;}
.film-play:hover{border-color:var(--signal);transform:translateY(-3px);}
.film-play::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,11,20,0.04),rgba(7,11,20,0.5));transition:background .3s ease;}
.film-play:hover::after{background:linear-gradient(180deg,rgba(7,11,20,0),rgba(7,11,20,0.32));}
.play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;width:58px;height:58px;
  border-radius:50%;background:rgba(56,189,248,0.92);color:var(--midnight);display:flex;align-items:center;
  justify-content:center;font-size:1.05rem;padding-left:3px;transition:background .25s ease,transform .25s ease;}
.film-play:hover .play-icon{background:var(--sky);transform:translate(-50%,-50%) scale(1.07);}
.film-play:focus-visible{outline:2px solid var(--sky);outline-offset:3px;}
.film figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-faint);margin-top:14px;}

/* closer */
.closer{background:var(--ac-gradient);border-bottom:1px solid var(--hairline-soft);}
.closer .wrap{padding-block:clamp(90px,13vw,160px);max-width:880px;}
.closer h2{font-size:clamp(2.1rem,4.4vw,3.6rem);line-height:1.06;max-width:18ch;}
.closer p{color:var(--text-muted);margin:26px 0 0;font-size:1.1rem;max-width:54ch;}
.closer-cta{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.closer-mail{font-family:var(--mono);font-size:.84rem;color:var(--text-muted);letter-spacing:.04em;}
.closer-mail:hover{color:var(--sky);}

/* footer */
.site-footer{background:var(--midnight);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-block:64px;
  border-bottom:1px solid var(--hairline-soft);}
.footer-brand .brand{font-size:1.1rem;}
.footer-brand p{color:var(--text-faint);font-size:.92rem;margin:18px 0 0;max-width:34ch;}
.footer-col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-faint);font-weight:400;margin:0 0 18px;}
.footer-col a,.footer-col span{display:block;color:var(--text-muted);font-size:.92rem;margin-bottom:11px;}
.footer-col a:hover{color:var(--sky);}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding-block:28px;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;color:var(--text-faint);text-transform:uppercase;}

/* reveal / anim */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
.reveal.is-visible{opacity:1;transform:none;}
.anim{opacity:0;transform:translateY(20px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards;}
.d1{animation-delay:.05s;} .d2{animation-delay:.18s;} .d3{animation-delay:.30s;} .d4{animation-delay:.42s;}
@keyframes rise{to{opacity:1;transform:none;}}

/* mobile */
@media (max-width:880px){
  .pillars,.work-grid,.work-grid.wide,.studios,.footer-top,.lead-grid,.collab-grid,.contact-grid,.service,.case-body,.film-grid{grid-template-columns:1fr;}
  .cap{grid-template-columns:1fr;gap:8px;} .cap p{text-align:left;}
  .footer-top{gap:34px;}
  .nav-links{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;
    background:rgba(7,11,20,0.97);backdrop-filter:blur(14px);padding:8px var(--pad) 24px;
    border-bottom:1px solid var(--hairline);transform:translateY(-130%);transition:transform .35s ease;}
  .nav-links.open{transform:none;}
  .nav-links a{padding:16px 0;width:100%;border-bottom:1px solid var(--hairline-soft);font-size:1rem;}
  .nav-links .btn{margin-top:16px;}
  .nav-toggle{display:inline-flex;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;}
  .reveal{opacity:1;transform:none;} html{scroll-behavior:auto;}
}
