/* =============================================================
   PLAN A — CASE STUDY STYLES (shared)
   Mirrors the main site design system: Space Grotesk / Inter /
   JetBrains Mono, void/red palette, custom cursor.
   Linked by every page under /case-studies/.
   ============================================================= */
:root{
  --void:#07070a; --concrete:#0f0f14; --steel:#1a1a22;
  --phosphor:#efede6; --mute:#7a7a85;
  --red:#df2228; --red-deep:#a5181c;
  --rule:rgba(239,237,230,.08); --max:1440px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--void);color:var(--phosphor);
  font-family:'Inter',-apple-system,sans-serif;font-weight:300;
  -webkit-font-smoothing:antialiased;cursor:none;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
em{font-style:normal;color:var(--red)}
.max{max-width:var(--max);margin:0 auto;padding:0 40px}

/* ---- custom cursor (matches site) ---- */
#cursor{position:fixed;top:0;left:0;width:10px;height:10px;background:var(--red);
  border-radius:50%;pointer-events:none;z-index:1000;
  transition:width .2s,height .2s,background .2s,border-color .2s;will-change:transform}
#cursor.hover{width:48px;height:48px;background:rgba(223,34,40,.4);border:1px solid var(--red)}
#cursor.zoom::before{content:'VIEW';position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font:500 9px 'JetBrains Mono';letter-spacing:.15em;color:var(--phosphor)}
@media(hover:none){#cursor{display:none} html,body{cursor:auto} a,button{cursor:pointer}}

/* ---- nav (matches site) ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;
  justify-content:space-between;padding:22px 40px;
  background:linear-gradient(180deg,rgba(7,7,10,.92),rgba(7,7,10,.4));
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid var(--rule);transition:background .3s}
nav.solid{background:rgba(7,7,10,.97)}
nav .logo{height:30px;width:auto}
nav .brand{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:24px;
  letter-spacing:-.02em;text-transform:lowercase}
nav .brand .a{color:var(--red)}
.nav-right{display:flex;align-items:center;gap:30px}
.nav-right ul{display:flex;gap:28px;list-style:none}
.nav-right ul a{font:500 14px 'JetBrains Mono';letter-spacing:.14em;text-transform:uppercase;
  color:var(--phosphor);transition:color .2s}
.nav-right ul a:hover,.nav-right ul a.active{color:var(--red)}
.nav-right .begin{padding:13px 24px;background:var(--red);color:var(--phosphor);
  font:500 13px 'JetBrains Mono';letter-spacing:.18em;text-transform:uppercase;border-radius:2px;
  transition:background .25s,transform .25s}
.nav-right .begin:hover{background:var(--red-deep);transform:translateY(-1px)}
@media(max-width:760px){.nav-right ul{display:none}}

/* ---- shared atoms ---- */
.eyebrow{font:500 11px 'JetBrains Mono';letter-spacing:.22em;color:var(--red);
  text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:26px}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--red)}
.num{font:500 11px 'JetBrains Mono';letter-spacing:.22em;color:var(--red);text-transform:uppercase}
.section{padding:120px 0}
h1,h2,h3{font-family:'Space Grotesk',sans-serif;letter-spacing:-.02em;line-height:1.02}

/* ---- breadcrumb ---- */
.crumb{font:500 11px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}
.crumb a:hover{color:var(--phosphor)}
.crumb .sep{color:var(--red);padding:0 8px}

/* ---- detail hero ---- */
.cs-hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.cs-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 28%;transform:scale(1.05)}
.cs-hero .veil{position:absolute;inset:0;
  background:radial-gradient(120% 90% at 72% 24%,rgba(7,7,10,.2),rgba(7,7,10,.78) 55%,var(--void) 92%),
  linear-gradient(180deg,rgba(7,7,10,.6),rgba(7,7,10,.05) 32%,rgba(7,7,10,.92))}
.cs-hero .inner{position:relative;z-index:2;width:100%;padding-bottom:80px}
.cs-hero .tag{font:500 11px 'JetBrains Mono';letter-spacing:.22em;color:var(--red);
  text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:18px}
