:root{
  --ink:#17130f;
  --ink-soft:#201a14;
  --ink-softer:#2a2219;
  --paper:#efe7d8;
  --paper-dim:#e2d7c1;
  --wax:#a8391f;
  --wax-deep:#6e2013;
  --graphite:#a89c87;
  --graphite-dim:#7d7362;
  --brass:#bb9d5c;
  --line:rgba(239,231,216,.16);
  --line-strong:rgba(239,231,216,.32);
  --line-ink:rgba(23,19,15,.18);
  --line-ink-strong:rgba(23,19,15,.38);

  --font-display:'VMS Display','Arial Narrow',sans-serif;
  --font-body:'VMS Serif',Georgia,'Times New Roman',serif;
  --font-mono:'VMS Mono','Courier New',monospace;

  --text-hero:clamp(4.2rem,14vw,11.5rem);
  --text-h2:clamp(2.1rem,6vw,4.25rem);
  --text-h3:clamp(1.35rem,2.6vw,1.9rem);
  --text-quote:clamp(1.5rem,3.4vw,2.35rem);
  --text-body:1.0625rem;
  --text-small:.9rem;
  --text-mono:.72rem;

  --sp-1:.3rem;--sp-2:.6rem;--sp-3:1.1rem;--sp-4:1.8rem;--sp-5:2.8rem;--sp-6:4.5rem;--sp-7:7rem;--sp-8:10rem;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-body);
  font-size:var(--text-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3{margin:0;text-wrap:balance;}
p{margin:0;}
ul{margin:0;padding:0;list-style:none;}
button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer;}
::selection{background:var(--wax);color:var(--paper);}

:focus-visible{outline:2px solid var(--brass);outline-offset:3px;}

.wrap{max-width:1360px;margin-inline:auto;padding-inline:var(--sp-4);}
@media (min-width:900px){.wrap{padding-inline:var(--sp-6);}}

/* grain overlay */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:50;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* mono label / eyebrow */
.eyebrow{
  font-family:var(--font-mono);
  font-size:var(--text-mono);
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--graphite);
}
.eyebrow em{color:var(--brass);font-style:normal;}

/* ---------- NAV ---------- */
.site-nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-3) var(--sp-4);
  background:rgba(23,19,15,.86);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
@media (min-width:900px){.site-nav{padding:var(--sp-3) var(--sp-6);}}
.nav-mark{
  font-family:var(--font-display);font-weight:800;
  font-size:1.05rem;letter-spacing:.02em;
  text-decoration:none;
}
.nav-mark span{color:var(--brass);}
.nav-links{display:none;gap:var(--sp-5);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;}
@media (min-width:760px){.nav-links{display:flex;}}
.nav-links a{text-decoration:none;position:relative;padding-bottom:2px;}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--brass);transition:right .3s var(--ease);}
.nav-links a:hover::after,.nav-links a:focus-visible::after{right:0;}
.nav-links a[aria-current="page"]{color:var(--brass);}
.nav-links a[aria-current="page"]::after{right:0;}
.nav-mobile-cta{display:none;}
@media (max-width:759px){.nav-mobile-cta{display:inline;}}
@media (max-width:759px){
  .nav-links.is-open{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(23,19,15,.97);
    border-bottom:1px solid var(--line);
    padding:var(--sp-4);gap:var(--sp-4);
  }
}
.nav-cta{
  font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--line-strong);padding:.55rem 1rem;text-decoration:none;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
}
.nav-cta:hover{background:var(--paper);color:var(--ink);border-color:var(--paper);}
@media (max-width:759px){.nav-cta{display:none;}}

