:root{
  --ink:#0B0B10; --ink2:#14131c;
  --paper:#E9E3F2; --cream:#EFE7D6;
  --violet:#8E86C9; --violet-deep:#4B4775;
  --mag:#B86A92; --green:#7FA98C;
  --sticker:#34D6C4;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --sans:'Archivo','Helvetica Neue',Arial,sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --script:'Still Time','Mr Dafoe',cursive;
  --display:'Still Time','Mr Dafoe',cursive;
  /* real photographed masking tape (cream on black) — swap here to change all tape at once */
  --tape-img:url("mpq8syys-hf_20260529_002205_da4b2d6d-364a-41ba-a579-ab889443b620.png");
}
@font-face{
  font-family:'Still Time';
  src:url(mppxoy82-still-time.ttf) format('truetype');
  font-weight:400;font-style:normal;font-display:swap;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink); color:var(--cream);
  font-family:var(--sans); font-size:16px; line-height:1.5;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--sticker);color:var(--ink)}

/* ---- print-object wear: lives on EDGES + OBJECTS only. NO global field grain. ---- */
.tape-strip{position:absolute;z-index:6;width:78px;height:30px;pointer-events:none;
  background:var(--tape-img) center/cover no-repeat;mix-blend-mode:screen}
.fold{position:absolute;left:0;right:0;height:0;pointer-events:none;z-index:1;
  border-top:1px solid rgba(255,255,255,.05);box-shadow:0 1px 0 rgba(0,0,0,.45)}
.ring-wear{position:absolute;width:260px;height:260px;border-radius:50%;pointer-events:none;
  border:2px solid rgba(239,231,214,.07);box-shadow:inset 0 0 0 7px rgba(239,231,214,.03);
  mix-blend-mode:screen}
.scuff{position:absolute;pointer-events:none;z-index:5;width:130px;height:3px;
  background:linear-gradient(90deg,transparent,rgba(239,231,214,.55),transparent);
  transform:rotate(-23deg);opacity:.5;filter:blur(.4px)}

/* skip link */
.skip{position:absolute;left:-999px;top:0;z-index:10000;background:var(--paper);color:var(--ink);
  font-family:var(--mono);font-size:12px;padding:10px 14px}
.skip:focus{left:10px;top:10px}

/* tiny corner book pill */
.book-pill{position:fixed;top:18px;right:18px;z-index:9500;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  background:var(--paper);color:var(--ink);text-decoration:none;
  padding:8px 13px;border:1px solid var(--ink);
  box-shadow:3px 3px 0 rgba(52,214,196,.9);transition:transform .15s}
.book-pill:hover{transform:translate(-1px,-1px)}
.book-pill:focus-visible{outline:3px solid var(--sticker);outline-offset:2px}

/* ===================== HERO ===================== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(24px,4vw,64px);overflow:hidden;isolation:isolate;z-index:9100}
.hero-photo{position:absolute;inset:0;z-index:-3}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
/* legibility scrim only — the photo underneath stays clean, untextured */
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:linear-gradient(180deg,rgba(11,11,16,.12) 0%,rgba(11,11,16,.04) 38%,rgba(11,11,16,.82) 100%)}

/* spray script logo */
.logo-svg{width:min(96%,1100px);height:auto;display:block;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.35))}
.logo-img{width:min(92%,1040px);height:auto;display:block;
  filter:drop-shadow(2px 4px 0 rgba(0,0,0,.5)) drop-shadow(0 0 26px rgba(200,162,75,.28))}
.hero-logo{position:absolute;top:clamp(6px,2vw,28px);left:50%;transform:translateX(-50%);width:100%;
  display:flex;justify-content:center;z-index:2;pointer-events:none}

