@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=IBM+Plex+Mono:ital,wght@0,300;0,400;0,700;1,400&family=Playfair+Display:ital,wght@0,400;1,400;1,700&display=swap');

:root {
  --bg:      #080604;
  --surface: #0f0c0a;
  --paper:   #e8ddd0;
  --red:     #8b2e1e;
  --red-dim: rgba(139,46,30,0.3);
  --mid:     #5a4f47;
  --dim:     #2a1f1a;
  --ghost:   rgba(232,221,208,0.06);
  --border:  rgba(232,221,208,0.08);
  --f-disp:  'Bebas Neue', sans-serif;
  --f-mono:  'IBM Plex Mono', monospace;
  --f-serif: 'Playfair Display', serif;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:  cubic-bezier(0.7, 0, 0.84, 0);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html { scroll-behavior:smooth; font-size:17px; }
body { background:var(--bg); color:var(--paper); font-family:var(--f-mono); font-weight:300; overflow-x:hidden; cursor:crosshair; }
img { display:block; width:100%; height:100%; object-fit:cover; }
button { cursor:pointer; font-family:var(--f-mono); }

/* ── GRAIN ── */
#grain {
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:150px; opacity:0.05; mix-blend-mode:overlay;
}

/* ── CURSOR ── */
#cursor {
  position:fixed; z-index:8999;
  width:10px; height:10px;
  background:var(--red); border-radius:50%;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .18s, height .18s, opacity .18s;
  mix-blend-mode:difference;
  left:-100px; top:-100px;
}
#cursor.big { width:48px; height:48px; background:var(--paper); opacity:0.12; }
@media (pointer:coarse) { #cursor { display:none; } body { cursor:auto; } }

/* ── LOADER ── */
#loader {
  position:fixed; inset:0; z-index:9998;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:20px;
  transition:opacity 0.7s var(--ease-in);
}
#loader.out { opacity:0; pointer-events:none; }
.loader-logo {
  font-family:var(--f-disp);
  font-size:clamp(56px,12vw,120px);
  letter-spacing:.18em; color:transparent;
  -webkit-text-stroke:1px rgba(232,221,208,0.18);
  animation:loader-pulse 1.2s ease-in-out infinite;
}
.loader-logo .n { -webkit-text-stroke-color:rgba(139,46,30,0.5); }
@keyframes loader-pulse { 0%,100%{opacity:0.3} 50%{opacity:1} }
.loader-bar { width:140px; height:1px; background:var(--dim); position:relative; overflow:hidden; }
.loader-bar::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:var(--red); animation:loader-fill 1.8s var(--ease-out) forwards; }
@keyframes loader-fill { to { left:0; } }

/* ── TICKER ── */
#ticker {
  position:fixed; top:0; left:0; right:0; z-index:500;
  height:30px; background:var(--red);
  overflow:hidden; white-space:nowrap;
  display:flex; align-items:center;
}
.ticker-track {
  display:inline-flex;
  animation:ticker-roll 26s linear infinite;
}
.ticker-track span {
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bg); padding:0 24px; flex-shrink:0;
}
@keyframes ticker-roll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── NAV ── */
#nav {
  position:fixed; top:30px; left:0; right:0; z-index:499;
  height:60px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(18px,4vw,56px);
  transition:background 0.3s, border-color 0.3s;
  border-bottom:1px solid transparent;
}
#nav.solid { background:rgba(8,6,4,0.95); border-bottom-color:var(--border); backdrop-filter:blur(16px); }
.nav-logo {
  font-family:var(--f-disp);
  font-size:clamp(22px,3.2vw,32px);
  letter-spacing:.2em; color:var(--paper); text-decoration:none;
  position:relative;
}
.nav-logo .n { color:var(--red); }
.nav-logo::after { content:''; position:absolute; left:0; bottom:-3px; width:0; height:1px; background:var(--red); transition:width 0.3s var(--ease-out); }
.nav-logo:hover::after { width:100%; }
.nav-links { display:flex; list-style:none; gap:0; }
.nav-links button {
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(232,221,208,0.4); background:transparent; border:none;
  padding:8px 14px; transition:color 0.15s;
}
.nav-links button:hover, .nav-links button.active { color:var(--paper); }
.nav-right { display:flex; align-items:center; gap:10px; }
.nav-cta {
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--red); border:1px solid var(--red); background:transparent;
  padding:7px 16px; transition:all 0.2s;
}
.nav-cta:hover { background:var(--red); color:var(--bg); }
.nav-menu-btn { display:none; background:transparent; border:none; flex-direction:column; gap:6px; padding:4px; }
.nav-menu-btn span { display:block; width:22px; height:1px; background:var(--paper); transition:all 0.3s; }
@media (max-width:800px) { .nav-links{display:none} .nav-menu-btn{display:flex} .nav-cta{display:none} }