.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:0;background:none;border:0;cursor:pointer;}
@media (min-width:760px){.nav-toggle{display:none;}}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--paper);transition:transform .25s var(--ease),opacity .25s var(--ease);}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- SECTION / LEDGER RAIL ---------- */
.section{
  padding-block:var(--sp-7);
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:1fr;
  gap:var(--sp-5);
}
@media (min-width:860px){
  .section{grid-template-columns:96px 1fr;column-gap:var(--sp-6);}
}
.rail{
  display:flex;align-items:flex-start;gap:var(--sp-2);
}
@media (min-width:860px){
  .rail{
    writing-mode:vertical-rl;
    text-orientation:mixed;
    transform:rotate(180deg);
    align-items:flex-end;
    height:100%;
  }
}
.rail-tag{font-family:var(--font-mono);font-size:var(--text-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--graphite-dim);white-space:nowrap;}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* index-only: baseline state for the GSAP-driven hero/label sequence (assets/index-anim.js).
   A <noscript> rule in index.html covers the case where JS itself is disabled. */
.gsap-reveal{opacity:0;}
@media (prefers-reduced-motion:reduce){.gsap-reveal{opacity:1;}}

/* ---------- HERO (home) ---------- */
.hero{position:relative;padding-top:var(--sp-6);padding-bottom:var(--sp-7);border-top:none;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-6);align-items:center;}
@media (min-width:900px){.hero-grid{grid-template-columns:1.35fr .9fr;}}
.hero-mark{font-family:var(--font-display);font-weight:800;font-size:var(--text-hero);line-height:.86;letter-spacing:-.03em;margin:0;}
.hero-mark small{display:block;font-family:var(--font-mono);font-weight:500;font-size:clamp(.85rem,1.6vw,1.05rem);letter-spacing:.42em;color:var(--brass);margin-top:var(--sp-3);}
.hero-sub{font-family:var(--font-body);font-style:italic;font-size:var(--text-quote);color:var(--paper);max-width:22ch;margin-top:var(--sp-5);line-height:1.3;}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-5);}
.btn{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:.9rem 1.4rem;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .2s var(--ease);}
.btn-solid{background:var(--paper);color:var(--ink);}
.btn-solid:hover{background:var(--brass);transform:translateY(-2px);}
.btn-ghost{border:1px solid var(--line-strong);}
.btn-ghost:hover{border-color:var(--paper);background:rgba(239,231,216,.06);}
.hero-meta{margin-top:var(--sp-6);display:flex;gap:var(--sp-5);flex-wrap:wrap;font-family:var(--font-mono);font-size:var(--text-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);}
.hero-meta strong{display:block;color:var(--paper);font-size:.95rem;letter-spacing:.02em;margin-bottom:.2rem;font-weight:500;}

/* vinyl */
.vinyl-wrap{position:relative;aspect-ratio:1/1;width:min(100%,420px);margin-inline:auto;}
.vinyl{width:100%;height:100%;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,#100d0a 0 2px,#1c1712 2px 4px);box-shadow:0 30px 60px -20px rgba(0,0,0,.7), inset 0 0 0 1px rgba(239,231,216,.08);position:relative;animation:spin 9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.vinyl{animation:none;}}
.vinyl::before{content:"";position:absolute;inset:34%;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--wax) 0%,var(--wax-deep) 70%);box-shadow:0 0 0 1px rgba(239,231,216,.12);}
.vinyl::after{content:"";position:absolute;inset:47.5%;border-radius:50%;background:var(--ink);box-shadow:0 0 0 1px rgba(239,231,216,.2);}
.vinyl-mark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-weight:800;font-size:.95rem;letter-spacing:.02em;color:var(--paper);z-index:2;}
.vinyl-stamp{position:absolute;right:-6px;bottom:8%;border:1px solid var(--brass);color:var(--brass);font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:.5rem .7rem;transform:rotate(6deg);background:var(--ink);}

/* ---------- PAGE HEAD (artists / contact) ---------- */
.page-head{padding-top:var(--sp-6);padding-bottom:var(--sp-2);}
.page-title{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,9vw,6.5rem);letter-spacing:-.02em;line-height:.92;margin-top:var(--sp-2);}
.page-title.is-compact{font-size:clamp(2.2rem,6vw,4rem);}
.page-lede{font-family:var(--font-body);font-style:italic;font-size:var(--text-quote);color:var(--paper-dim);max-width:28ch;margin-top:var(--sp-4);line-height:1.35;}
.page-lede.is-compact{font-size:1.15rem;max-width:50ch;}