.hero-copy{position:relative;z-index:3;max-width:760px}
.ransom-line{display:table;margin:0 0 5px}
.ransom-line .hl{
  font-family:var(--mono);font-weight:500;color:var(--ink);background:var(--paper);
  font-size:clamp(15px,2.2vw,25px);line-height:1.75;letter-spacing:-.01em;
  padding:.1em .34em;box-decoration-break:clone;-webkit-box-decoration-break:clone;
  box-shadow:2px 2px 0 rgba(0,0,0,.5);
  filter:url(#torn)} /* rough photocopy edge — interior text stays crisp */
.ransom-line:nth-child(1){transform:rotate(-.5deg)}
.ransom-line:nth-child(2){transform:rotate(.4deg);margin-left:6px}
.ransom-line:nth-child(3){transform:rotate(-.3deg)}
.ransom-line:nth-child(4){transform:rotate(.5deg);margin-left:3px}

.nyt{margin-top:18px;display:table}
.nyt .q{font-family:var(--serif);font-style:italic;font-weight:700;color:var(--ink);
  background:var(--cream);font-size:clamp(16px,2.1vw,24px);padding:.12em .4em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;box-shadow:2px 2px 0 rgba(0,0,0,.5)}
.nyt .src{display:block;text-align:right;font-family:var(--serif);font-style:italic;
  color:var(--cream);font-size:13px;margin-top:6px;text-shadow:0 1px 3px #000}

.sticker{position:absolute;right:clamp(20px,4vw,64px);bottom:clamp(20px,4vw,60px);z-index:4;
  background:var(--sticker);color:var(--ink);font-family:var(--mono);font-weight:700;
  padding:9px 14px;transform:rotate(-3deg);box-shadow:3px 3px 0 rgba(0,0,0,.4);line-height:1.15}
.sticker b{font-size:14px;letter-spacing:.12em}
.sticker small{display:block;font-size:11px;letter-spacing:.2em;opacity:.85}
.scroll-cue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:4;
  font-family:var(--mono);font-size:10px;letter-spacing:.35em;color:var(--cream);
  text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:7px;opacity:.8}
.scroll-cue span{width:1px;height:34px;background:var(--cream);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ===================== TITLE STRIP ===================== */
.strip{border-top:1px solid rgba(239,231,214,.3);border-bottom:1px solid rgba(239,231,214,.3);
  padding:14px 20px;text-align:center;font-family:var(--sans);font-weight:600;
  letter-spacing:.06em;font-size:clamp(13px,1.7vw,19px);background:var(--ink2)}
.strip em{font-family:var(--display);font-style:normal;font-weight:400;color:#C8A24B;
  font-size:1.5em;line-height:.7;letter-spacing:.01em;vertical-align:-2px}
.strip .dot{color:var(--sticker);padding:0 .3em}

/* ===================== INTRO COLLAGE ===================== */
.intro{position:relative;padding:clamp(40px,6vw,90px) clamp(20px,4vw,64px);overflow:hidden;isolation:isolate;z-index:9100}
.intro-logo{position:absolute;left:50%;top:clamp(150px,22vw,300px);transform:translateX(-50%);
  width:135%;max-width:1500px;z-index:0;opacity:.5;pointer-events:none;mix-blend-mode:screen}
.portraits{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,26px);
  max-width:1120px;margin:0 auto}
/* photo sits clean + on top; only the taped/torn FRAME carries wear */
.portrait{position:relative;border:1px solid rgba(239,231,214,.4);overflow:visible;background:#000;
  box-shadow:5px 6px 0 rgba(0,0,0,.5)}
.portrait img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.portrait .tape{position:absolute;z-index:4;width:80px;height:30px;
  background:var(--tape-img) center/cover no-repeat;mix-blend-mode:screen}
.portrait .tape.tl{top:-9px;left:18px;transform:rotate(-7deg)}
.portrait .tape.br{bottom:-9px;right:20px;transform:rotate(-5deg)}

.redaction{position:relative;z-index:2;max-width:980px;margin:clamp(26px,3vw,42px) auto 0}
.redaction p{text-align:left;line-height:0;transform-origin:left center} /* left, not justified → each line strip follows text length (ragged right) */
.redaction .hl{font-family:var(--mono);font-weight:500;color:var(--ink);background:var(--paper);
  font-size:clamp(12.5px,1.45vw,16px);line-height:1.78;letter-spacing:-.02em;
  padding:.12em .26em;box-decoration-break:clone;-webkit-box-decoration-break:clone;
  box-shadow:2px 2px 0 rgba(0,0,0,.45),-1.5px 0 0 rgba(52,214,196,.22),1.5px 0 0 rgba(184,106,146,.2)}
  /* dense body block: kept crisp — wear comes from tape + registration shadows, no displacement */
.redaction em{font-family:var(--serif);font-style:italic;font-weight:700;color:var(--ink);
  background:var(--cream);padding:.04em .26em;box-decoration-break:clone;-webkit-box-decoration-break:clone;
  box-shadow:2px 2px 0 rgba(0,0,0,.5)}
/* slight per-line tilt — rotate values ported verbatim from .ransom-line (hero) */
.redaction p:nth-of-type(1){transform:rotate(-.5deg)}
.redaction p:nth-of-type(2){transform:rotate(.4deg);margin-left:6px}
.redaction p:nth-of-type(3){transform:rotate(-.3deg)}
.redaction p:nth-of-type(4){transform:rotate(.5deg);margin-left:3px}
.redaction p:nth-of-type(5){transform:rotate(-.4deg)}
.redaction p:nth-of-type(6){transform:rotate(.35deg);margin-left:4px}

/* ===================== CREDITS ZINE GRID ===================== */
/* the whole credits block sits on a beat-up dark printed surface (EPK pg2):
   matte-paper unevenness in the bg, a dotted tear at the top edge, and a
   directional white scratch/crease overlay — all scoped to .zine only. */
.zine{position:relative;isolation:isolate;overflow:hidden;
  padding:clamp(44px,5.2vw,80px) clamp(20px,4vw,64px) clamp(50px,6vw,90px);
  border-top:1px solid rgba(239,231,214,.18);
  background:
    radial-gradient(130% 70% at 12% 0%, rgba(75,71,117,.13), transparent 55%),
    radial-gradient(90% 60% at 88% 26%, rgba(142,134,201,.07), transparent 60%),
    radial-gradient(42% 30% at 22% 62%, rgba(142,134,201,.10), transparent 70%),
    radial-gradient(38% 26% at 78% 74%, rgba(75,71,117,.16), transparent 72%),
    radial-gradient(30% 40% at 50% 88%, rgba(239,231,214,.045), transparent 70%),
    radial-gradient(80% 55% at 60% 104%, rgba(0,0,0,.55), transparent 70%),
    #0c0c12;
  box-shadow:inset 0 0 130px rgba(0,0,0,.6)}
/* dotted/perforated tear line across the top of the printed surface */
.zine .tear-top{position:absolute;top:0;left:0;right:0;height:15px;z-index:2;pointer-events:none;
  mix-blend-mode:screen;opacity:.55;
  background:
    radial-gradient(circle at 5px 4px, var(--paper) 1.5px, transparent 2px) 0 0/13px 15px repeat-x,
    radial-gradient(circle at 11px 9px, rgba(239,231,214,.55) 1px, transparent 1.6px) 0 0/19px 15px repeat-x}
/* directional white scratches + creases + flecks; screen-blend = bright on the
   dark field, self-masks over light text so copy stays fully legible */
.zine-wear{position:absolute;inset:0;z-index:3;pointer-events:none;mix-blend-mode:screen;opacity:.78}
.zine-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,40px);
  max-width:1320px;margin:0 auto}