/* Mobile drawer */
#mobile-drawer {
  position:fixed; top:90px; left:0; right:0; z-index:498;
  background:rgba(8,6,4,0.97); border-bottom:1px solid var(--border);
  padding:16px 0; transform:translateY(-120%); transition:transform 0.35s var(--ease-out);
}
#mobile-drawer.open { transform:translateY(0); }
#mobile-drawer button {
  display:block; width:100%;
  font-size:12px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--mid); background:transparent; border:none;
  padding:16px clamp(18px,4vw,56px); text-align:left;
  border-bottom:1px solid var(--border); transition:color 0.15s;
}
#mobile-drawer button:hover { color:var(--paper); }

/* ── SECTIONS ── */
.section { padding-top:90px; }

/* ── COVER ── */
#cover {
  position:relative; height:100vh; min-height:640px;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
}
#cover-canvas {
  position:absolute; inset:0; z-index:1;
  pointer-events:none;
}
.cover-bg {
  position:absolute; inset:0; z-index:0;
  background-image:url('/images/dj-bw.jpg');
  background-size:cover; background-position:center;
  transform:scale(1.06); transition:transform 8s var(--ease-out);
}
#cover.loaded .cover-bg { transform:scale(1); }
.cover-overlay {
  position:absolute; inset:0; z-index:2;
  background:
    linear-gradient(to top, rgba(8,6,4,0.97) 0%, rgba(8,6,4,0.6) 42%, rgba(8,6,4,0.2) 100%),
    linear-gradient(to right, rgba(8,6,4,0.45) 0%, transparent 65%);
}
.cover-content {
  position:relative; z-index:3;
  padding:clamp(28px,5vw,72px); padding-bottom:clamp(48px,7vh,80px);
  max-width:900px;
}
.cover-badge {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--red); padding:5px 14px;
  font-size:11px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--bg); margin-bottom:20px;
}
.cover-badge::before { content:'▪'; font-size:11px; }
.cover-h1 {
  font-family:var(--f-disp);
  font-size:clamp(100px,17vw,220px);
  line-height:.83; letter-spacing:.02em; color:var(--paper);
  opacity:0; transform:translateY(32px);
  transition:opacity 0.9s 0.3s var(--ease-out), transform 0.9s 0.3s var(--ease-out);
}
#cover.loaded .cover-h1 { opacity:1; transform:translateY(0); }
.cover-h1 .r { color:var(--red); }
.cover-sub {
  font-family:var(--f-serif); font-style:italic;
  font-size:clamp(16px,2.2vw,24px); line-height:1.5;
  color:rgba(232,221,208,0.65); max-width:560px; margin-top:20px;
  opacity:0; transform:translateY(20px);
  transition:opacity 0.9s 0.5s var(--ease-out), transform 0.9s 0.5s var(--ease-out);
}
#cover.loaded .cover-sub { opacity:1; transform:translateY(0); }
.cover-tags { display:flex; flex-wrap:wrap; gap:9px; margin-top:24px; opacity:0; transition:opacity 0.9s 0.7s var(--ease-out); }
#cover.loaded .cover-tags { opacity:1; }
.cover-tag {
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(232,221,208,0.3); border:1px solid rgba(232,221,208,0.12); padding:5px 12px;
}
.cover-stamp {
  position:absolute; top:clamp(80px,12vh,130px); right:clamp(18px,4vw,56px);
  text-align:right; z-index:3;
}
.stamp-num { font-family:var(--f-disp); font-size:clamp(90px,16vw,200px); color:rgba(232,221,208,0.04); line-height:1; letter-spacing:.04em; }
.stamp-label { font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:rgba(232,221,208,0.16); margin-top:4px; }
.cover-scroll-hint {
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  font-size:11px; letter-spacing:.26em; text-transform:uppercase;
  color:rgba(232,221,208,0.2); display:flex; flex-direction:column; align-items:center; gap:9px;
  animation:pulse 2s ease-in-out infinite; z-index:3;
}
.cover-scroll-hint::after { content:''; width:1px; height:36px; background:linear-gradient(to bottom, rgba(232,221,208,0.3), transparent); }
@keyframes pulse { 0%,100%{opacity:0.3} 50%{opacity:1} }

/* ── STATS BAR ── */
.stats-bar { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
@media(max-width:500px) { .stats-bar{grid-template-columns:repeat(2,1fr)} }
.stat-cell { padding:clamp(18px,2.5vw,28px) clamp(18px,3vw,36px); border-right:1px solid var(--border); }
.stat-cell:last-child { border-right:none; }
.stat-n { font-family:var(--f-disp); font-size:clamp(36px,5vw,60px); letter-spacing:.04em; color:var(--paper); line-height:1; }
.stat-n.accent { color:var(--red); }
.stat-label { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--dim); margin-top:5px; }

/* ── SECTION HEADER ── */
.sec-head { display:flex; align-items:baseline; justify-content:space-between; padding:clamp(16px,2vw,22px) clamp(18px,4vw,56px); border-bottom:1px solid var(--border); }
.sec-label { font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--red); display:flex; align-items:center; gap:9px; }
.sec-label::before { content:''; width:20px; height:1.5px; background:var(--red); flex-shrink:0; }
.sec-count { font-size:11px; letter-spacing:.14em; color:var(--dim); }

