/* ============================================================
   SITE — components
   ============================================================ */

/* ---------- intro explosion overlay ---------- */
#intro{
  position:fixed; inset:0; z-index:9999; background:#ffffff;
  display:grid; place-items:center; overflow:hidden;
}
#intro canvas{ position:absolute; inset:0; width:100%; height:100%; }
#intro.done{ opacity:0; transition:opacity .8s var(--ease); pointer-events:none; }
.intro-skip{
  position:absolute; bottom:24px; right:26px; z-index:3;
  font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(20,21,26,.4); mix-blend-mode:difference;
}
body.intro-lock{ overflow:hidden; height:100vh; }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease), border-color .4s, padding .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.solid{ background:rgba(10,11,13,.82); backdrop-filter:blur(14px); border-bottom-color:var(--line); padding-block:13px; }

/* condensed nav on scroll-down (desktop): only the burst mark + wordmark, centered */
.nav-condensed{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-44%);
  display:flex; align-items:center; gap:13px;
  opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.nav-condensed .nc-mark{
  width:25px; height:25px; flex:none; background:var(--red);
  -webkit-mask:url('../assets/burst.png') center/contain no-repeat;
  mask:url('../assets/burst.png') center/contain no-repeat;
}
.nav-condensed .nc-text{
  font-family:var(--font-display); font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking); text-transform:uppercase;
  font-size:1.05rem; line-height:1; color:var(--white); white-space:nowrap;
}
@media (min-width:861px){
  .nav.condensed .nav-logo,
  .nav.condensed .nav-links{ opacity:0; pointer-events:none; transition:opacity .3s var(--ease); }
  .nav.condensed .nav-condensed{ opacity:1; pointer-events:auto; transform:translate(-50%,-50%); }
}
@media (max-width:860px){
  .nav-condensed{ display:none; }
}
.nav-logo{ display:flex; align-items:center; gap:12px; z-index:2; }
.nav-logo img{ height:30px; }
.nav-links{ display:flex; align-items:center; gap:36px; }
.nav-links a{
  font-size:.86rem; font-weight:500; letter-spacing:.04em; color:var(--mut);
  position:relative; padding-block:6px; transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{ color:var(--white); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px; background:var(--red);
}
.nav-cta{ display:flex; align-items:center; gap:18px; }
.nav-burger{ display:none; width:30px; height:20px; position:relative; z-index:2; }
.nav-burger span{ position:absolute; left:0; right:0; height:2px; background:var(--white); transition:.3s var(--ease); }
.nav-burger span:nth-child(1){ top:0; } .nav-burger span:nth-child(2){ top:9px; } .nav-burger span:nth-child(3){ top:18px; }
@media (max-width:860px){
  .nav-links,.nav-cta .btn{ display:none; }
  .nav-burger{ display:block; }
  .nav.open .nav-burger span:nth-child(1){ top:9px; transform:rotate(45deg); }
  .nav.open .nav-burger span:nth-child(2){ opacity:0; }
  .nav.open .nav-burger span:nth-child(3){ top:9px; transform:rotate(-45deg); }
}
/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:850; background:var(--ink); padding:120px var(--gutter) 40px;
  display:flex; flex-direction:column; gap:8px; transform:translateY(-100%); transition:transform .5s var(--ease);
  overflow:hidden;
}
.mobile-menu.open{ transform:none; }
.mobile-menu a{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(2rem,8vw,3rem); padding-block:10px; border-bottom:1px solid var(--line); }
.mobile-menu a.cta-row{ color:var(--red); border:0; margin-top:18px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:11px;
  font-weight:600; font-size:.92rem; letter-spacing:.01em;
  padding:15px 28px; border:1px solid transparent; position:relative;
  transition:background .25s var(--ease), color .25s, border-color .25s, transform .25s;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--red); color:#fff; }