.col{display:flex;flex-direction:column;gap:26px}
.block p,.block li{text-shadow:0 1px 0 rgba(0,0,0,.55)} /* faint print-seat onto the worn surface */
.block .h-zine{font-family:var(--sans);font-weight:800;text-transform:uppercase;
  letter-spacing:.07em;font-size:clamp(14px,1.3vw,17px);color:#fff;
  border-bottom:1.5px solid rgba(239,231,214,.42);padding-bottom:7px;margin-bottom:11px}
.block .h-sub{font-family:var(--sans);font-weight:700;color:var(--cream);font-size:13.5px;
  margin:11px 0 4px;letter-spacing:.01em}
.block p,.block li{font-family:var(--sans);font-weight:400;font-size:13px;line-height:1.42;
  color:rgba(239,231,214,.96)}
.block .lead{font-size:13px;line-height:1.48}
.block ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.block li{padding-left:13px;position:relative}
.block li::before{content:"›";position:absolute;left:0;color:var(--sticker);font-weight:700}
.block em{font-family:var(--serif);font-style:italic;font-weight:600;color:var(--cream)}
.block strong{font-family:var(--sans);font-weight:700;color:var(--cream)}
.block .dj-lead{font-weight:700;color:var(--cream)} /* DJ column: bold lead sentence, rest regular (EPK) */
.zine-frame{position:relative;z-index:1;max-width:1320px;margin:0 auto clamp(22px,3vw,38px);
  border:1px solid rgba(239,231,214,.22);padding:12px 16px;text-align:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--violet)}

/* ===================== SELECTED HIGHLIGHTS / RECENT WORK ===================== */
/* press-kit filmography index — sits on the same beat-up dark printed surface as
   the credits zine. distress (vt/grain) is scoped BEHIND crisp text. dense,
   ruled, newspaper-column index of titles. */