/* ── FILTER BAR ── */
.filter-bar { display:flex; overflow-x:auto; scrollbar-width:none; border-bottom:1px solid var(--border); padding:0 clamp(18px,4vw,56px); }
.filter-bar::-webkit-scrollbar { display:none; }
.filter-btn { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); background:transparent; border:none; padding:14px 18px; white-space:nowrap; border-bottom:2px solid transparent; transition:color 0.15s, border-color 0.15s; }
.filter-btn:hover { color:var(--mid); }
.filter-btn.active { color:var(--paper); border-bottom-color:var(--red); }

/* ── ARTICLE GRID ── */
#article-grid { display:grid; grid-template-columns:repeat(3,1fr); border-bottom:1px solid var(--border); }
@media(max-width:900px) { #article-grid{grid-template-columns:1fr 1fr} }
@media(max-width:560px) { #article-grid{grid-template-columns:1fr} }
.article-card { border-right:1px solid var(--border); border-bottom:1px solid var(--border); cursor:pointer; overflow:hidden; transition:background 0.2s; }
.article-card:hover { background:var(--ghost); }
.article-card:nth-child(3n) { border-right:none; }
@media(max-width:900px) { .article-card:nth-child(2n){border-right:none} }
.article-card.featured { grid-column:span 2; display:grid; grid-template-columns:1fr 1fr; }
@media(max-width:560px) { .article-card.featured{grid-column:span 1;grid-template-columns:1fr} }
.card-photo { position:relative; overflow:hidden; aspect-ratio:4/3; background:var(--surface); }
.article-card.featured .card-photo { aspect-ratio:unset; height:100%; min-height:260px; }
.card-photo img { transition:transform 0.6s var(--ease-out); }
.article-card:hover .card-photo img { transform:scale(1.05); }
.card-photo-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(8,6,4,0.7) 0%, transparent 55%); }
.card-body { padding:clamp(16px,2.5vw,28px); }
.article-card.featured .card-body { padding:clamp(22px,3vw,40px); display:flex; flex-direction:column; justify-content:flex-end; }
.card-cat { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--red); display:flex; align-items:center; gap:7px; margin-bottom:10px; }
.card-cat::before { content:''; width:12px; height:1px; background:var(--red); flex-shrink:0; }
.card-title { font-family:var(--f-disp); font-size:clamp(22px,2.8vw,34px); line-height:.95; letter-spacing:.03em; color:var(--paper); margin-bottom:10px; }
.article-card.featured .card-title { font-size:clamp(28px,4.2vw,54px); }
.card-rule { width:0; height:1px; background:var(--red); transition:width 0.4s var(--ease-out); margin-bottom:10px; }
.article-card:hover .card-rule { width:100%; }
@media(pointer:coarse) { .card-rule{width:44px} }
.card-excerpt { font-size:13px; line-height:1.75; color:var(--mid); max-height:0; overflow:hidden; transition:max-height 0.35s var(--ease-out); }
.article-card:hover .card-excerpt { max-height:80px; }
.article-card.featured .card-excerpt { max-height:80px; }
@media(pointer:coarse) { .card-excerpt{max-height:60px} }
.card-meta { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); display:flex; gap:14px; margin-top:12px; }
.no-results { padding:56px; text-align:center; grid-column:1/-1; font-size:12px; letter-spacing:.26em; text-transform:uppercase; color:var(--dim); }