/* ---------- MANIFESTO (home) ---------- */
.quote{font-family:var(--font-body);font-style:italic;font-weight:400;font-size:var(--text-quote);line-height:1.3;color:var(--paper);max-width:20ch;border-left:2px solid var(--wax);padding-left:var(--sp-4);}
.label-body{margin-top:var(--sp-5);display:grid;gap:var(--sp-4);max-width:62ch;}
.label-body p{color:var(--paper-dim);}
.stat-row{margin-top:var(--sp-6);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4);border-top:1px solid var(--line);padding-top:var(--sp-4);max-width:24rem;}
.stat-row div strong{display:block;font-family:var(--font-display);font-weight:800;font-size:1.5rem;}
.stat-row div span{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);}

.empty-note{font-family:var(--font-body);font-style:italic;color:var(--paper-dim);font-size:var(--text-h3);max-width:36ch;padding-block:var(--sp-3);border-top:1px dashed var(--line);}

/* ---------- ARTISTS: grid of cards ---------- */
.artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-5) var(--sp-4);}
.artist-card{display:block;text-decoration:none;color:inherit;}
.artist-card-avatar-wrap{aspect-ratio:1/1;overflow:hidden;background:var(--ink-soft);border:1px solid var(--line);}
.artist-card-avatar{width:100%;height:100%;object-fit:cover;filter:grayscale(85%) contrast(1.05);transition:filter .35s var(--ease),transform .45s var(--ease);}
.artist-card:hover .artist-card-avatar,.artist-card:focus-visible .artist-card-avatar{filter:grayscale(0%);transform:scale(1.04);}
.artist-card-name{display:block;margin-top:var(--sp-3);font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:-.01em;transition:color .2s var(--ease);}
.artist-card:hover .artist-card-name,.artist-card:focus-visible .artist-card-name{color:var(--brass);}
.artist-card-role{display:block;margin-top:.25rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite);}
.artist-grid-note{margin-top:var(--sp-5);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite-dim);}

/* ---------- ARTIST PROFILE ---------- */
.back-btn{display:inline-flex;}
.artist-hero{display:grid;grid-template-columns:1fr;gap:var(--sp-4);margin-top:var(--sp-5);align-items:end;}
@media (min-width:640px){.artist-hero{grid-template-columns:180px 1fr;align-items:center;}}
.artist-hero-avatar{width:100%;max-width:220px;aspect-ratio:1/1;object-fit:cover;border:1px solid var(--line-strong);}
.artist-hero-name{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,6vw,3.8rem);letter-spacing:-.02em;line-height:.95;}
.artist-hero-role{margin-top:.5rem;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite);}
.artist-hero-handle{margin-top:.6rem;font-family:var(--font-body);font-style:italic;font-size:1rem;color:var(--paper-dim);}
.artist-hero-handle a{color:var(--brass);text-decoration:none;border-bottom:1px solid var(--line-strong);}
.artist-hero-handle a:hover{border-color:var(--brass);}

.artist-detail{padding-block:var(--sp-6) var(--sp-7);}
.artist-detail h2{font-family:var(--font-display);font-weight:800;font-size:1.4rem;letter-spacing:-.01em;margin-top:var(--sp-6);margin-bottom:var(--sp-3);}
.artist-detail h2:first-child{margin-top:0;}

.embed-wrap{border:1px solid var(--line);background:var(--ink-soft);}
.embed-wrap iframe{display:block;border:0;}