.btn-primary:hover{ background:var(--red-bright); }
.btn-ghost{ border-color:var(--line-2); color:var(--white); }
.btn-ghost:hover{ border-color:var(--white); background:var(--white); color:var(--ink); }
.btn-ink{ background:var(--ink); color:#fff; }
.btn-ink:hover{ background:var(--red); }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-lg{ padding:18px 34px; font-size:1rem; }
.on-paper .btn-ghost{ border-color:var(--line-on-paper); color:var(--ink-on-paper); }
.on-paper .btn-ghost:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }

.link-arrow{ display:inline-flex; align-items:center; gap:10px; font-weight:600; color:var(--white); border-bottom:2px solid var(--red); padding-bottom:4px; }
.link-arrow .arr{ color:var(--red); transition:transform .25s var(--ease); }
.link-arrow:hover .arr{ transform:translateX(5px); }
.on-paper .link-arrow{ color:var(--ink-on-paper); }

/* ---------- hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; background:#0a0b0d; filter:grayscale(.18) contrast(1.03) brightness(.92); }
.hero-burst{
  position:absolute; right:5%; top:46%; transform:translateY(-50%);
  width:min(380px,32vw); aspect-ratio:1; opacity:calc(.26 + var(--glow) * .12); z-index:1; mix-blend-mode:screen;
  -webkit-mask:url('../assets/burst.png') center/contain no-repeat; mask:url('../assets/burst.png') center/contain no-repeat;
  background:var(--red);
}
.hero-grad{ position:absolute; inset:0; z-index:1; background:
  radial-gradient(120% 90% at 78% 28%, rgba(214,47,46,calc(var(--glow)*.20)) 0%, transparent 52%),
  linear-gradient(90deg, rgba(8,9,11,.92) 0%, rgba(8,9,11,.72) 34%, rgba(8,9,11,.34) 62%, rgba(8,9,11,.5) 100%),
  linear-gradient(180deg, rgba(10,11,13,.55) 0%, rgba(10,11,13,.18) 30%, rgba(10,11,13,.6) 76%, var(--ink) 100%); }
.hero-particles{ position:absolute; inset:0; z-index:1; }
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(60px,9vh,120px); padding-top:140px; }
.hero h1{ font-size:var(--fs-hero); text-transform:uppercase; margin-block:.32em .5em; }
.hero .lead{ max-width:46ch; }
.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; margin-top:38px; }
.hero-scroll{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2; font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--mut-2); display:flex; flex-direction:column; align-items:center; gap:10px; }
.hero-scroll .bar{ width:1px; height:46px; background:linear-gradient(var(--red),transparent); }

/* ---------- statement / interstitial ---------- */
.statement{ font-size:clamp(1.8rem,4.4vw,3.4rem); line-height:1.08; font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-tracking); text-wrap:balance; }
.statement .red{ color:var(--red); }
.interstitial{ background:var(--red); color:#fff; }

/* marquee */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:22px; white-space:nowrap; }
.marquee-track{ display:inline-flex; gap:60px; animation:marq 52s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee span{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(1.3rem,2.6vw,2.1rem); text-transform:uppercase; letter-spacing:.01em; color:var(--mut); display:inline-flex; align-items:center; gap:60px; }
.marquee span::after{ content:""; width:12px; height:12px; background:var(--red); -webkit-mask:url('../assets/burst.png') center/contain no-repeat; mask:url('../assets/burst.png') center/contain no-repeat; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------- section heading ---------- */
.sec-head{ display:grid; grid-template-columns:1fr; gap:22px; margin-bottom:clamp(40px,5vw,72px); }
.sec-head.split{ grid-template-columns:1.1fr .9fr; align-items:end; }
@media (max-width:860px){ .sec-head.split{ grid-template-columns:1fr; } }
.sec-head h2{ font-size:var(--fs-h2); text-transform:uppercase; }
.sec-head .sub{ color:var(--mut); max-width:46ch; }
.num-index{ font-family:var(--font-display); font-weight:var(--display-weight); color:var(--red); }

/* ---------- service list ---------- */
.svc{ border-top:1px solid var(--line); }
.svc-row{ display:grid; grid-template-columns:64px 1fr 1.3fr auto; gap:28px; align-items:baseline; padding:30px 0; border-bottom:1px solid var(--line); transition:padding-left .4s var(--ease), background .4s; position:relative; }
.svc-row::before{ content:""; position:absolute; left:-100vw; right:0; top:0; bottom:0; background:linear-gradient(90deg,transparent, rgba(214,47,46,.06)); opacity:0; transition:opacity .4s; z-index:-1; }
.svc-row:hover{ padding-left:18px; }
.svc-row:hover::before{ opacity:1; }
.svc-row .n{ font-family:var(--font-display); font-weight:var(--display-weight); color:var(--mut-2); font-size:1rem; }
.svc-row h3{ font-size:clamp(1.3rem,2.3vw,1.9rem); text-transform:uppercase; }
.svc-row:hover h3{ color:var(--red); }
.svc-row p{ color:var(--mut); font-size:.96rem; }
.svc-row .arr{ color:var(--red); opacity:0; transform:translateX(-8px); transition:.3s var(--ease); }
.svc-row:hover .arr{ opacity:1; transform:none; }
@media (max-width:860px){ .svc-row{ grid-template-columns:40px 1fr; } .svc-row p,.svc-row .arr{ grid-column:2; } }

/* ---------- results cards ---------- */
.result{ position:relative; display:flex; flex-direction:column; background:var(--ink-2); border:1px solid var(--line); overflow:hidden; transition:border-color .35s, transform .35s var(--ease); }
.result > *{ position:relative; z-index:2; }
.result:hover{ border-color:var(--red); transform:translateY(-4px); }

/* head — stat + name on solid dark, fully legible */
.r-head{ padding:28px 28px 22px; }
.result .stat{ font-family:var(--font-display); font-weight:900; font-size:clamp(2.3rem,3.8vw,3.4rem); line-height:.92; color:var(--white); letter-spacing:-.02em; }
.result .stat .unit{ font-size:.42em; color:var(--red); vertical-align:super; margin-left:.1em; }
.result .who{ margin-top:16px; font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.18rem; text-transform:uppercase; }
.result .where{ color:var(--mut); font-size:.86rem; letter-spacing:.04em; margin-top:3px; }

/* photo — full colour, isolated middle band */
.r-photo{ position:relative; height:clamp(165px,15vw,205px); overflow:hidden; border-top:1px solid var(--line); }
.r-photo .bg{ position:absolute; inset:0; background-repeat:no-repeat; filter:contrast(1.04) saturate(1.07); transition:transform .8s var(--ease); }
.result:hover .r-photo .bg{ transform:scale(1.05); }

/* foot — descriptive text inside the brand-red band */
.r-foot{ margin-top:auto; padding:22px 26px 24px; background:linear-gradient(180deg, #181b21 0%, #531412 48%, #74140f 100%); }
.result .desc{ color:rgba(255,255,255,.84); font-size:.92rem; line-height:1.5; }
.result .desc .red{ color:#ff9079; font-weight:600; }
.result .tag{ display:inline-block; margin-top:16px; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.34); padding:6px 11px; }

/* ---------- media wall ---------- */
.mediawall{ position:relative; background:var(--ink-1); overflow:hidden; }
.mw-strip{ position:relative; height:clamp(190px,24vw,300px); overflow:hidden; margin-bottom:clamp(44px,6vw,80px);
  -webkit-mask:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent); mask:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent); }
.mw-track{ position:absolute; top:50%; left:50%; width:150%; transform:translate(-50%,-50%) rotate(-4deg); display:flex; flex-direction:column; gap:16px; }
.mw-line{ white-space:nowrap; display:inline-flex; gap:18px; }
.mw-line.a{ animation:mwL 48s linear infinite; }
.mw-line.b{ animation:mwR 54s linear infinite; }
.mw-quote{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(1.1rem,2vw,1.7rem); text-transform:uppercase; color:rgba(247,247,245,.07); border:1px solid var(--line); padding:12px 22px; }
.mw-quote.hot{ color:var(--red); border-color:rgba(214,47,46,.4); }
@keyframes mwL{ to{ transform:translateX(-33.33%); } }
@keyframes mwR{ from{ transform:translateX(-33.33%);} to{ transform:translateX(0);} }

/* ---------- team ---------- */
.member{ }
.member .photo{ position:relative; aspect-ratio:4/5; background:linear-gradient(160deg,var(--ink-3),var(--ink-1)); border:1px solid var(--line); overflow:hidden; }
.member .photo img{ width:100%; height:100%; object-fit:cover; filter:contrast(1.03); transition:transform .8s var(--ease); }
.member:hover .photo img{ transform:scale(1.04); }
.member .ph-mark{ position:absolute; inset:0; display:grid; place-items:center; }
.member .ph-mark span{ width:34%; aspect-ratio:1; background:var(--ink-3); -webkit-mask:url('../assets/burst.png') center/contain no-repeat; mask:url('../assets/burst.png') center/contain no-repeat; }
.member .ph-tag{ position:absolute; left:14px; bottom:14px; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--mut-2); background:rgba(10,11,13,.6); padding:6px 9px; }
.member h3{ margin-top:20px; font-size:1.35rem; text-transform:uppercase; }
.member .role{ color:var(--red); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-top:5px; font-weight:600; }
.member p{ color:var(--mut); font-size:.92rem; margin-top:14px; }
.member .social{ display:flex; gap:10px; margin-top:18px; }
.member .social a{ width:38px; height:38px; display:grid; place-items:center; border:1px solid var(--line); color:var(--mut); border-radius:999px; transition:color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease), transform .3s var(--ease); }
.member .social a svg{ width:17px; height:17px; fill:currentColor; }
.member .social a:hover{ color:#fff; background:var(--red); border-color:var(--red); transform:translateY(-2px); }
.on-paper .member .social a{ color:var(--mut-on-paper); border-color:var(--line-on-paper); }
.on-paper .member .social a:hover{ color:#fff; background:var(--red); border-color:var(--red); }

/* ---------- process steps ---------- */
.steps{ border-top:1px solid var(--line); }
.step{ display:grid; grid-template-columns:auto 1fr; gap:clamp(24px,5vw,80px); padding:clamp(36px,5vw,68px) 0; border-bottom:1px solid var(--line); }
.step .big-n{ font-family:var(--font-display); font-weight:900; font-size:clamp(3rem,9vw,8rem); line-height:.8; color:transparent; -webkit-text-stroke:1.5px var(--line-2); }
.step:hover .big-n{ -webkit-text-stroke-color:var(--red); }
.step h3{ font-size:var(--fs-h3); text-transform:uppercase; margin-bottom:16px; }
.step p{ color:var(--mut); max-width:60ch; }
@media (max-width:680px){ .step{ grid-template-columns:1fr; gap:10px; } }

/* ---------- video / podcast cards ---------- */
.video-card{ position:relative; aspect-ratio:9/16; background:var(--ink-2); border:1px solid var(--line); overflow:hidden; cursor:pointer; transition:border-color .3s, transform .4s var(--ease); }
.video-card:hover{ border-color:var(--red); transform:translateY(-4px); }
.video-card video,.video-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.video-card .ph{ position:absolute; inset:0; display:grid; place-items:center; background:linear-gradient(160deg,var(--ink-3),var(--ink-1)); }
.video-card .play{ position:absolute; inset:0; display:grid; place-items:center; z-index:2; }
.video-card .play b{ width:62px; height:62px; border-radius:50%; background:rgba(214,47,46,.92); display:grid; place-items:center; transition:transform .3s var(--ease); }
.video-card:hover .play b{ transform:scale(1.1); }
.video-card .play b::after{ content:""; border-left:18px solid #fff; border-block:11px solid transparent; margin-left:5px; }
.video-card .label{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:16px; background:linear-gradient(transparent,rgba(10,11,13,.85)); font-size:.82rem; letter-spacing:.04em; }

/* ---------- footer ---------- */
.footer{ background:var(--ink-1); border-top:1px solid var(--line); padding-block:clamp(60px,8vw,110px) 36px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr; gap:36px; } }
.footer h4{ font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; color:var(--mut-2); margin-bottom:20px; font-family:var(--font-body); font-weight:600; }
.footer a{ color:var(--mut); display:block; padding-block:6px; transition:color .2s; }
.footer a:hover{ color:var(--white); }
.footer .big-cta{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(2rem,5vw,3.4rem); text-transform:uppercase; line-height:1; color:var(--white); }
.footer .big-cta:hover{ color:var(--red); }
.footer-bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:clamp(50px,7vw,90px); padding-top:26px; border-top:1px solid var(--line); font-size:.8rem; color:var(--mut-2); }

/* ---------- contact form ---------- */
.form{ display:grid; gap:24px; }
.field{ display:flex; flex-direction:column; gap:9px; }
.field label{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--mut); font-weight:600; }
.field input,.field textarea,.field select{
  background:var(--ink-2); border:1px solid var(--line-2); color:var(--white);
  padding:15px 16px; font-family:var(--font-body); font-size:1rem; transition:border-color .25s;
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--red); }
.field textarea{ resize:vertical; min-height:140px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media (max-width:680px){ .field-row{ grid-template-columns:1fr; } }
.form-note{ font-size:.82rem; color:var(--mut-2); }
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ border:1px solid var(--line-2); padding:10px 16px; font-size:.86rem; color:var(--mut); cursor:pointer; transition:.2s; user-select:none; }
.chip:hover{ color:var(--white); border-color:var(--white); }
.chip.on{ background:var(--red); border-color:var(--red); color:#fff; }

/* page hero (subpages) */
.page-hero{ position:relative; padding-top:clamp(150px,18vh,230px); padding-bottom:clamp(50px,7vw,96px); overflow:hidden; }
.page-hero .hero-burst{ opacity:calc(var(--glow)*.1); }
.page-hero h1{ font-size:var(--fs-h1); text-transform:uppercase; }

/* tiny helpers */
.divider{ height:1px; background:var(--line); }
.center{ text-align:center; }
.mt-cta{ margin-top:clamp(40px,5vw,68px); }
.maxw-prose{ max-width:62ch; }
.pill-row{ display:flex; flex-wrap:wrap; gap:12px; }
.pill{ border:1px solid var(--line-2); padding:9px 15px; font-size:.82rem; color:var(--mut); }

/* ---------- waiting-time slider ---------- */
.wait-slider{ margin-top:20px; }
.wait-range{ -webkit-appearance:none; appearance:none; width:100%; height:3px; background:var(--line); border-radius:2px; outline:none; cursor:pointer; }
.wait-range::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--red); border:3px solid var(--ink-1); box-shadow:0 0 0 1px var(--red); cursor:pointer; transition:transform .15s var(--ease); }
.wait-range:hover::-webkit-slider-thumb,.wait-range:focus-visible::-webkit-slider-thumb{ transform:scale(1.12); }
.wait-range::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--red); border:3px solid var(--ink-1); box-shadow:0 0 0 1px var(--red); cursor:pointer; }
.wait-range::-moz-range-track{ height:3px; background:var(--line); border-radius:2px; }
.wait-ticks{ display:flex; margin-top:13px; }
.wait-ticks span{ flex:1; font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; color:var(--mut-2); text-align:center; transition:color .2s; }
.wait-ticks span:first-child{ text-align:left; }
.wait-ticks span:last-child{ text-align:right; }
.wait-ticks span.on{ color:var(--white); font-weight:600; }
.wait-current{ margin-top:15px; font-size:.95rem; color:var(--mut); }
.wait-current strong{ color:var(--red); }