.highlights{position:relative;isolation:isolate;overflow:hidden;
  padding:clamp(44px,5.2vw,80px) clamp(20px,4vw,64px) clamp(50px,6vw,90px);
  border-top:1px solid rgba(239,231,214,.18);
  background:
    radial-gradient(120% 60% at 84% 0%, rgba(75,71,117,.14), transparent 56%),
    radial-gradient(70% 50% at 14% 30%, rgba(142,134,201,.08), transparent 62%),
    radial-gradient(40% 30% at 70% 60%, rgba(184,106,146,.07), transparent 70%),
    radial-gradient(80% 55% at 50% 104%, rgba(0,0,0,.5), transparent 70%),
    #0c0c12;
  box-shadow:inset 0 0 130px rgba(0,0,0,.6)}
/* same dotted/perforated tear seam as the zine, on the top edge */
.highlights .tear-top{position:absolute;top:0;left:0;right:0;height:15px;z-index:2;pointer-events:none;
  mix-blend-mode:screen;opacity:.55;
  background:
    radial-gradient(circle at 5px 4px, var(--paper) 1.5px, transparent 2px) 0 0/13px 15px repeat-x,
    radial-gradient(circle at 11px 9px, rgba(239,231,214,.55) 1px, transparent 1.6px) 0 0/19px 15px repeat-x}
.highlights.vt::after,.highlights.vt-grain::before{z-index:0}  /* distress above #0c0c12 bg, below content */
.rw-wrap{position:relative;z-index:1;max-width:1320px;margin:0 auto}

.rw-head{text-align:center;margin-bottom:clamp(22px,3vw,38px)}
.rw-head h2{font-family:var(--display);font-style:normal;font-weight:400;
  font-size:clamp(46px,7.4vw,94px);line-height:1.05;margin-top:6px;color:var(--cream)}
.rw-frame{position:relative;max-width:560px;margin:clamp(16px,2vw,24px) auto 0;
  border:1px solid rgba(239,231,214,.22);padding:11px 16px;text-align:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--violet)}

/* RECENT WORK lead photo — mirrors .portrait frame + tape vocabulary */
.rw-lead{position:relative;width:clamp(260px,34vw,400px);margin:clamp(22px,3vw,40px) auto;
  border:1px solid rgba(239,231,214,.4);background:#000}
.rw-lead img{position:relative;z-index:2;display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.rw-lead figcaption{position:relative;z-index:2;font-family:var(--mono);font-size:9.5px;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(239,231,214,.55);
  padding:8px 12px;border-top:1px solid rgba(239,231,214,.18)}
.rw-lead .tape{position:absolute;z-index:4;width:80px;height:30px;
  background:var(--tape-img) center/cover no-repeat;mix-blend-mode:screen}
.rw-lead .tape.tl{top:-9px;left:18px;transform:rotate(-7deg)}
.rw-lead .tape.br{bottom:18px;right:20px;transform:rotate(-5deg)}

/* category header — mirrors .h-zine, with a mono index sub-label */
.rw-cat{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-bottom:1.5px solid rgba(239,231,214,.42);padding-bottom:7px;
  margin:clamp(34px,4vw,58px) 0 clamp(16px,1.8vw,22px)}
.rw-cat h3{font-family:var(--sans);font-weight:800;text-transform:uppercase;
  letter-spacing:.07em;font-size:clamp(15px,1.4vw,19px);color:#fff}
.rw-cat .rw-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(239,231,214,.55)}

/* RECENT WORK marquee: title (serif italic) + premiere tag (mono accent) */
.rw-list{columns:2;column-gap:clamp(28px,4vw,64px);list-style:none;
  text-shadow:0 1px 0 rgba(0,0,0,.55)}
.rw-list li{break-inside:avoid;padding:6px 0;line-height:1.34;
  border-bottom:1px dotted rgba(239,231,214,.16)}
.rw-list .rw-t{font-family:var(--serif);font-style:italic;font-weight:600;font-size:14.5px;color:var(--cream)}
.rw-list .rw-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--sticker);margin-left:6px;white-space:nowrap}

/* awards callout strip */
.rw-awards{margin-top:clamp(20px,2.4vw,30px);border:1px solid rgba(239,231,214,.2);
  padding:13px 18px;text-align:center;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;line-height:1.7;
  color:rgba(239,231,214,.86);text-shadow:0 1px 0 rgba(0,0,0,.55)}
.rw-awards b{color:var(--sticker);font-weight:700;letter-spacing:.14em}