.cs-hero .tag::before{content:'';width:24px;height:1px;background:var(--red)}
.cs-hero h1{font-weight:700;font-size:clamp(60px,12vw,168px);line-height:.92;letter-spacing:-.03em}
.cs-hero .lede{font-weight:600;color:var(--red);font-size:clamp(22px,4vw,44px);
  letter-spacing:-.02em;margin-top:4px;font-family:'Space Grotesk',sans-serif}
.cs-hero p{max-width:620px;margin-top:22px;color:#cfcfd4;font-size:17px;line-height:1.55}
.cs-hero .meta{display:flex;gap:36px;flex-wrap:wrap;margin-top:30px}
.cs-hero .meta span{font:500 10px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}
.cs-hero .meta b{display:block;color:var(--phosphor);font-size:12px;letter-spacing:.06em;margin-top:6px;font-weight:500}
.scrollcue{position:absolute;left:40px;bottom:30px;z-index:3;font:500 10px 'JetBrains Mono';
  letter-spacing:.3em;color:var(--mute);text-transform:uppercase}

/* ---- intro ---- */
.intro{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:start}
.intro h2{font-weight:600;font-size:clamp(34px,5vw,68px)}
.intro .body p{color:var(--mute);font-size:17px;line-height:1.6;margin-top:18px;max-width:44ch}
.facts{border-top:1px solid var(--rule);margin-top:56px}
.facts .row{display:flex;justify-content:space-between;gap:20px;padding:17px 0;border-bottom:1px solid var(--rule)}
.facts .k{font:500 11px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.facts .v{text-align:right;font-size:14px;color:var(--phosphor);font-weight:300}

/* ---- marquee ---- */
.marquee{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  overflow:hidden;padding:22px 0;background:var(--concrete)}
.marquee .track{display:flex;width:max-content;white-space:nowrap;animation:scroll 40s linear infinite}
.marquee .track span{font-family:'Space Grotesk',sans-serif;font-weight:600;text-transform:uppercase;
  font-size:26px;letter-spacing:.01em;color:var(--steel);padding:0 .5em}
.marquee .track span.on{color:var(--phosphor)}
.marquee .track span.dot{color:var(--red)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- layer section ---- */
.layer{border-top:1px solid var(--rule)}
.layer-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;
  flex-wrap:wrap;margin-bottom:44px}
.layer-head h2{font-weight:600;font-size:clamp(40px,7vw,96px);margin-top:14px}
.layer-head .desc{max-width:440px;color:var(--mute);font-size:15px;line-height:1.55}
.layer-head .desc .t{display:block;margin-top:14px;font:500 10.5px 'JetBrains Mono';
  letter-spacing:.16em;text-transform:uppercase;color:var(--phosphor)}

/* ---- galleries ---- */
.gal{display:grid;gap:16px}
.gal.c2{grid-template-columns:repeat(2,1fr)}
.gal.c3{grid-template-columns:repeat(3,1fr)}
.gal.c4{grid-template-columns:repeat(4,1fr)}
.gal.c5{grid-template-columns:repeat(5,1fr)}
.shot{position:relative;overflow:hidden;background:var(--concrete);border-radius:2px;
  border:1px solid var(--rule);cursor:none;aspect-ratio:9/16}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .6s}
.shot:hover img{transform:scale(1.06);filter:saturate(1.1)}
.shot .cap{position:absolute;left:0;right:0;bottom:0;padding:32px 12px 12px;
  font:500 10px 'JetBrains Mono';letter-spacing:.14em;text-transform:uppercase;color:#fff;
  opacity:0;transition:opacity .3s;background:linear-gradient(180deg,transparent,rgba(0,0,0,.78))}
.shot:hover .cap{opacity:1}

/* ---- play tiles ---- */
.plays{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.play{position:relative;aspect-ratio:16/10;border:1px solid var(--rule);background:var(--concrete);
  display:flex;flex-direction:column;justify-content:space-between;padding:18px;
  transition:.25s;border-radius:2px;cursor:none}
.play:hover{border-color:var(--red);background:var(--steel)}
.play .pico{width:42px;height:42px;border:1px solid var(--phosphor);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:.25s}
.play:hover .pico{background:var(--red);border-color:var(--red)}
.play .pico svg{width:14px;height:14px;fill:var(--phosphor)}
.play .pt{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;line-height:1.15}
.play .pm{font:500 9.5px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-top:6px}

/* ---- embedded film (vertical Vimeo) ---- */
.filmwrap{position:relative;width:100%;max-width:380px;min-height:560px;margin:0 auto;aspect-ratio:9/16;
  border:1px solid var(--rule);border-radius:2px;overflow:hidden;background:var(--concrete);cursor:none}
.filmwrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.filmwrap .film-poster{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease}
.filmwrap:hover .film-poster{transform:scale(1.04)}
.filmwrap .film-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:70px;height:70px;border-radius:50%;border:1px solid var(--phosphor);
  background:rgba(7,7,10,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;cursor:none;transition:background .25s,border-color .25s,transform .25s}
.filmwrap:hover .film-play{background:var(--red);border-color:var(--red);transform:translate(-50%,-50%) scale(1.06)}
.filmwrap .film-play svg{width:24px;height:24px;fill:var(--phosphor);margin-left:3px}
.filmwrap.playing .film-poster,.filmwrap.playing .film-play{display:none}
.fi-cap .vlink{color:var(--phosphor);cursor:none}
.fi-cap .vlink:hover{color:var(--red)}

/* in-site video modal */
.vmodal{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;
  background:rgba(7,7,10,.96);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);padding:28px;cursor:auto}
.vmodal.open{display:flex}
.vmodal-inner{position:relative;height:min(86vh,900px);aspect-ratio:9/16;max-width:94vw;
  border:1px solid var(--rule);border-radius:2px;overflow:hidden;background:#000}
.vmodal-inner iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vmodal-close{position:absolute;top:22px;right:28px;width:50px;height:50px;border-radius:50%;
  border:1px solid rgba(239,237,230,.3);background:transparent;color:var(--phosphor);
  font:300 26px/1 'Inter';cursor:pointer;z-index:2}
.vmodal-close:hover{border-color:var(--red);color:var(--red)}
body.modal-open #cursor{display:none}
body.modal-open{overflow:hidden}

/* film + venue intro side-by-side (portrait video left, text right) */
.film-intro{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:64px;align-items:center}
.film-intro .fi-video{display:flex;flex-direction:column}
.film-intro .fi-cap{color:var(--mute);font:400 11px 'JetBrains Mono';letter-spacing:.06em;
  text-align:center;margin-top:16px}
.film-intro .fi-text h2{font-family:'Space Grotesk',sans-serif;font-weight:600;
  font-size:clamp(34px,5vw,68px);line-height:1.02;margin-bottom:6px}
.film-intro .fi-text p{color:var(--mute);font-size:17px;line-height:1.6;margin-top:20px;max-width:54ch}
@media(max-width:860px){.film-intro{grid-template-columns:1fr;gap:36px;justify-items:center;text-align:left}
  .film-intro .fi-text{width:100%}}

/* ---- press quotes ---- */
.press{background:var(--concrete);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.press .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{border-left:2px solid var(--red);padding:4px 0 4px 22px}
.quote p{font-size:18px;line-height:1.45;color:var(--phosphor);font-style:italic;font-weight:300}
.quote .src{display:block;margin-top:14px;font:500 10px 'JetBrains Mono';letter-spacing:.18em;
  text-transform:uppercase;color:var(--red)}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.stat{padding:36px 26px;border-right:1px solid var(--rule)}
.stat:last-child{border-right:none}
.stat .n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:52px;line-height:1}
.stat .l{font:500 11px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-top:12px}
.stat .s{color:var(--mute);font-size:12.5px;margin-top:6px;line-height:1.4}

/* ---- visit / cta ---- */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.visit h2{font-weight:600;font-size:clamp(38px,6vw,76px)}
.visit .info{margin-top:6px}
.visit .info .row{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--rule)}
.visit .info .k{font:500 11px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.visit .info .v{text-align:right;font-size:14px}
.visit-img{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.visit-img .shot{aspect-ratio:9/16}
.cta{text-align:center;border-top:1px solid var(--rule)}
.cta h2{font-weight:700;font-size:clamp(46px,9vw,128px)}
.cta p{max-width:600px;margin:22px auto 0;color:var(--mute);font-size:17px;line-height:1.55}
.btn{display:inline-block;margin-top:32px;padding:16px 30px;background:var(--red);color:var(--phosphor);
  font:500 14px 'JetBrains Mono';letter-spacing:.16em;text-transform:uppercase;border-radius:2px;
  transition:background .25s,transform .25s}
.btn:hover{background:var(--red-deep);transform:translateY(-1px)}

/* ---- index (listing) page ---- */
.idx-head{padding:160px 0 60px}
.idx-head h1{font-weight:700;font-size:clamp(54px,10vw,150px);line-height:.92}
.idx-head p{color:var(--mute);font-size:18px;max-width:560px;margin-top:24px;line-height:1.55}
.idx-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;padding-bottom:120px}
.cs-card{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;border-radius:2px;
  background:var(--concrete);cursor:none;border:1px solid var(--rule)}
.cs-card .thumb{position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .7s ease;filter:saturate(1.02)}
.cs-card:hover .thumb{transform:scale(1.06)}
.cs-card .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,7,10,.1) 30%,rgba(7,7,10,.88))}
.cs-card .tag{position:absolute;top:22px;left:22px;font:500 10px 'JetBrains Mono';letter-spacing:.2em;
  text-transform:uppercase;color:var(--red);z-index:2}