/* ── READER ── */
#reader { display:none; border-bottom:1px solid var(--border); }
#reader.visible { display:block; }
.reader-back { display:flex; align-items:center; gap:9px; padding:16px clamp(18px,4vw,56px); border-bottom:1px solid var(--border); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--mid); background:transparent; border-left:none; border-right:none; border-top:none; width:100%; text-align:left; transition:color 0.15s; }
.reader-back:hover { color:var(--paper); }
.reader-hero { position:relative; aspect-ratio:21/8; overflow:hidden; min-height:300px; }
@media(max-width:600px) { .reader-hero{aspect-ratio:4/3} }
.reader-hero img { object-position:center 20%; }
.reader-hero-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(8,6,4,0.92) 0%, rgba(8,6,4,0.3) 60%, rgba(8,6,4,0.1) 100%); }
.reader-hero-text { position:absolute; bottom:0; left:0; right:0; padding:clamp(22px,3vw,52px) clamp(18px,4vw,56px); }
.reader-kicker { font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--red); margin-bottom:14px; display:flex; align-items:center; gap:9px; }
.reader-kicker::before { content:''; width:22px; height:1px; background:var(--red); }
.reader-title { font-family:var(--f-disp); font-size:clamp(52px,9vw,108px); line-height:.88; letter-spacing:.02em; color:var(--paper); }
.reader-byline { font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:rgba(232,221,208,0.4); margin-top:14px; display:flex; gap:18px; flex-wrap:wrap; }
.reader-body { display:grid; grid-template-columns:210px 1fr; border-bottom:1px solid var(--border); }
@media(max-width:700px) { .reader-body{grid-template-columns:1fr} }
.reader-sidebar { border-right:1px solid var(--border); padding:36px 22px; position:sticky; top:90px; height:fit-content; }
@media(max-width:700px) { .reader-sidebar{display:none} }
.sidebar-label { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--dim); margin-bottom:16px; }
.sidebar-tag { display:block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); padding:8px 0; border-bottom:1px solid var(--border); transition:color 0.15s; cursor:pointer; }
.sidebar-tag:hover { color:var(--mid); }
.reader-content { padding:clamp(32px,4vw,60px) clamp(22px,4vw,68px); max-width:740px; }
.reader-lead { font-family:var(--f-serif); font-style:italic; font-size:clamp(18px,2.4vw,24px); line-height:1.52; color:var(--paper); padding-bottom:28px; margin-bottom:28px; border-bottom:1px solid var(--border); }
.reader-content p { font-size:clamp(14px,1.7vw,16px); line-height:1.95; color:var(--mid); margin-bottom:20px; font-weight:300; }
.reader-content p.drop::first-letter { font-family:var(--f-disp); font-size:4.4em; float:left; line-height:.8; margin-right:9px; margin-top:6px; color:var(--paper); }
.reader-content h3 { font-family:var(--f-disp); font-size:clamp(26px,3.2vw,42px); letter-spacing:.04em; color:var(--paper); margin:34px 0 12px; }
.reader-pullquote { border-top:1px solid rgba(232,221,208,0.22); border-bottom:1px solid rgba(232,221,208,0.22); padding:clamp(16px,2.5vw,26px) 0; margin:32px 0; font-family:var(--f-serif); font-style:italic; font-size:clamp(18px,2.8vw,26px); line-height:1.38; color:var(--paper); }
.reader-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:28px; padding-top:20px; border-top:1px solid var(--border); }
.reader-tag { font-size:8px; letter-spacing:.15em; text-transform:uppercase; border:1px solid var(--border); padding:5px 10px; color:var(--dim); transition:all 0.15s; cursor:pointer; }
.reader-tag:hover { border-color:var(--red); color:var(--paper); }
.reader-related { padding:clamp(28px,3vw,44px) clamp(18px,4vw,56px); }
.related-grid { display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--border); margin-top:18px; }
@media(max-width:700px) { .related-grid{grid-template-columns:1fr} }

/* ── INTERSTITIAL ── */
.interstitial { position:relative; height:62vh; min-height:420px; overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end; }
.interstitial-bg { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); transition:transform 0.6s var(--ease-out); }
.interstitial:hover .interstitial-bg { transform:scale(1); }
.interstitial-overlay { position:absolute; inset:0; }
.interstitial-content { position:relative; z-index:2; padding:clamp(26px,4vw,56px); }
.int-eyebrow { font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--red); display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.int-eyebrow::before { content:''; width:20px; height:1px; background:var(--red); }
.int-title { font-family:var(--f-disp); font-size:clamp(60px,10vw,130px); line-height:.88; letter-spacing:.02em; color:var(--paper); text-shadow:0 2px 30px rgba(0,0,0,0.6); }
.int-title .r { color:var(--red); }
.int-cta { display:inline-block; margin-top:20px; font-size:9px; letter-spacing:.24em; text-transform:uppercase; color:var(--paper); border:1px solid rgba(232,221,208,0.3); padding:9px 20px; background:transparent; transition:all 0.2s var(--ease-out); }
.int-cta:hover { background:var(--paper); color:var(--bg); border-color:var(--paper); }

/* ── BRANDS ── */
#brands-section { border-bottom:1px solid var(--border); }
.brands-header { display:grid; grid-template-columns:1fr 1fr; border-bottom:1px solid var(--border); }
@media(max-width:640px) { .brands-header{grid-template-columns:1fr} }
.bh-left { padding:clamp(26px,4vw,56px); border-right:1px solid var(--border); }
.bh-title { font-family:var(--f-disp); font-size:clamp(68px,10vw,144px); line-height:.85; letter-spacing:.02em; }
.bh-title .r { color:var(--red); }
.bh-right { padding:clamp(26px,4vw,56px); display:flex; flex-direction:column; justify-content:flex-end; }
.bh-right p { font-size:15px; line-height:1.85; color:var(--mid); max-width:480px; font-weight:300; }
.brands-grid { display:grid; grid-template-columns:repeat(4,1fr); }
@media(max-width:900px) { .brands-grid{grid-template-columns:1fr 1fr} }
@media(max-width:480px) { .brands-grid{grid-template-columns:1fr} }
.brand-card { border-right:1px solid var(--border); border-bottom:1px solid var(--border); padding:clamp(18px,2.5vw,28px); cursor:pointer; transition:background 0.15s; }
.brand-card:nth-child(4n) { border-right:none; }
@media(max-width:900px) { .brand-card:nth-child(2n){border-right:none} }
.brand-card:hover { background:var(--ghost); }
.brand-logo { aspect-ratio:3/2; background:var(--surface); display:flex; align-items:center; justify-content:center; font-family:var(--f-disp); font-size:clamp(20px,3vw,34px); color:var(--dim); letter-spacing:.1em; margin-bottom:16px; border:1px solid var(--border); transition:color 0.2s; }
.brand-card:hover .brand-logo { color:rgba(232,221,208,0.4); }
.brand-city { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:4px; }
.brand-name { font-family:var(--f-disp); font-size:clamp(18px,2.4vw,26px); letter-spacing:.05em; color:var(--paper); margin-bottom:6px; }
.brand-desc { font-size:13px; line-height:1.68; color:var(--dim); }