/* dense filmography index — pure serif-italic title columns */
.rw-index{columns:4;column-gap:clamp(22px,2.6vw,44px);list-style:none;
  text-shadow:0 1px 0 rgba(0,0,0,.55)}
.rw-index li{break-inside:avoid;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:13px;line-height:1.5;color:rgba(239,231,214,.94);padding:2.5px 0}

/* art & cultural — 2-col bulleted list */
.rw-art{columns:2;column-gap:clamp(28px,4vw,56px);list-style:none;text-shadow:0 1px 0 rgba(0,0,0,.55)}
.rw-art li{break-inside:avoid;font-family:var(--sans);font-weight:400;font-size:13px;line-height:1.45;
  color:rgba(239,231,214,.96);padding:4px 0 4px 14px;position:relative}
.rw-art li::before{content:"›";position:absolute;left:0;color:var(--sticker);font-weight:700}
.rw-art em{font-family:var(--serif);font-style:italic;font-weight:600;color:var(--cream)}

/* festivals & fashion prose closer */
.rw-prose{max-width:760px;font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.62;
  color:rgba(239,231,214,.92);text-shadow:0 1px 0 rgba(0,0,0,.55)}
.rw-prose p+p{margin-top:14px}
.rw-prose strong{color:var(--cream);font-weight:700}
.rw-prose em{font-family:var(--serif);font-style:italic;font-weight:600;color:var(--cream)}

@media(max-width:880px){
  .rw-index{columns:2}
  .rw-list,.rw-art{columns:1}
}
@media(max-width:560px){
  .rw-index{columns:1}
}

/* nightlife reuses .highlights surface + .rw-* system; only the photo trio
   and shared-billing chips are new */
.nl-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,22px);
  max-width:1100px;margin:clamp(20px,3vw,40px) auto clamp(26px,3.4vw,46px)}
.nl-fig{position:relative;margin:0;border:1px solid rgba(233,227,242,.5);background:#000;
  box-shadow:0 14px 38px rgba(0,0,0,.5)}
.nl-fig img{position:relative;z-index:2;display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.nl-fig figcaption{position:relative;z-index:2;font-family:var(--mono);font-size:9.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--cream);opacity:.78;
  padding:7px 10px;border-top:1px solid rgba(233,227,242,.18)}
.nl-fig .tape{position:absolute;z-index:4;width:76px;height:28px;
  background:var(--tape-img) center/cover no-repeat;mix-blend-mode:screen}
.nl-fig .tape.tl{top:-9px;left:16px;transform:rotate(-7deg)}
.nl-fig .tape.br{bottom:16px;right:18px;transform:rotate(-5deg)}
.nl-bill{margin-top:clamp(14px,1.8vw,22px);display:flex;flex-wrap:wrap;gap:7px 8px}
.nl-bill .nl-chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;
  color:var(--paper);padding:5px 10px;border:1px solid rgba(239,231,214,.22);
  background:rgba(239,231,214,.04);line-height:1;text-shadow:0 1px 0 rgba(0,0,0,.55)}
@media(max-width:680px){.nl-trio{grid-template-columns:1fr;max-width:420px}}

/* music direction reuses .highlights surface + .rw-* system; only the
   video grid + featured embed are new */
.md-prose{max-width:780px;font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.62;
  color:rgba(239,231,214,.92);text-shadow:0 1px 0 rgba(0,0,0,.55);margin-bottom:clamp(6px,1vw,12px)}
.md-prose em{font-family:var(--serif);font-style:italic;font-weight:600;color:var(--cream)}
.md-feature{position:relative;z-index:2;max-width:900px;margin:clamp(18px,2.4vw,32px) auto;
  border:1px solid rgba(239,231,214,.4);background:#000;box-shadow:0 18px 48px rgba(0,0,0,.55)}
.md-feature iframe{display:block;width:100%;aspect-ratio:16/9;border:0}
.md-feature figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(239,231,214,.6);padding:9px 12px;border-top:1px solid rgba(239,231,214,.18)}
.md-feature figcaption b{color:var(--sticker);font-weight:700;letter-spacing:.16em}
.md-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(12px,1.6vw,20px);
  margin:clamp(14px,1.8vw,24px) 0}
.md-grid.cols-3{grid-template-columns:repeat(3,1fr);max-width:1180px;margin-left:auto;margin-right:auto}
@media(max-width:820px){.md-grid.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.md-grid.cols-3{grid-template-columns:1fr}}
.rw-cat h3 .md-titlesub{display:block;font-size:.6em;letter-spacing:.14em;margin-top:7px;opacity:.82}
.md-vid{position:relative;z-index:2;margin:0;border:1px solid rgba(239,231,214,.36);background:#000;
  box-shadow:0 12px 32px rgba(0,0,0,.5)}