.embed-gate{position:relative;border:1px solid var(--line);background:var(--ink-soft) center/cover no-repeat;min-height:166px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);text-align:center;padding:var(--sp-4);}
.embed-gate--tall{min-height:340px;}
.embed-gate::before{content:"";position:absolute;inset:0;background:rgba(23,19,15,.66);}
.embed-gate-btn{position:relative;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:.8rem 1.3rem;background:var(--paper);color:var(--ink);border:0;transition:background .2s var(--ease),transform .2s var(--ease);}
.embed-gate-btn:hover{background:var(--brass);transform:translateY(-1px);}
.embed-gate-note{position:relative;font-family:var(--font-body);font-style:italic;font-size:.82rem;color:var(--paper-dim);max-width:36ch;}
.embed-gate-note a{color:var(--brass);}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-5);}
@media (min-width:760px){.contact-grid{grid-template-columns:1fr 1fr;}}
.contact-block h3{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);margin-bottom:.6rem;}
.contact-block a.email{font-family:var(--font-body);font-style:italic;font-size:1.3rem;text-decoration:none;color:var(--paper);border-bottom:1px solid var(--line-strong);transition:border-color .2s var(--ease),color .2s var(--ease);}
.contact-block a.email:hover{border-color:var(--brass);color:var(--brass);}
.contact-block p.note{margin-top:.6rem;color:var(--graphite);font-size:.92rem;max-width:38ch;}

.stub-card{
  margin-top:var(--sp-6);
  background:var(--paper);color:var(--ink);
  padding:var(--sp-4);
  display:grid;gap:var(--sp-3);
  max-width:30rem;
  position:relative;
  box-shadow:0 20px 45px -25px rgba(0,0,0,.6);
}
@media (min-width:620px){.stub-card{grid-template-columns:1fr auto;align-items:center;}}
.stub-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:8px;
  background-image:repeating-linear-gradient(90deg,var(--ink) 0 6px,transparent 6px 14px);
  mask-image:radial-gradient(circle 4px at center,transparent 96%,black 100%);
  mask-size:14px 14px;mask-repeat:repeat-x;mask-position:top;
  opacity:.3;
}
.stub-card address{font-style:normal;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;line-height:1.7;color:#4a4238;}
.stub-card .stamp{border:1px solid var(--wax);color:var(--wax);font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:.5rem .7rem;transform:rotate(-4deg);justify-self:start;white-space:nowrap;}

.social-row{margin-top:var(--sp-6);display:flex;flex-wrap:wrap;gap:var(--sp-4);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;}
.social-row a{text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color .2s var(--ease);}
.social-row a:hover{border-color:var(--paper);}

/* ---------- FOOTER ---------- */
.site-footer{padding:var(--sp-4) var(--sp-4) var(--sp-5);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--sp-3);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite-dim);}
@media (min-width:900px){.site-footer{padding-inline:var(--sp-6);}}
.site-footer a{text-decoration:none;color:inherit;}
.site-footer a:hover{color:var(--paper);}
.footer-legal{display:flex;gap:var(--sp-4);flex-wrap:wrap;}

/* ---------- LEGAL DOCS ---------- */
.legal-content{max-width:68ch;padding-block:var(--sp-6) var(--sp-7);}
.legal-content h2{font-family:var(--font-display);font-weight:800;font-size:1.4rem;letter-spacing:-.01em;margin-top:var(--sp-6);margin-bottom:var(--sp-3);}
.legal-content h2:first-child{margin-top:0;}
.legal-content p{color:var(--paper-dim);margin-top:var(--sp-3);line-height:1.7;}
.legal-content p:first-of-type{margin-top:0;}
.legal-content a{color:var(--brass);text-decoration:underline;text-underline-offset:2px;}
.legal-content .todo{color:var(--wax);font-family:var(--font-mono);font-size:.82em;background:rgba(168,57,31,.14);padding:.05em .35em;}
.legal-meta{margin-top:var(--sp-6);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--graphite-dim);}

/* ---------- NOTICE BANNER ---------- */
.notice-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:var(--ink-soft);border-top:1px solid var(--line-strong);
  padding:var(--sp-3) var(--sp-4);
  display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:center;justify-content:space-between;
}
@media (min-width:900px){.notice-banner{padding-inline:var(--sp-6);}}
.notice-banner[hidden]{display:none;}
.notice-banner p{font-family:var(--font-body);font-style:italic;font-size:.95rem;color:var(--paper-dim);max-width:64ch;}
.notice-banner a{color:var(--brass);text-decoration:underline;text-underline-offset:2px;}
.notice-banner button{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line-strong);padding:.55rem 1rem;white-space:nowrap;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);}
.notice-banner button:hover{background:var(--paper);color:var(--ink);border-color:var(--paper);}