/* Brand overlay */
#brand-overlay { position:fixed; inset:0; z-index:900; background:rgba(8,6,4,0.93); display:none; align-items:center; justify-content:center; }
#brand-overlay.open { display:flex; }
.brand-panel { width:min(720px,95vw); max-height:88vh; overflow-y:auto; background:var(--bg); border:1px solid var(--border); -webkit-overflow-scrolling:touch; }
.brand-panel::-webkit-scrollbar { width:3px; }
.brand-panel::-webkit-scrollbar-thumb { background:var(--border); }
@media(max-width:580px) { #brand-overlay{align-items:flex-end} .brand-panel{width:100%;max-height:88vh;border:none;border-top:1px solid var(--border)} }
.bpanel-bar { position:sticky; top:0; z-index:2; display:flex; justify-content:space-between; align-items:center; padding:16px 26px; background:var(--bg); border-bottom:1px solid var(--border); }
.bpanel-tag { font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--mid); }
.bpanel-close { font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--mid); background:transparent; border:none; transition:color 0.15s; }
.bpanel-close:hover { color:var(--paper); }
.bpanel-body { padding:clamp(22px,3.5vw,44px); }
.bp-city { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--red); margin-bottom:7px; }
.bp-name { font-family:var(--f-disp); font-size:clamp(44px,8vw,76px); line-height:.9; color:var(--paper); margin-bottom:16px; }
.bp-desc { font-size:14px; line-height:1.8; color:var(--mid); margin-bottom:16px; }
.bp-story { font-size:14px; line-height:1.92; color:var(--mid); font-weight:300; margin-bottom:22px; }
.bp-meta { display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--border); }
.bp-cell { padding:13px 0; border-bottom:1px solid var(--border); }
.bp-cell:nth-child(odd) { padding-right:16px; }
.bp-cell:nth-child(even) { padding-left:16px; border-left:1px solid var(--border); }
.bp-label { font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); margin-bottom:4px; }
.bp-val { font-family:var(--f-disp); font-size:19px; letter-spacing:.05em; }

/* ── MUSIC ── */
#music-section { border-bottom:1px solid var(--border); }
.music-hero { position:relative; height:clamp(320px,52vh,520px); overflow:hidden; }
.music-hero-img { position:absolute; inset:0; background-image:url('/images/desi-dj.jpg'); background-size:cover; background-position:center 30%; filter:contrast(1.1) brightness(0.8); }
.music-hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(8,6,4,0.2) 0%, rgba(8,6,4,0.97) 100%); }
.music-hero-content { position:absolute; bottom:0; left:0; right:0; padding:clamp(26px,4vw,56px); }
.music-big { font-family:var(--f-disp); font-size:clamp(80px,15vw,190px); line-height:.85; letter-spacing:.02em; color:var(--paper); }
.music-big .r { color:var(--red); }
.music-sub { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:rgba(232,221,208,0.4); margin-top:14px; }
.music-layout { display:grid; grid-template-columns:2fr 1fr; border-bottom:1px solid var(--border); }
@media(max-width:760px) { .music-layout{grid-template-columns:1fr} }
.music-feature { border-right:1px solid var(--border); padding:clamp(26px,4vw,52px); }
.music-feature-title { font-family:var(--f-disp); font-size:clamp(36px,5.5vw,66px); line-height:.9; letter-spacing:.03em; margin-bottom:16px; }
.music-feature-text { font-size:15px; line-height:1.88; color:var(--mid); max-width:480px; margin-bottom:24px; font-weight:300; }
.music-embed { background:var(--surface); border:1px solid var(--border); }
.music-embed-label { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); padding:9px 14px; border-bottom:1px solid var(--border); }
.music-embed iframe { width:100%; display:block; border:none; }
.track-row { display:flex; align-items:center; gap:14px; padding:clamp(14px,1.8vw,20px) clamp(18px,3vw,30px); border-bottom:1px solid var(--border); cursor:pointer; transition:background 0.12s; }
.track-row:hover { background:var(--ghost); }
.track-row.playing { background:rgba(139,46,30,0.08); }
.tr-num { font-family:var(--f-disp); font-size:24px; color:rgba(232,221,208,0.1); min-width:28px; transition:color 0.15s; }
.track-row.playing .tr-num { color:var(--red); }
.tr-info { flex:1; }
.tr-name { font-family:var(--f-disp); font-size:clamp(17px,2.2vw,24px); letter-spacing:.04em; color:var(--paper); }
.tr-artist { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--mid); margin-top:3px; }
.tr-bar { height:1px; width:0; background:var(--red); transition:width 0.4s var(--ease-out); margin-top:6px; }
.track-row:hover .tr-bar, .track-row.playing .tr-bar { width:100%; }
.tr-genre { font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--red); flex-shrink:0; }
.music-player { padding:14px; background:var(--surface); border-top:1px solid var(--border); }
.music-player iframe { width:100%; display:block; border:none; }