.md-vid iframe,.md-vid video{display:block;width:100%;aspect-ratio:16/9;border:0;background:#000}
.md-vid figcaption{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(239,231,214,.55);padding:6px 9px;border-top:1px solid rgba(239,231,214,.16)}
/* selected-sample credit list — production serif-italic + role mono accent */
.md-credits{columns:1;max-width:640px;margin:0 auto;list-style:none;
  text-shadow:0 1px 0 rgba(0,0,0,.55)}
.md-credits li{break-inside:avoid;padding:7px 0;line-height:1.4;
  border-bottom:1px dotted rgba(239,231,214,.16)}
.md-credits .md-prod{font-family:var(--serif);font-style:italic;font-weight:600;font-size:14.5px;color:var(--cream)}
.md-credits .md-role{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--sticker);margin-top:2px}
@media(max-width:680px){.md-credits{columns:1}}

/* ===================== PRESS & SPONSORSHIPS ===================== */
/* featured anchor quote */
.press-feat{max-width:1000px;margin:0 auto clamp(30px,4vw,50px);text-align:center;position:relative;
  padding:clamp(28px,4vw,48px) clamp(20px,4vw,56px);
  border-top:1.5px solid rgba(239,231,214,.42);border-bottom:1.5px solid rgba(239,231,214,.42)}
.press-feat .pq-quote{font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:clamp(23px,3.4vw,42px);line-height:1.16;color:var(--cream);
  text-shadow:0 1px 0 rgba(0,0,0,.5)}
.press-feat .pq-pub{display:inline-block;margin-top:18px;font-family:var(--sans);
  font-weight:800;letter-spacing:.2em;text-transform:uppercase;font-size:12px;color:var(--sticker)}
/* masonry press wall */
.press-grid{columns:3;column-gap:clamp(18px,2.4vw,30px);max-width:1320px;margin:0 auto}
.pq{break-inside:avoid;margin:0 0 clamp(16px,2vw,24px);
  padding:clamp(15px,1.8vw,21px) clamp(15px,1.8vw,21px) clamp(13px,1.6vw,17px);
  background:rgba(20,19,28,.55);border:1px solid rgba(239,231,214,.16);box-shadow:4px 4px 0 rgba(0,0,0,.4)}
.pq-pub{font-family:var(--sans);font-weight:800;letter-spacing:.13em;text-transform:uppercase;
  font-size:11px;color:var(--cream);padding-bottom:7px;margin-bottom:10px;
  border-bottom:1px solid rgba(239,231,214,.3)}
.pq-quote{font-family:var(--serif);font-style:italic;font-weight:500;font-size:14px;line-height:1.5;
  color:var(--paper);text-shadow:0 1px 0 rgba(0,0,0,.5)}
.pq-src{display:inline-block;margin-top:11px;font-family:var(--mono);font-size:9px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--sticker);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.pq-src:hover{border-color:var(--sticker)}
@media(max-width:980px){.press-grid{columns:2}}
@media(max-width:620px){.press-grid{columns:1}}
/* sponsorship */
.spon{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(22px,3vw,46px);align-items:center;
  max-width:1100px;margin:0 auto;padding-top:clamp(6px,1.2vw,14px)}
.spon-copy .spon-name{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(28px,4vw,52px);
  line-height:1;color:var(--cream);letter-spacing:.01em}
.spon-copy p{font-family:var(--serif);font-style:italic;font-size:15px;line-height:1.55;color:var(--paper);margin-top:12px;
  text-shadow:0 1px 0 rgba(0,0,0,.5)}
.spon-copy .pq-pub{display:block;margin-top:16px}
.spon-vid{position:relative;aspect-ratio:16/9;border:1px solid rgba(239,231,214,.3);
  background:#000;box-shadow:6px 6px 0 rgba(0,0,0,.5)}
.spon-vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:760px){.spon{grid-template-columns:1fr}}
/* podcasts */
.pods{list-style:none;max-width:1100px;margin:0 auto;display:grid;gap:2px}
.pods a{display:flex;align-items:baseline;gap:14px;text-decoration:none;
  padding:14px 0;border-bottom:1px dotted rgba(239,231,214,.2)}