.cs-card .read{position:absolute;top:22px;right:22px;font:500 10px 'JetBrains Mono';letter-spacing:.15em;
  color:var(--phosphor);padding:6px 10px;border:1px solid var(--rule);border-radius:2px;background:rgba(0,0,0,.3);z-index:2}
.cs-card .meta{position:absolute;left:24px;right:24px;bottom:24px;z-index:2}
.cs-card .meta .t{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:26px;letter-spacing:-.01em;line-height:1.05}
.cs-card .meta .s{font:400 11px 'JetBrains Mono';letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-top:8px}
.cs-card.soon{pointer-events:none}
.cs-card.soon .thumb{filter:grayscale(1) brightness(.5)}
.cs-card.soon .read{color:var(--mute)}

/* ---- footer (matches site) ---- */
footer{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:44px 40px;border-top:1px solid var(--rule);max-width:var(--max);margin:0 auto}
footer span{font:500 10.5px 'JetBrains Mono';letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}
footer .red{color:var(--red)}
footer a:hover{color:var(--phosphor)}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- lightbox ---- */
.lb{position:fixed;inset:0;z-index:200;background:rgba(5,5,7,.95);display:none;
  align-items:center;justify-content:center;padding:40px;cursor:zoom-out;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:90vh;object-fit:contain;border:1px solid var(--rule)}
.lb .x{position:absolute;top:24px;right:30px;font:300 30px/1 'Inter';color:var(--phosphor);cursor:pointer}

/* ---- responsive ---- */
@media(max-width:980px){
  .intro,.visit{grid-template-columns:1fr;gap:36px}
  .gal.c4,.gal.c5{grid-template-columns:repeat(3,1fr)}
  .plays{grid-template-columns:repeat(2,1fr)}
  .press .grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--rule)}
  .idx-grid{grid-template-columns:1fr}
}
@media(max-width:620px){
  .max{padding:0 22px}
  .section{padding:74px 0}
  .gal.c3,.gal.c4,.gal.c5{grid-template-columns:repeat(2,1fr)}
  .plays{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--rule)}
  .scrollcue{display:none}
  nav{padding:16px 22px}
  footer{padding:32px 22px}
}