/* ══════════════════════════════════════════
   NEWSLETTER SECTION — 3D VINYL
══════════════════════════════════════════ */
#newsletter-section {
  position:relative;
  min-height:100vh;
  overflow:hidden;
  display:flex; align-items:center;
  border-bottom:1px solid var(--border);
  padding-top:0;
}
#vinyl-canvas {
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
}
.nl-overlay {
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to right, rgba(8,6,4,0.97) 0%, rgba(8,6,4,0.75) 50%, rgba(8,6,4,0.2) 100%),
    linear-gradient(to bottom, rgba(8,6,4,0.5) 0%, transparent 30%, transparent 70%, rgba(8,6,4,0.5) 100%);
}
.nl-inner {
  position:relative; z-index:2;
  display:grid; grid-template-columns:1fr 1fr;
  width:100%; gap:0;
  align-items:center;
  padding:clamp(80px,10vh,120px) 0;
}
@media(max-width:800px) { .nl-inner{grid-template-columns:1fr;padding:clamp(60px,8vh,100px) 0} }
.nl-left {
  padding:clamp(36px,5vw,72px) clamp(18px,5vw,72px);
  border-right:1px solid var(--border);
}
@media(max-width:800px) { .nl-left{border-right:none;border-bottom:1px solid var(--border)} }
.nl-title {
  font-family:var(--f-disp);
  font-size:clamp(80px,13vw,170px);
  line-height:.85; letter-spacing:.02em; color:var(--paper);
  margin-bottom:22px;
}
.nl-title .r { color:var(--red); }
.nl-desc {
  font-family:var(--f-serif); font-style:italic;
  font-size:clamp(16px,2.2vw,22px); line-height:1.5;
  color:rgba(232,221,208,0.6); max-width:480px; margin-bottom:32px;
}
.nl-perks { display:flex; flex-direction:column; gap:0; }
.nl-perk {
  display:flex; align-items:center; gap:14px;
  font-size:12px; letter-spacing:.1em; color:var(--mid);
  padding:12px 0; border-bottom:1px solid var(--border);
  font-weight:300;
}
.nl-perk-mark { color:var(--red); font-size:14px; flex-shrink:0; }

/* Right side — form card */
.nl-right {
  padding:clamp(36px,5vw,72px) clamp(18px,5vw,72px);
  display:flex; flex-direction:column; justify-content:center;
}
.nl-card {
  background:rgba(15,12,10,0.8);
  border:1px solid rgba(232,221,208,0.1);
  padding:clamp(28px,4vw,48px);
  backdrop-filter:blur(20px);
  position:relative; overflow:hidden;
}
.nl-card::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(to right, var(--red), transparent);
}
.nl-card-label { font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--red); margin-bottom:6px; }
.nl-card-count { font-family:var(--f-disp); font-size:clamp(28px,4vw,44px); color:rgba(232,221,208,0.15); letter-spacing:.06em; margin-bottom:20px; line-height:1; }
.nl-card-rule { width:100%; height:1px; background:var(--border); margin-bottom:24px; }

.nl-field { margin-bottom:16px; }
.nl-input {
  width:100%; background:transparent; border:none;
  border-bottom:1px solid rgba(232,221,208,0.2);
  padding:12px 0; color:var(--paper);
  font-family:var(--f-mono); font-size:15px; font-weight:300;
  outline:none; transition:border-color 0.2s;
}
.nl-input:focus { border-bottom-color:var(--red); }
.nl-input::placeholder { color:rgba(232,221,208,0.2); }

.nl-submit-btn {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  font-family:var(--f-disp); font-size:20px; letter-spacing:.14em; text-transform:uppercase;
  background:var(--red); border:none; color:var(--paper);
  padding:16px 22px; margin-top:4px;
  transition:all 0.2s var(--ease-out);
  position:relative; overflow:hidden;
}
.nl-submit-btn::before {
  content:''; position:absolute; inset:0;
  background:rgba(232,221,208,0.1);
  transform:translateX(-100%); transition:transform 0.3s var(--ease-out);
}
.nl-submit-btn:hover::before { transform:translateX(0); }
.nl-submit-btn:hover { letter-spacing:.18em; }
.nl-btn-icon { font-size:22px; transition:transform 0.2s; }
.nl-submit-btn:hover .nl-btn-icon { transform:translateX(5px); }
.nl-submit-btn:disabled { opacity:0.5; cursor:not-allowed; }