.pods .pod-name{font-family:var(--serif);font-style:italic;font-weight:600;font-size:15.5px;color:var(--cream);flex:1}
.pods .pod-host{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;color:var(--paper);opacity:.7}
.pods .pod-go{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--sticker)}
.pods a:hover .pod-name{color:#fff}

/* ===================== SOUND ===================== */
.sound{position:relative;padding:clamp(40px,5vw,80px) clamp(20px,4vw,64px);overflow:hidden;isolation:isolate}
.sound-bg{position:absolute;inset:0;z-index:-2}
.sound-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.32}
.sound::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,var(--ink) 0%,rgba(11,11,16,.6) 50%,var(--ink) 100%)}
.sound-head{max-width:1100px;margin:0 auto clamp(22px,3vw,36px)}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--sticker)}
.sound-head h2{font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:clamp(34px,6vw,72px);line-height:.95;margin-top:6px;color:var(--cream)}
.sleeves{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);max-width:1100px;margin:0 auto}
.sleeve{position:relative;background:var(--ink2);border:1px solid rgba(239,231,214,.3);
  padding:14px;box-shadow:6px 6px 0 rgba(0,0,0,.5)}
.sleeve:nth-child(2){transform:rotate(.6deg)}
.sleeve:nth-child(3){transform:rotate(-.5deg)}
.sleeve .tape{position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:118px;height:30px;background:var(--tape-img) center/cover no-repeat;mix-blend-mode:screen}
.sleeve .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:rgba(239,231,214,.85);
  margin:6px 2px 10px;text-transform:uppercase}
.sleeve iframe{width:100%;height:120px;display:block;border:0}

/* ===================== FOOTER ===================== */
.foot{position:relative;padding:clamp(50px,7vw,110px) clamp(20px,4vw,64px) 60px;text-align:center;
  border-top:1px solid rgba(239,231,214,.2);overflow:hidden}
.foot-mark{font-family:var(--script);font-size:clamp(60px,15vw,200px);line-height:.8;color:var(--violet);
  opacity:.16;letter-spacing:.01em;margin-bottom:-.15em;pointer-events:none;user-select:none}
.foot .url{display:inline-block;font-family:var(--sans);font-weight:800;font-style:italic;
  background:var(--cream);color:var(--ink);font-size:clamp(20px,3.4vw,38px);
  padding:.12em .5em;transform:rotate(-1deg);box-shadow:3px 3px 0 rgba(0,0,0,.5);text-decoration:none}
.foot .url:focus-visible{outline:3px solid var(--sticker);outline-offset:3px}
.socials{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin:clamp(28px,4vw,46px) 0 22px}
.stamp{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;color:var(--ink);background:var(--paper);padding:9px 14px;
  border:1px solid var(--ink);transform:rotate(-1.2deg);transition:transform .15s,box-shadow .15s;
  box-shadow:2px 2px 0 rgba(0,0,0,.45)}
.socials a:nth-child(even) .stamp,.socials .stamp:nth-child(even){transform:rotate(1deg)}
.stamp:hover{transform:translate(-1px,-1px) rotate(0);box-shadow:3px 3px 0 var(--sticker)}
.stamp:focus-visible{outline:3px solid var(--sticker);outline-offset:2px}
.booking{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:rgba(239,231,214,.7)}
.booking a{color:var(--violet)}
.colophon{margin-top:26px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(239,231,214,.4)}

/* ===================== VINTAGE DISTRESS OVERLAYS ===================== */
/* Three static PNG textures (white distress on solid black) laid as
   screen-blend pseudo-element overlays on the DARK sections only. Under
   `screen` the black backing contributes nothing (0 glow) and only the white
   wear shows. Every overlay sits BEHIND its section's content, so text + all
   <img> photos stay crisp, full-colour and on top. Static PNGs => already
   prefers-reduced-motion safe (no animation). translateZ(0) puts each overlay
   on its own GPU layer so scrolling stays smooth over the long regions. */
:root{
  --wear-fine:.4;    /* fine film scratches + dust — default, most sections */
  --wear-heavy:.18;  /* heavy vinyl/grindhouse wear — hero / accent only     */
  --wear-grain:.3;   /* even film-grain speckle — subtle field pass          */
}
/* scratch layer (::after) — fine by default, heavy variant for the hero */
.vt::after,.vt-heavy::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-repeat:no-repeat;background-position:center;
  background-size:cover;            /* aspect preserved — never stretch-distorted */
  mix-blend-mode:screen;transform:translateZ(0)}
.vt::after{background-image:url("mpq7g45x-scratches-fine.png");opacity:var(--wear-fine)}
.vt-heavy::after{background-image:url("mpq7g45y-scratches-heavy.png");opacity:var(--wear-heavy)}
/* even grain field (::before) — solid-dark sections only, stays off the photos */
.vt-grain::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:url("mpq7g45s-grain-dust.png") center/cover no-repeat;
  mix-blend-mode:screen;opacity:var(--wear-grain);transform:translateZ(0)}
/* per-section stacking — overlay above the section's own dark backdrop, below content */
.hero.vt-heavy::after{z-index:-1}                         /* above photo(-3)+scrim(-2), below copy(z2+) */
.intro.vt::after,.intro.vt-grain::before{z-index:-1}      /* above body field, below logo/portraits/bio  */
.zine.vt::after,.zine.vt-grain::before{z-index:0}         /* above #0c0c12 bg, below grid(z1)/wear(z3)    */
.sound.vt .sound-bg{z-index:-3}                           /* lift photo + scrim so the scratch seats above */
.sound.vt::before{z-index:-2}
.sound.vt::after{z-index:-1}

/* ===================================================================
   PART 3 — HERO ATMOSPHERIC (one reusable treatment, NO frame)
   Revert in one place: remove `hero-vintage` from <header> + this block.
   purple-spot = primary atmosphere (screen drops its black backing);
   grain = a whisper on top; soft edge vignette seats the frame. The
   purple texture's dense centre is pushed low (off Daisy's face).
   =================================================================== */
.hero-vintage .hero-photo::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:url("mpq7g45t-purple-spot-texture.png") center 80%/cover no-repeat;
  mix-blend-mode:screen;opacity:.38}
.hero-vintage .hero-photo::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:url("mpq7g45s-grain-dust.png") center/cover no-repeat;
  mix-blend-mode:screen;opacity:.15}
.hero-vintage::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  box-shadow:inset 0 0 90px rgba(0,0,0,.4)}                  /* soft edge vignette; faces stay bright + sharp */

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

/* ---- responsive ---- */
@media(max-width:880px){
  .zine-grid{grid-template-columns:repeat(2,1fr)}
  .sleeves{grid-template-columns:1fr}
  .portraits{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:560px){
  .zine-grid{grid-template-columns:1fr}
  .portraits{grid-template-columns:1fr;max-width:380px}
  .intro-logo{top:120px;width:160%}
  .book-pill{top:12px;right:12px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .scroll-cue span{animation:none}
  .rv{transition:none;opacity:1;transform:none}
  .ransom-line,.redaction p,.sleeve,.foot .url,.stamp,.sticker{transform:none!important}
}

/* ===================== SITE NAV (multi-page tabs) ===================== */
.sitenav{position:sticky;top:0;z-index:9000;display:flex;align-items:center;
  gap:clamp(10px,1.8vw,26px);flex-wrap:wrap;
  padding:11px clamp(14px,3vw,40px);
  background:rgba(11,11,16,.82);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);
  border-bottom:1px solid rgba(233,227,242,.14)}
.sitenav .wm{font-family:var(--display);font-size:clamp(20px,2.3vw,30px);
  color:var(--cream);line-height:.8;margin-right:auto;text-decoration:none;
  letter-spacing:.5px;padding-right:14px;white-space:nowrap}
.sitenav .wm:hover{color:var(--sticker)}
.sitenav .tabs{display:flex;flex-wrap:wrap;gap:6px 4px;align-items:center}
.sitenav a.tab{font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  color:var(--cream);opacity:.7;padding:6px 10px;border:1px solid transparent;
  transition:opacity .15s,color .15s,background .15s,border-color .15s}
.sitenav a.tab:hover{opacity:1;color:var(--ink);background:var(--cream)}
.sitenav a.tab[aria-current="page"]{opacity:1;color:var(--ink);
  background:var(--sticker);border-color:var(--ink);
  box-shadow:2px 2px 0 rgba(0,0,0,.5);transform:rotate(-1deg)}
@media (max-width:640px){
  .sitenav{gap:8px 0;padding:9px 12px}
  .sitenav .wm{font-size:22px;width:100%;margin-bottom:4px}
  .sitenav a.tab{font-size:10px;padding:5px 7px;letter-spacing:.1em}
}
/* page wrapper so inner pages aren't full-viewport hero height */
.page-main{min-height:60vh}
/* on inner pages the first section shouldn't reserve hero top-padding */
body.inner .strip{margin-top:0}