.nl-msg { font-size:12px; letter-spacing:.16em; text-transform:uppercase; margin-top:12px; min-height:16px; }
.nl-msg.ok { color:#5a9a6f; }
.nl-msg.err { color:#c94040; }
.nl-fine-print { font-size:11px; letter-spacing:.1em; color:var(--dim); margin-top:18px; }

/* ── MANIFESTO ── */
#manifesto-section { border-bottom:1px solid var(--border); }
.manifesto-layout { display:grid; grid-template-columns:1fr 1fr; min-height:72vh; }
@media(max-width:700px) { .manifesto-layout{grid-template-columns:1fr} }
.manifesto-left { position:relative; overflow:hidden; border-right:1px solid var(--border); }
.mf-photo { position:absolute; inset:0; background-image:url('/images/moscow-rave.jpg'); background-size:cover; background-position:center; }
.mf-overlay { position:absolute; inset:0; background:linear-gradient(135deg, rgba(8,6,4,0.75) 0%, rgba(8,6,4,0.2) 100%); }
.mf-content { position:relative; z-index:2; height:100%; display:flex; flex-direction:column; justify-content:flex-end; padding:clamp(26px,4vw,56px); min-height:440px; }
.mf-quote { font-family:var(--f-serif); font-style:italic; font-size:clamp(22px,3.2vw,38px); line-height:1.22; color:var(--paper); border-left:3px solid var(--red); padding-left:20px; }
.manifesto-right { padding:clamp(32px,5vw,68px) clamp(18px,4vw,56px); display:flex; flex-direction:column; justify-content:center; }
.manifesto-body p { font-size:clamp(14px,1.7vw,16px); line-height:1.92; color:var(--mid); margin-bottom:18px; font-weight:300; }
.manifesto-stamp { display:inline-block; border:1.5px solid var(--red); color:var(--red); font-family:var(--f-disp); font-size:clamp(11px,1.5vw,14px); letter-spacing:.34em; padding:4px 12px; transform:rotate(-3deg); opacity:0.55; margin-top:18px; }

/* ── SUBMIT ── */
#submit-section { border-bottom:1px solid var(--border); }
.submit-layout { display:grid; grid-template-columns:1fr 1fr; }
@media(max-width:700px) { .submit-layout{grid-template-columns:1fr} }
.submit-left { border-right:1px solid var(--border); padding:clamp(32px,5vw,68px) clamp(18px,4vw,56px); }
.submit-title { font-family:var(--f-disp); font-size:clamp(64px,10vw,130px); line-height:.88; letter-spacing:.02em; }
.submit-title .r { color:var(--red); }
.submit-desc { font-family:var(--f-serif); font-style:italic; font-size:clamp(16px,2.2vw,21px); line-height:1.48; color:var(--mid); margin:20px 0 28px; }
.submit-list { list-style:none; }
.submit-list li { padding:10px 0; border-bottom:1px solid var(--border); font-size:14px; letter-spacing:.1em; color:var(--mid); display:flex; align-items:center; gap:12px; }
.submit-list li::before { content:'→'; color:var(--red); flex-shrink:0; }
.submit-right { padding:clamp(32px,5vw,68px) clamp(18px,4vw,56px); }
.form-group { margin-bottom:22px; }
.form-group label { display:block; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--dim); margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:transparent; border:none; border-bottom:1px solid var(--border); padding:10px 0; color:var(--paper); font-family:var(--f-mono); font-size:15px; font-weight:300; outline:none; transition:border-color 0.2s; -webkit-appearance:none; border-radius:0; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-bottom-color:var(--red); }
.form-group select option { background:var(--bg); }
.form-group textarea { resize:none; height:90px; line-height:1.68; }
.form-msg { font-size:12px; letter-spacing:.12em; margin-top:10px; display:none; }
.form-msg.error { color:#c94040; display:block; }
.form-msg.success { color:#5a9a6f; display:block; }
.form-submit { font-family:var(--f-disp); font-size:20px; letter-spacing:.16em; background:transparent; border:1px solid var(--paper); color:var(--paper); padding:14px 36px; transition:all 0.2s; margin-top:10px; text-transform:uppercase; }
.form-submit:hover { background:var(--paper); color:var(--bg); }
.form-submit:disabled { opacity:0.4; cursor:not-allowed; }

/* ── FOOTER ── */
#footer { border-top:2px solid rgba(232,221,208,0.1); padding:clamp(26px,3.5vw,44px) clamp(18px,4vw,56px); display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:22px; }
@media(max-width:600px) { #footer{grid-template-columns:1fr;gap:16px} }
.foot-logo { font-family:var(--f-disp); font-size:22px; letter-spacing:.2em; color:var(--dim); }
.foot-logo .n { color:var(--red); }
.foot-copy { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); text-align:center; }
.foot-links { display:flex; gap:18px; justify-content:flex-end; }
.foot-links a { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); text-decoration:none; cursor:pointer; transition:color 0.15s; }
.foot-links a:hover { color:var(--mid); }

/* ── RX DECORATION ── */
.rx-strip { display:flex; gap:4px; align-items:center; padding:clamp(10px,1.5vw,14px) clamp(18px,4vw,56px); border-bottom:1px solid var(--border); }
.rx { height:4px; background:var(--red); border-radius:1px; opacity:0.55; }
.rxd { height:4px; background:var(--border); border-radius:1px; }

/* ── REVEAL ANIMATIONS ── */
.reveal { opacity:0; transform:translateY(26px); transition:opacity 0.75s var(--ease-out), transform 0.75s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }

/* ── TOAST ── */
#toast { position:fixed; bottom:32px; left:50%; transform:translateX(-50%) translateY(90px); background:var(--surface); border:1px solid var(--border); padding:12px 22px; z-index:9997; font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--paper); transition:transform 0.4s var(--ease-out); pointer-events:none; white-space:nowrap; }
#toast.show { transform:translateX(-50%) translateY(0); }

/* ── MOBILE NAV ── */
#mobile-nav { display:none; position:fixed; bottom:0; left:0; right:0; z-index:600; background:rgba(8,6,4,0.97); border-top:1px solid var(--border); padding:9px 0 max(9px, env(safe-area-inset-bottom)); flex-direction:row; justify-content:space-around; }
@media(max-width:700px) { #mobile-nav{display:flex} }
.mn-btn { display:flex; flex-direction:column; align-items:center; gap:4px; background:transparent; border:none; padding:5px 10px; }
.mn-dot { width:5px; height:5px; border-radius:50%; background:var(--dim); transition:background 0.18s; }
.mn-btn.active .mn-dot { background:var(--red); }
.mn-lbl { font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); transition:color 0.18s; }
.mn-btn.active .mn-lbl { color:var(--paper); }

/* ── SKELETON ── */
.skeleton { background:linear-gradient(90deg, var(--surface) 25%, var(--ghost) 50%, var(--surface) 75%); background-size:200% 100%; animation:shimmer 1.5s infinite; border-radius:2px; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ════════════════════════════════════════
   SHOP SECTION — COMING SOON
════════════════════════════════════════ */
#shop-section {
  position:relative; min-height:100vh; overflow:hidden;
  display:flex; align-items:center;
  border-bottom:1px solid var(--border); padding-top:0;
  background:var(--bg);
}
#shop-canvas {
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
}
.shop-overlay {
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 60% 80% at 70% 50%, rgba(8,6,4,0.1) 0%, rgba(8,6,4,0.85) 100%),
    linear-gradient(to right, rgba(8,6,4,0.98) 0%, rgba(8,6,4,0.6) 55%, rgba(8,6,4,0.2) 100%);
}
.shop-inner {
  position:relative; z-index:2;
  width:100%; display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  padding:clamp(80px,10vh,120px) 0;
}
@media(max-width:800px) { .shop-inner { grid-template-columns:1fr; padding:clamp(60px,8vh,100px) 0; } }
.shop-left {
  padding:clamp(36px,5vw,72px) clamp(18px,5vw,72px);
  border-right:1px solid var(--border);
}
@media(max-width:800px) { .shop-left { border-right:none; border-bottom:1px solid var(--border); } }
.shop-cs-stamp {
  display:inline-flex; align-items:center; gap:10px;
  border:1.5px solid var(--red); color:var(--red);
  font-family:var(--f-disp); font-size:13px; letter-spacing:.36em;
  padding:5px 16px; transform:rotate(-2deg);
  opacity:.7; margin-bottom:28px;
}
.shop-title {
  font-family:var(--f-disp);
  font-size:clamp(88px,15vw,190px);
  line-height:.83; letter-spacing:.02em; color:var(--paper);
  margin-bottom:24px;
}
.shop-title .r { color:var(--red); }
.shop-desc {
  font-family:var(--f-serif); font-style:italic;
  font-size:clamp(16px,2.2vw,22px); line-height:1.5;
  color:rgba(232,221,208,0.6); max-width:480px; margin-bottom:36px;
}
.shop-teaser-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0; margin-bottom:32px;
  border:1px solid var(--border);
}
.shop-teaser-item {
  padding:16px 20px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.shop-teaser-item:nth-child(2n) { border-right:none; }
.shop-teaser-item:nth-last-child(-n+2) { border-bottom:none; }
.shop-ti-cat {
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); margin-bottom:5px;
}
.shop-ti-name {
  font-family:var(--f-disp); font-size:clamp(16px,2.2vw,22px);
  letter-spacing:.05em; color:var(--paper); margin-bottom:4px;
}
.shop-ti-price {
  font-size:12px; letter-spacing:.1em; color:var(--mid);
}
.shop-notify-wrap {
  display:flex; gap:0;
}
.shop-notify-input {
  flex:1; background:transparent; border:none;
  border-bottom:1px solid rgba(232,221,208,0.25);
  padding:12px 0; color:var(--paper);
  font-family:var(--f-mono); font-size:14px; font-weight:300;
  outline:none; transition:border-color 0.2s;
}
.shop-notify-input:focus { border-bottom-color:var(--red); }
.shop-notify-input::placeholder { color:rgba(232,221,208,0.2); }
.shop-notify-btn {
  font-family:var(--f-disp); font-size:16px; letter-spacing:.14em;
  background:transparent; border:none; border-bottom:1px solid rgba(232,221,208,0.25);
  color:var(--red); padding:12px 20px; transition:all 0.2s; flex-shrink:0;
}
.shop-notify-btn:hover { color:var(--paper); border-bottom-color:var(--red); }
.shop-notify-msg { font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-top:10px; min-height:16px; }
.shop-notify-msg.ok { color:#5a9a6f; }
.shop-notify-msg.err { color:#c94040; }
.shop-right {
  padding:clamp(36px,5vw,72px) clamp(18px,5vw,72px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:400px;
}
/* Music EQ canvas */
#music-eq-canvas {
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%; pointer-events:none;
  opacity:0.45;
}
.music-hero { position:relative; }
