/* ═══════════════════════════════════════════
   DJ CINCINATI — style.css
   Fonts: YekanBakh (local) + Bebas/Anton/DM Mono via Google
   ═══════════════════════════════════════════ */

/* ── YEKAN BAKH LOCAL FONTS ── */
@font-face {
  font-family: 'YekanBakh';
  src: url('../fonts/YekanBakh-Regular.ttf') format('truetype'),
       url('../fonts/YekanBakh-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'YekanBakh';
  src: url('../fonts/YekanBakh-Bold.ttf') format('truetype'),
       url('../fonts/YekanBakh-Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'YekanBakh';
  src: url('../fonts/YekanBakh-ExtraBlack.ttf') format('truetype'),
       url('../fonts/YekanBakh-ExtraBlack.otf') format('opentype');
  font-weight: 900; font-style: normal; font-display: swap;
}

/* ── RESET ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --r:   #FF1A1A;
  --w:   #FFFFFF;
  --off: #C8C8C0;
  --dim: #555550;
  --bg:  #080808;
  --bg1: #0E0E0E;
  --bg2: #141414;

  --mono:  'DM Mono', monospace;
  --cond:  'Barlow Condensed', 'YekanBakh', sans-serif;
  --big:   'Bebas Neue', 'YekanBakh', sans-serif;
  --heavy: 'Anton', 'YekanBakh', sans-serif;
  --fa:    'YekanBakh', sans-serif;
}

html { scroll-behavior: smooth; font-size: 16px; }
body { background: var(--bg); color: var(--w); font-family: var(--mono); overflow-x: hidden; cursor: crosshair; }

/* Skip link — a11y & crawlers see main landmark first when focused */
.skip-link {
  position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden;
}
.skip-link:focus {
  position: fixed; left: 1rem; top: 1rem; z-index: 10000; width: auto; height: auto;
  padding: 0.75rem 1.25rem; background: var(--r); color: var(--bg); font-family: var(--mono);
  font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase; text-decoration: none;
  clip: auto; overflow: visible;
}

/* Grain overlay */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 1000; 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.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: 0.4; mix-blend-mode: overlay;
}
::-webkit-scrollbar { width: 2px; }
::-webkit-scrollbar-thumb { background: var(--r); }

/* ── NAV (scoped — do not use bare `nav`; footer uses <nav class="footer-tags">) ── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.2rem 3rem;
  border-bottom: 1px solid rgba(255,26,26,0.15);
  background: rgba(8,8,8,0.92); backdrop-filter: blur(12px);
}
.nav-logo {
  display: inline-flex; align-items: center; line-height: 0; text-decoration: none;
  flex-shrink: 0;
}
.nav-logo-img {
  height: 36px; width: auto; max-width: min(200px, 46vw);
  object-fit: contain; object-position: left center;
}
.nav-links { display: flex; gap: 2.5rem; list-style: none; align-items: center; }
.nav-links a { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--dim); text-decoration: none; transition: color 0.2s; }
.nav-links a:hover { color: var(--r); }
.nav-book { color: var(--r) !important; border: 1px solid var(--r); padding: 0.5rem 1.2rem; transition: all 0.2s; }
.nav-book:hover { background: var(--r); color: var(--bg) !important; }
.hamburger { display: none; flex-direction: column; gap: 4px; cursor: crosshair; }
.hamburger span { width: 22px; height: 1px; background: var(--r); display: block; transition: all 0.3s; }

/* ── HERO ── */
#home { min-height: 100vh; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 3rem 4rem; position: relative; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
}
.hero-slide {
  position: absolute; inset: 0; opacity: 0; z-index: 0;
  transition: opacity 1.35s ease-in-out;
}
.hero-slide.is-active { opacity: 1; z-index: 1; }
.hero-slide img {
  width: 100%; height: 100%; object-fit: cover; object-position: 50% 30%;
  filter: saturate(0.92) contrast(1.06);
  display: block;
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide { transition: none; }
  .hero-slide:not(.is-active) { visibility: hidden; }
}
.hero-bg-shade {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(8,8,8,0.55) 0%,
    rgba(8,8,8,0.25) 38%,
    rgba(8,8,8,0.65) 72%,
    var(--bg) 100%
  );
}
.hero-scanlines { position: absolute; inset: 0; z-index: 2; pointer-events: none; background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,26,26,0.015) 2px,rgba(255,26,26,0.015) 4px); }
.hero-cross { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 500px; height: 500px; z-index: 2; pointer-events: none; opacity: 0.04; }
.hero-cross::before, .hero-cross::after { content: ''; position: absolute; background: var(--r); }
.hero-cross::before { width: 1px; height: 100%; left: 50%; top: 0; }
.hero-cross::after  { width: 100%; height: 1px; top: 50%; left: 0; }
.hero-tag { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--r); margin-bottom: 1.5rem; display: flex; align-items: center; gap: 1rem; position: relative; z-index: 3; }
.hero-tag::before { content: ''; width: 1px; height: 40px; background: var(--r); }
.hero-name { font-family: var(--heavy); font-size: clamp(5rem,18vw,18rem); line-height: 0.85; letter-spacing: -0.02em; color: var(--w); position: relative; z-index: 3; text-transform: uppercase; margin: 0; font-weight: 400; text-shadow: 0 2px 40px rgba(0,0,0,0.75); }
.hero-name .name-cin    { display: block; color: var(--r); }
.hero-name .name-cinati { display: block; -webkit-text-stroke: 1px rgba(255,255,255,0.3); color: transparent; }
.glitch { position: relative; display: inline-block; }
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.glitch::before { color: var(--r); clip-path: polygon(0 30%,100% 30%,100% 50%,0 50%); animation: glitch1 4s infinite; }
.glitch::after  { color: #00FFFF; clip-path: polygon(0 60%,100% 60%,100% 75%,0 75%); animation: glitch2 4s infinite; mix-blend-mode: screen; }
@keyframes glitch1 { 0%,90%,100%{transform:translateX(0);opacity:0;} 92%{transform:translateX(-4px);opacity:1;} 94%{transform:translateX(4px);opacity:1;} 96%{transform:translateX(0);opacity:0;} }
@keyframes glitch2 { 0%,90%,100%{transform:translateX(0);opacity:0;} 93%{transform:translateX(5px);opacity:1;} 95%{transform:translateX(-3px);opacity:1;} 97%{transform:translateX(0);opacity:0;} }
.hero-bottom { display: flex; align-items: flex-end; justify-content: space-between; margin-top: 2rem; flex-wrap: wrap; gap: 2rem; position: relative; z-index: 3; }
.hero-meta { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--dim); display: flex; flex-direction: column; gap: 0.4rem; }
.hero-meta span { display: flex; align-items: center; gap: 0.75rem; }
.hero-meta .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--r); flex-shrink: 0; }
.hero-cta { display: flex; gap: 1.5rem; align-items: center; flex-wrap: wrap; }
.hero-num { font-family: var(--big); font-size: 6rem; color: rgba(255,26,26,0.12); position: absolute; top: 8rem; right: 3rem; z-index: 3; letter-spacing: -0.05em; line-height: 1; }
.btn-r { font-family: var(--cond); font-size: 1rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; background: var(--r); color: var(--bg); padding: 0.9rem 2.5rem; text-decoration: none; transition: all 0.2s; display: inline-block; border: 2px solid var(--r); }
.btn-r:hover { background: transparent; color: var(--r); }
.btn-ghost { font-family: var(--cond); font-size: 1rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; background: transparent; color: var(--w); padding: 0.9rem 2.5rem; text-decoration: none; transition: all 0.2s; display: inline-block; border: 2px solid rgba(255,255,255,0.15); }
.btn-ghost:hover { border-color: var(--w); }

/* ── TICKER ── */
.ticker { background: var(--r); padding: 0.6rem 0; overflow: hidden; border-top: 1px solid rgba(255,255,255,0.1); border-bottom: 1px solid rgba(255,255,255,0.1); }
.ticker-inner { display: flex; white-space: nowrap; animation: ticker 25s linear infinite; }
.ticker-item { font-family: var(--cond); font-size: 0.85rem; font-weight: 700; letter-spacing: 0.3em; text-transform: uppercase; color: var(--bg); padding: 0 2.5rem; flex-shrink: 0; }
.ticker-sep { color: rgba(8,8,8,0.4); }
@keyframes ticker { from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ── HOME: VENUES ── */
.home-venues {
  padding: 4.5rem 3rem 5rem;
  background: var(--bg1);
  border-top: 1px solid rgba(255,26,26,0.12);
  border-bottom: 1px solid rgba(255,26,26,0.12);
}
.home-venues-inner { max-width: 1200px; margin: 0 auto; }
.home-venues-head { text-align: center; max-width: 36rem; margin: 0 auto 2.75rem; }
.home-venues-title {
  font-family: var(--big); font-size: clamp(1.75rem, 4vw, 2.75rem); line-height: 1.05;
  text-transform: uppercase; color: var(--w); margin-bottom: 1rem;
}
.home-venues-title em { color: var(--r); font-style: normal; }
.home-venues-lead {
  font-family: var(--mono); font-size: 0.72rem; color: var(--off); line-height: 1.85;
  font-weight: 300; text-align: justify; text-wrap: pretty;
}
.home-venues-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: rgba(255,26,26,0.15);
  border: 1px solid rgba(255,26,26,0.15);
}
.home-venues-grid > li { margin: 0; min-width: 0; }
.home-venues-card {
  display: flex; align-items: center; justify-content: center;
  min-height: 120px; padding: 1.75rem 1.25rem;
  background: var(--bg2); text-decoration: none; color: inherit;
  transition: background 0.2s, box-shadow 0.2s;
}
.home-venues-card:hover,
.home-venues-card:focus-visible {
  background: rgba(255,26,26,0.06);
  box-shadow: inset 0 0 0 1px rgba(255,26,26,0.35);
  outline: none;
}
.home-venues-img {
  max-width: 100%; height: auto; object-fit: contain;
  opacity: 0.92; transition: opacity 0.2s;
}
.home-venues-card:hover .home-venues-img { opacity: 1; }
.home-venues-img--338 { max-height: 52px; max-width: min(220px, 100%); width: auto; }
.home-venues-img--e1 { max-height: 44px; max-width: min(140px, 100%); width: auto; }
.home-venues-img--steelyard { max-height: 48px; max-width: min(180px, 100%); width: auto; }
.home-venues-img--tabu { max-height: 42px; max-width: min(200px, 100%); width: auto; }

@media (max-width: 800px) {
  .home-venues-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px) {
  .home-venues-card { min-height: 100px; padding: 1.25rem 1rem; }
}

/* ── SHARED ── */
.section-num { font-family: var(--big); font-size: 8rem; color: rgba(255,26,26,0.08); line-height: 1; margin-bottom: -1rem; display: block; }
.section-label { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--r); display: block; margin-bottom: 1.5rem; }

/* ── ABOUT ── */
#about { padding: 8rem 3rem; background: var(--bg); }
.about-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 0; max-width: 1400px; margin: 0 auto; }
.about-left  { border-right: 1px solid rgba(255,26,26,0.15); padding-right: 4rem; }
.about-right { padding-left: 4rem; }
.about-title { font-family: var(--big); font-size: clamp(3rem,7vw,6rem); line-height: 0.9; text-transform: uppercase; color: var(--w); margin-bottom: 2rem; }
.about-title em { color: var(--r); font-style: normal; display: block; }
.rj-badge { display: inline-flex; align-items: center; gap: 0.75rem; border: 1px solid var(--r); padding: 0.5rem 1rem; margin-bottom: 2rem; }
.rj-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--r); animation: blink 1.5s step-end infinite; }
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0;} }
.rj-badge span { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--r); }
.about-body p { font-size: 0.82rem; line-height: 2; color: var(--off); margin-bottom: 1.2rem; font-weight: 300; }
.about-body strong { color: var(--w); font-weight: 400; }
.about-stats { margin-top: 3rem; display: grid; grid-template-columns: repeat(3,1fr); }
.stat { border-left: 1px solid rgba(255,26,26,0.2); padding: 1.5rem; }
.stat:first-child { border-left: none; padding-left: 0; }
.stat-n { font-family: var(--big); font-size: 3.5rem; color: var(--r); line-height: 1; }
.stat-l { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--dim); margin-top: 0.25rem; }
.about-big-text { font-family: var(--heavy); font-size: clamp(6rem,12vw,11rem); color: var(--bg1); letter-spacing: -0.03em; line-height: 0.85; -webkit-text-stroke: 1px rgba(255,26,26,0.12); text-transform: uppercase; user-select: none; }
.about-big-text em { -webkit-text-stroke: 1px rgba(255,26,26,0.3); color: transparent; font-style: normal; display: block; }
.about-card { background: var(--bg1); border: 1px solid rgba(255,26,26,0.15); padding: 2rem; margin-top: 2rem; position: relative; }
.about-card::before { content: ''; position: absolute; top: -1px; left: 0; width: 60px; height: 2px; background: var(--r); }
.about-card-label { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--r); margin-bottom: 0.75rem; }
.about-card-val   { font-family: var(--cond); font-size: 1.3rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.about-photo {
  margin: 0 0 1.5rem; position: relative; border: 1px solid rgba(255,26,26,0.2);
  overflow: hidden; aspect-ratio: 4 / 3; max-height: min(52vh, 420px);
}
.about-photo::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--r); z-index: 1;
}
.about-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 25%; display: block; }
.about-photo-cap {
  position: absolute; bottom: 0; left: 0; right: 0; padding: 0.65rem 1rem;
  font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--w); background: linear-gradient(transparent, rgba(8,8,8,0.92));
}

/* ── DISCOGRAPHY ── */
#discography { padding: 8rem 3rem; background: var(--bg1); }
.disco-header {
  display: grid; grid-template-columns: 1fr minmax(200px, 36%); align-items: end; gap: 2.5rem 3rem;
  max-width: 1400px; margin: 0 auto 3rem;
}
.disco-header-main { display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 1rem; min-width: 0; }
.disco-header-photo {
  position: relative; border: 1px solid rgba(255,26,26,0.2); overflow: hidden;
  min-height: 200px; max-height: 280px; aspect-ratio: 16 / 10;
}
.disco-header-photo::before {
  content: ''; position: absolute; top: 0; left: 0; width: 48px; height: 2px; background: var(--r); z-index: 1;
}
.disco-header-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; display: block; }
.disco-title { font-family: var(--big); font-size: clamp(3rem,8vw,7rem); line-height: 0.85; text-transform: uppercase; }
.disco-title em { color: var(--r); font-style: normal; }
.disco-sub { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--dim); max-width: 300px; line-height: 1.8; }
.disco-list { max-width: 1400px; margin: 0 auto; }
.disco-latest-head {
  display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 0.75rem 1.5rem;
  padding: 0 0 1.25rem; margin-bottom: 0.25rem; border-bottom: 1px solid rgba(255,26,26,0.25);
}
.disco-latest-title { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--w); }
.disco-latest-more {
  font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--r);
  text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35); padding-bottom: 2px;
}
.disco-latest-more:hover { border-color: var(--r); }
.disco-divider {
  display: flex; align-items: center; gap: 1.5rem; margin: 2.5rem 0 1.5rem;
  font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--dim);
}
.disco-divider::before, .disco-divider::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.08); }
.disco-divider-text { flex-shrink: 0; }
.disco-row {
  display: grid; grid-template-columns: 60px 1fr 1fr auto; align-items: center; gap: 2rem; padding: 1.5rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.05); cursor: crosshair; transition: all 0.2s; position: relative;
}
a.disco-row--link { text-decoration: none; color: inherit; }
.d-meta-end { display: flex; align-items: center; gap: 1.5rem; }
.disco-row:hover { background: rgba(255,26,26,0.04); padding-left: 1rem; padding-right: 1rem; margin: 0 -1rem; }
.disco-row:hover .d-num { color: var(--r); }
.disco-row:hover .play-icon { opacity: 1; }
.disco-row:hover .d-bar-wrap { opacity: 1; }
.d-num { font-family: var(--big); font-size: 2rem; color: rgba(255,255,255,0.08); transition: color 0.2s; letter-spacing: -0.03em; }
.disco-thumb {
  width: 56px; height: 56px; flex-shrink: 0; border: 1px solid rgba(255,26,26,0.22);
  overflow: hidden; background: var(--bg2); transition: border-color 0.2s;
}
.disco-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.disco-row--remix { cursor: pointer; outline: none; }
.disco-row--remix:focus-visible { box-shadow: inset 0 0 0 2px var(--r); }
.disco-row--remix.is-preview-active { background: rgba(255,26,26,0.07); }
.disco-row--remix:hover .disco-thumb { border-color: rgba(255,26,26,0.5); }
.disco-row--remix:hover .play-icon--preview { opacity: 1; }
.d-type { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--r); margin-bottom: 0.3rem; }
.d-name { font-family: var(--cond); font-size: 1.4rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.d-sub  { font-family: var(--mono); font-size: 0.65rem; color: var(--dim); margin-top: 0.2rem; }
.d-platform { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--dim); }
.d-duration { font-family: var(--big); font-size: 1.2rem; color: rgba(255,255,255,0.2); white-space: nowrap; }
.d-bar-wrap { display: flex; align-items: flex-end; gap: 2px; height: 24px; opacity: 0; transition: opacity 0.3s; }
.d-bar { width: 3px; border-radius: 1px; background: var(--r); }
.play-icon { position: absolute; right: 0; width: 28px; height: 28px; border: 1px solid var(--r); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--r); font-size: 0.7rem; opacity: 0; transition: opacity 0.2s; flex-shrink: 0; }

.disco-row--preview { cursor: pointer; outline: none; }
.disco-row--preview:focus-visible { box-shadow: inset 0 0 0 2px var(--r); }
.disco-row--preview.is-preview-active { background: rgba(255,26,26,0.07); }
.disco-row--preview:hover .play-icon--preview { opacity: 1; }
.d-preview-pill {
  display: inline-block; margin-top: 0.45rem; font-family: var(--mono); font-size: 0.48rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--r); border: 1px solid rgba(255,26,26,0.35);
  padding: 0.2rem 0.45rem;
}
@media (hover: none) {
  .play-icon--preview { opacity: 0.85; }
}

/* Discography preview player */
body.has-disco-preview { padding-bottom: 7.5rem; }
body.disco-modal-open { overflow: hidden; }
.disco-preview-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 550;
  background: rgba(6,6,6,0.96); border-top: 2px solid var(--r);
  box-shadow: 0 -8px 40px rgba(0,0,0,0.5); backdrop-filter: blur(16px);
}
.disco-preview-bar.is-hidden { display: none; }
.disco-preview-inner {
  max-width: 1400px; margin: 0 auto; padding: 1rem 1.5rem 1.15rem;
  display: flex; align-items: center; gap: 1.25rem;
}
.disco-pp-play {
  width: 54px; height: 54px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid var(--r); background: var(--r); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0; transition: transform 0.2s, box-shadow 0.25s;
}
.disco-pp-play:hover { transform: scale(1.06); box-shadow: 0 0 28px rgba(255,26,26,0.45); }
.disco-pp-play-ic {
  display: block; width: 0; height: 0; border-style: solid;
  border-width: 10px 0 10px 16px; border-color: transparent transparent transparent var(--bg);
  margin-left: 5px; transition: all 0.15s;
}
.disco-pp-play.is-playing .disco-pp-play-ic {
  width: 18px; height: 20px; margin-left: 0; border: none;
  background: linear-gradient(90deg, var(--bg) 0 32%, transparent 32% 68%, var(--bg) 68% 100%);
}
.disco-pp-body { flex: 1; min-width: 0; }
.disco-pp-title {
  font-family: var(--cond); font-size: 1rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 0.4rem;
}
.disco-pp-row { display: flex; align-items: center; gap: 0.75rem; }
.disco-pp-time { font-family: var(--mono); font-size: 0.58rem; color: var(--dim); min-width: 2.4rem; flex-shrink: 0; }
.disco-pp-time-cap { color: var(--r); text-align: right; }
.disco-pp-seek-wrap { flex: 1; position: relative; min-width: 0; height: 10px; }
.disco-pp-seek {
  width: 100%; height: 6px; -webkit-appearance: none; appearance: none;
  background: linear-gradient(90deg, rgba(255,26,26,0.45) 0%, rgba(255,26,26,0.45) 100%), rgba(255,255,255,0.08);
  background-size: 100% 100%; border-radius: 3px; cursor: pointer; margin: 0;
}
.disco-pp-seek::-webkit-slider-thumb {
  -webkit-appearance: none; width: 14px; height: 14px; border-radius: 50%;
  background: var(--w); border: 2px solid var(--r); cursor: grab; box-shadow: 0 0 12px rgba(255,26,26,0.5);
}
.disco-pp-seek::-moz-range-thumb {
  width: 14px; height: 14px; border-radius: 50%; background: var(--w); border: 2px solid var(--r);
  cursor: grab;
}
.disco-pp-seek-cap {
  position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 0; height: 6px;
  pointer-events: none; border-radius: 0 3px 3px 0;
}
.disco-pp-hint {
  font-family: var(--mono); font-size: 0.5rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--dim); margin: 0.35rem 0 0; opacity: 0.85;
}
.disco-pp-full {
  font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.4);
  flex-shrink: 0; white-space: nowrap; padding-bottom: 2px;
}
.disco-pp-full:hover { border-color: var(--r); }

/* Floating WhatsApp (main.js adds .wa-float when number is configured) */
.wa-float {
  position: fixed;
  right: max(1rem, env(safe-area-inset-right, 0px));
  bottom: max(1.25rem, env(safe-area-inset-bottom, 0px));
  z-index: 480;
  pointer-events: none;
}
.wa-float__btn {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 1.15rem 0.75rem 0.9rem;
  background: #25d366;
  color: #0b141a;
  border-radius: 999px;
  text-decoration: none;
  font-family: var(--cond);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  box-shadow: 0 6px 28px rgba(37, 211, 102, 0.32), 0 2px 14px rgba(0, 0, 0, 0.45);
  transition: transform 0.2s, box-shadow 0.2s, filter 0.2s;
  border: 1px solid rgba(255, 255, 255, 0.22);
}
.wa-float__btn:hover {
  filter: brightness(1.07);
  transform: scale(1.03);
  box-shadow: 0 8px 34px rgba(37, 211, 102, 0.42), 0 4px 18px rgba(0, 0, 0, 0.5);
}
.wa-float__btn:focus-visible {
  outline: 2px solid var(--w);
  outline-offset: 3px;
}
.wa-float__icon { display: flex; flex-shrink: 0; line-height: 0; }
.wa-float__icon svg { display: block; }
body.has-disco-preview .wa-float {
  bottom: calc(7.85rem + env(safe-area-inset-bottom, 0px));
}
body.has-podcast-player .wa-float {
  bottom: calc(6.35rem + env(safe-area-inset-bottom, 0px));
}
@media (max-width: 520px) {
  .wa-float__label {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
  }
  .wa-float__btn {
    padding: 0.85rem;
    border-radius: 50%;
    width: 56px;
    height: 56px;
    justify-content: center;
  }
}

/* Mobile floating Book now → #contact or /#contact (main.js) */
.book-float {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 470;
  padding: 0.5rem max(1rem, env(safe-area-inset-left, 0px))
    calc(0.5rem + env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-right, 0px));
  pointer-events: none;
  justify-content: center;
  box-sizing: border-box;
}
.book-float__btn {
  pointer-events: auto;
  display: block;
  width: 100%;
  max-width: 22rem;
  margin: 0 auto;
  padding: 0.95rem 1.5rem;
  text-align: center;
  text-decoration: none;
  font-family: var(--cond);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bg);
  background: var(--r);
  border: 2px solid var(--r);
  border-radius: 4px;
  box-shadow:
    0 0 0 3px rgba(255, 26, 26, 0.45),
    0 10px 32px rgba(0, 0, 0, 0.55);
  transition: filter 0.2s, transform 0.2s, box-shadow 0.2s;
}
.book-float__btn:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
  box-shadow:
    0 0 0 3px rgba(255, 26, 26, 0.55),
    0 12px 36px rgba(0, 0, 0, 0.6);
}
.book-float__btn:focus-visible {
  outline: 2px solid var(--w);
  outline-offset: 3px;
}
@media (max-width: 768px) {
  .book-float {
    display: flex;
  }
  .wa-float {
    bottom: calc(4.1rem + max(1.25rem, env(safe-area-inset-bottom, 0px)));
  }
  body.has-disco-preview .wa-float {
    bottom: calc(7.85rem + 4.1rem + max(1.25rem, env(safe-area-inset-bottom, 0px)));
  }
  body.has-podcast-player .wa-float {
    bottom: calc(6.35rem + 4.1rem + max(1.25rem, env(safe-area-inset-bottom, 0px)));
  }
}

/* Preview modal */
.disco-modal {
  position: fixed; inset: 0; z-index: 800; display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
}
.disco-modal.is-hidden { display: none; }
.disco-modal-backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,0.78); backdrop-filter: blur(6px);
}
.disco-modal-panel {
  position: relative; z-index: 1; max-width: 420px; width: 100%;
  background: var(--bg1); border: 1px solid rgba(255,26,26,0.35);
  padding: 2.25rem 2rem; text-align: center;
  box-shadow: 0 24px 80px rgba(0,0,0,0.65);
}
.disco-modal-panel::before {
  content: ''; display: block; width: 48px; height: 3px; background: var(--r); margin: 0 auto 1.5rem;
}
.disco-modal-title {
  font-family: var(--big); font-size: 1.75rem; text-transform: uppercase; letter-spacing: 0.06em;
  margin: 0 0 1rem; line-height: 1.1;
}
.disco-modal-text {
  font-family: var(--mono); font-size: 0.72rem; color: var(--off); line-height: 1.85; margin: 0 0 1.75rem;
}
.disco-modal-btn {
  display: inline-block; font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.22em;
  text-transform: uppercase; background: var(--r); color: var(--bg); padding: 1rem 1.75rem;
  text-decoration: none; transition: filter 0.2s; margin-bottom: 1rem;
}
.disco-modal-btn:hover { filter: brightness(1.08); }
.disco-modal-dismiss {
  display: block; width: 100%; margin: 0 auto; background: transparent; border: 0;
  font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--dim); cursor: pointer; padding: 0.5rem;
}
.disco-modal-dismiss:hover { color: var(--off); }

/* ── PACKAGES ── */
#packages { padding: 8rem 3rem; background: var(--bg); }
.pkg-header {
  max-width: 1400px; margin: 0 auto 4rem;
  display: grid; grid-template-columns: 1fr minmax(180px, 32%); gap: 2.5rem 3rem; align-items: end;
}
.pkg-header-copy { min-width: 0; }
.pkg-header-photo {
  position: relative; border: 1px solid rgba(255,26,26,0.18); overflow: hidden;
  min-height: 160px; max-height: 220px; aspect-ratio: 5 / 3;
}
.pkg-header-photo::before {
  content: ''; position: absolute; top: 0; right: 0; width: 40px; height: 2px; background: var(--r); z-index: 1;
}
.pkg-header-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 30%; display: block; }
.pkg-title { font-family: var(--big); font-size: clamp(3rem,8vw,7rem); line-height: 0.85; text-transform: uppercase; margin-bottom: 1rem; }
.pkg-title em { color: var(--r); font-style: normal; }
.pkg-grid { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,26,26,0.1); }
.pkg-card { background: var(--bg); padding: 3rem 2.5rem; position: relative; overflow: hidden; transition: background 0.3s; }
.pkg-card:hover { background: var(--bg1); }
.pkg-card.hot { background: var(--bg1); }
.pkg-card.hot::after { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--r); }
.pkg-tier { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--r); margin-bottom: 1.5rem; }
.pkg-name { font-family: var(--big); font-size: 3.5rem; text-transform: uppercase; line-height: 0.9; margin-bottom: 0.5rem; }
.pkg-tag  { font-family: var(--cond); font-size: 0.85rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--dim); margin-bottom: 2.5rem; }
.pkg-hot-tag { display: inline-block; font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.2em; text-transform: uppercase; background: var(--r); color: var(--bg); padding: 0.25rem 0.6rem; margin-bottom: 1rem; }
.pkg-line { width: 30px; height: 1px; background: rgba(255,26,26,0.4); margin-bottom: 2rem; }
.pkg-features { list-style: none; margin-bottom: 2.5rem; }
.pkg-features li { font-family: var(--mono); font-size: 0.72rem; padding: 0.7rem 0; border-bottom: 1px solid rgba(255,255,255,0.04); color: var(--off); display: flex; align-items: center; gap: 0.75rem; }
.pkg-features li::before { content: '—'; color: var(--r); font-size: 0.6rem; flex-shrink: 0; }
.pkg-features li.no { color: rgba(255,255,255,0.15); }
.pkg-features li.no::before { color: rgba(255,255,255,0.1); }
.pkg-footnote {
  max-width: 1400px; margin: 2.5rem auto 0; padding: 0 2.5rem;
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--dim); line-height: 1.75; text-align: center;
  border-top: 1px solid rgba(255,26,26,0.12); padding-top: 2rem;
}

/* ── BLOG ── */
#blog { padding: 8rem 3rem; background: var(--bg1); }
.blog-header { max-width: 1400px; margin: 0 auto 3rem; display: flex; flex-direction: column; gap: 1.5rem; }
.blog-header-top { display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 1rem; width: 100%; }
.blog-header-photo {
  width: 100%; max-height: 200px; border: 1px solid rgba(255,26,26,0.15); overflow: hidden;
  position: relative;
}
.blog-header-photo::before {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: var(--r); z-index: 1; opacity: 0.85;
}
.blog-header-photo img { width: 100%; height: 100%; min-height: 140px; object-fit: cover; object-position: 50% 32%; display: block; }
.blog-title { font-family: var(--big); font-size: clamp(3rem,8vw,7rem); line-height: 0.85; text-transform: uppercase; }
.blog-title em { color: var(--r); font-style: normal; }
.see-all { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.3); padding-bottom: 2px; transition: border-color 0.2s; }
.see-all:hover { border-color: var(--r); }
.blog-grid { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr; gap: 1px; background: rgba(255,26,26,0.1); }
.blog-main { background: var(--bg1); overflow: hidden; cursor: crosshair; transition: background 0.2s; }
.blog-main:hover { background: var(--bg2); }
.blog-main-num { font-family: var(--big); font-size: 12rem; color: rgba(255,26,26,0.06); line-height: 1; padding: 2rem 2.5rem 0; letter-spacing: -0.05em; }
.blog-main-content { padding: 0 2.5rem 2.5rem; }
.blog-main-cat   { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--r); margin-bottom: 1rem; }
.blog-main-title { font-family: var(--big); font-size: clamp(1.8rem,4vw,3rem); line-height: 0.95; text-transform: uppercase; margin-bottom: 1rem; }
.blog-main-p     { font-family: var(--mono); font-size: 0.75rem; color: var(--off); line-height: 1.9; margin-bottom: 1.5rem; font-weight: 300; }
.blog-main-meta  { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.1em; color: var(--dim); display: flex; gap: 1.5rem; }
.blog-side { display: flex; flex-direction: column; gap: 1px; background: rgba(255,26,26,0.1); }
.blog-card { background: var(--bg1); padding: 2rem; flex: 1; cursor: crosshair; transition: background 0.2s; border-left: 2px solid transparent; }
.blog-card:hover { background: var(--bg2); border-left-color: var(--r); }
.blog-card-cat   { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--r); margin-bottom: 0.75rem; }
.blog-card-title { font-family: var(--cond); font-size: 1.1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; line-height: 1.2; margin-bottom: 0.5rem; }
.blog-card-p     { font-family: var(--mono); font-size: 0.68rem; color: var(--off); line-height: 1.8; font-weight: 300; }
.blog-card-meta  { font-family: var(--mono); font-size: 0.55rem; color: var(--dim); margin-top: 1rem; letter-spacing: 0.1em; }

/* ── BLOG PAGE (blog.html) ── */
.blog-page-main { background: var(--bg1); padding-bottom: 5rem; }
.blog-page-hero {
  max-width: 1400px; margin: 0 auto; padding: 6.5rem 3rem 2rem;
  display: grid; gap: 2rem;
}
.blog-page-hero-inner { min-width: 0; }
.blog-page-title {
  font-family: var(--big); font-size: clamp(2.2rem, 6vw, 4.5rem); line-height: 0.95;
  text-transform: uppercase; color: var(--w); margin-bottom: 1.25rem;
}
.blog-page-title em { color: var(--r); font-style: normal; display: block; margin-top: 0.2em; }
.blog-page-lead {
  font-family: var(--mono); font-size: 0.78rem; color: var(--off); line-height: 1.95;
  max-width: 42rem; font-weight: 300;
  text-align: justify; text-wrap: pretty;
}
.blog-page-hero-photo {
  width: 100%; max-height: min(42vh, 360px); border: 1px solid rgba(255,26,26,0.2); overflow: hidden;
}
.blog-page-hero-img { width: 100%; height: 100%; min-height: 200px; object-fit: cover; object-position: 50% 30%; display: block; }
.blog-page-tags { max-width: 1400px; margin: 0 auto; padding: 0 3rem 2rem; }
.blog-page-tags-heading {
  font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--r); margin-bottom: 1rem;
}
.blog-tag-cloud { display: flex; flex-wrap: wrap; gap: 0.5rem 0.65rem; margin-bottom: 1.5rem; }
.blog-tag {
  font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--off); text-decoration: none; border: 1px solid rgba(255,26,26,0.35);
  padding: 0.4rem 0.75rem; transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.blog-tag:hover { color: var(--r); border-color: var(--r); background: rgba(255,26,26,0.06); }
.blog-page-index { max-width: 1400px; margin: 0 auto; padding: 0 3rem 3rem; }
.blog-page-section-title {
  font-family: var(--big); font-size: clamp(2rem, 5vw, 3.5rem); text-transform: uppercase;
  margin-bottom: 1.5rem; color: var(--w);
}
.blog-index-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr)); gap: 1px;
  background: rgba(255,26,26,0.12);
}
.blog-index-card { background: var(--bg2); min-width: 0; }
.blog-index-card-anchor {
  display: flex; flex-direction: column; height: 100%; min-height: 100%;
  text-decoration: none; color: inherit; transition: background 0.2s;
}
@media (min-width: 520px) {
  .blog-index-card-anchor { flex-direction: row; align-items: stretch; }
}
.blog-index-card-anchor:hover { background: rgba(255,26,26,0.05); }
.blog-index-card-num {
  font-family: var(--big); font-size: 2.5rem; color: rgba(255,26,26,0.2); line-height: 1;
  padding: 1.25rem 0 0 1.25rem; flex-shrink: 0; width: 3.5rem;
}
.blog-index-card-body { flex: 1; padding: 1.25rem 1.25rem 1.5rem; min-width: 0; }
.blog-index-card-title {
  font-family: var(--cond); font-size: 1.05rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em; line-height: 1.25; margin-bottom: 0.5rem; color: var(--w);
}
.blog-index-card-excerpt {
  font-family: var(--mono); font-size: 0.68rem; color: var(--off); line-height: 1.75; font-weight: 300; margin-bottom: 0.75rem;
  text-align: justify; text-wrap: pretty;
}
.blog-index-card-tags {
  display: flex; flex-wrap: wrap; gap: 0.35rem; list-style: none; margin: 0 0 0.75rem; padding: 0;
}
.blog-tag-pill {
  font-family: var(--mono); font-size: 0.48rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--r); border: 1px solid rgba(255,26,26,0.4); padding: 0.2rem 0.45rem; display: inline-block;
}
a.blog-tag-pill--link { text-decoration: none; color: var(--r); transition: background 0.2s, border-color 0.2s; }
a.blog-tag-pill--link:hover { background: rgba(255,26,26,0.12); border-color: var(--r); }
.blog-index-card-meta {
  font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.12em; color: var(--dim); text-transform: uppercase;
}
.blog-index-card-thumb {
  width: 100%; min-height: 140px; max-height: 200px; overflow: hidden; flex-shrink: 0; border-top: 1px solid rgba(255,26,26,0.1);
}
@media (min-width: 520px) {
  .blog-index-card-thumb {
    width: 200px; max-height: none; min-height: 100%; border-top: none; border-left: 1px solid rgba(255,26,26,0.1);
  }
}
.blog-index-card-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: center 28%; display: block; min-height: 140px; }
.blog-articles { background: var(--bg); border-top: 1px solid rgba(255,26,26,0.12); padding: 2rem 0 4rem; }
.blog-article-full { max-width: 720px; margin: 0 auto; padding: 3.5rem 1.5rem; border-bottom: 1px solid rgba(255,255,255,0.06); }
.blog-article-full:last-child { border-bottom: none; }
.blog-article-head { margin-bottom: 1.5rem; }
.blog-article-title {
  font-family: var(--big); font-size: clamp(1.6rem, 4vw, 2.4rem); line-height: 1; text-transform: uppercase;
  color: var(--w); margin-bottom: 0.75rem;
}
.blog-article-meta {
  font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.12em; color: var(--dim); text-transform: uppercase; margin-bottom: 1rem;
}
.blog-article-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; list-style: none; margin: 0; padding: 0; }
.blog-article-figure { margin: 0 0 1.75rem; border: 1px solid rgba(255,26,26,0.15); overflow: hidden; }
.blog-article-figure img { width: 100%; height: auto; display: block; }
.blog-article-body p {
  font-family: var(--mono); font-size: 0.78rem; color: var(--off); line-height: 2; font-weight: 300; margin-bottom: 1.25rem;
  text-align: justify; text-wrap: pretty;
}
.blog-index-card-title[lang="fa"] {
  font-family: var(--fa); direction: rtl; text-align: right;
}
.blog-index-card-excerpt[lang="fa"] {
  font-family: var(--fa); direction: rtl; text-align: justify; text-justify: inter-character;
}
.blog-article-inner--fa .blog-article-head {
  direction: rtl; text-align: right;
}
.blog-article-title--fa {
  font-family: var(--fa); font-size: clamp(1.35rem, 3.8vw, 2rem); line-height: 1.35;
  text-transform: none; letter-spacing: 0; font-weight: 700;
}
.blog-article-inner--fa .blog-article-meta {
  direction: rtl; text-align: right;
}
.blog-article-inner--fa .blog-article-tags {
  flex-direction: row-reverse; flex-wrap: wrap; justify-content: flex-end;
}
.blog-article-body--fa p {
  font-family: var(--fa); font-size: 0.95rem; line-height: 2.05; font-weight: 400;
  text-align: justify; text-justify: inter-character; text-wrap: pretty;
}
.blog-article-lang-note {
  margin-top: 1.75rem; padding-top: 1.25rem; border-top: 1px solid rgba(255,26,26,0.15);
  font-family: var(--mono); font-size: 0.68rem; color: var(--dim); line-height: 1.7; font-weight: 300;
}
.blog-article-lang-note a { color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35); }
.blog-article-lang-note a:hover { border-color: var(--r); }
.blog-article-inner--fa .blog-back-top { display: inline-block; margin-top: 1.25rem; direction: rtl; }
.blog-back-top {
  display: inline-block; margin-top: 1rem; font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35);
}
.blog-back-top:hover { border-color: var(--r); }
#blog .blog-featured { max-width: 1400px; margin: 0 auto; }
#blog .blog-featured-grid {
  display: grid; grid-template-columns: 1fr; gap: 1px;
  background: rgba(255,26,26,0.12);
}
@media (min-width: 900px) {
  #blog .blog-featured-grid { grid-template-columns: repeat(3, 1fr); }
}
#blog .blog-featured-grid .blog-index-card-anchor { min-height: 100%; }
@media (min-width: 900px) {
  #blog .blog-featured-grid .blog-index-card-anchor {
    flex-direction: column; align-items: stretch;
  }
  #blog .blog-featured-grid .blog-index-card-num {
    padding: 1rem 1.25rem 0; width: auto;
  }
  #blog .blog-featured-grid .blog-index-card-thumb {
    width: 100%; max-height: 180px; min-height: 140px; border-left: none; border-top: 1px solid rgba(255,26,26,0.1); order: -1;
  }
  #blog .blog-featured-grid .blog-index-card-thumb img { min-height: 140px; }
}
.blog-featured-cta {
  text-align: center; margin-top: 2rem; font-family: var(--mono);
}
.blog-featured-cta .btn-r { display: inline-block; }

/* ── THANK YOU (thank-you.html) ── */
.offscreen-field {
  position: absolute; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden;
}
.thank-page {
  min-height: 100vh; padding: 10rem 3rem 6rem; background: var(--bg1);
  display: flex; align-items: center; justify-content: center;
}
.thank-inner { max-width: 36rem; text-align: center; }
.thank-title {
  font-family: var(--big); font-size: clamp(3rem, 10vw, 5.5rem); line-height: 0.95;
  text-transform: uppercase; margin: 1rem 0 1.5rem; color: var(--w);
}
.thank-lead, .thank-note {
  font-family: var(--mono); font-size: 0.82rem; color: var(--off); line-height: 1.9; font-weight: 300; margin-bottom: 1rem;
}
.thank-note { color: var(--dim); font-size: 0.72rem; margin-bottom: 0; }
.thank-actions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-top: 2rem; }
.thank-btn-ghost { font-size: 0.75rem !important; padding: 0.65rem 1.25rem !important; }

/* ── PRESS KIT (press.html) ── */
.press-page {
  padding: 8.5rem 3rem 5rem;
  background: var(--bg1);
  min-height: 100vh;
}
.press-inner { max-width: 720px; margin: 0 auto; }
.press-header { margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid rgba(255,26,26,0.15); }
.press-title {
  font-family: var(--big); font-size: clamp(2.5rem, 7vw, 4.5rem); line-height: 0.95;
  text-transform: uppercase; color: var(--w); margin: 0.75rem 0 1.25rem;
}
.press-title em { color: var(--r); font-style: normal; }
.press-intro {
  font-family: var(--mono); font-size: 0.78rem; color: var(--off); line-height: 1.95;
  font-weight: 300; text-align: justify; text-wrap: pretty; max-width: 40rem;
}
.press-section { margin-bottom: 3rem; }
.press-h2 {
  font-family: var(--cond); font-size: 0.95rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--w); margin: 0 0 1.25rem; padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.press-hint {
  font-family: var(--mono); font-size: 0.55rem; font-weight: 300; letter-spacing: 0.12em;
  color: var(--dim); text-transform: uppercase;
}
.press-copy {
  font-family: var(--mono); font-size: 0.82rem; color: var(--off); line-height: 2; font-weight: 300;
  text-align: justify; text-wrap: pretty; margin: 0 0 1rem;
}
.press-copy-btn {
  font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.2em; text-transform: uppercase;
  background: transparent; color: var(--r); border: 1px solid rgba(255,26,26,0.45);
  padding: 0.5rem 1rem; cursor: pointer; transition: background 0.2s, border-color 0.2s;
}
.press-copy-btn:hover { background: rgba(255,26,26,0.1); border-color: var(--r); }
.press-prose p {
  font-family: var(--mono); font-size: 0.78rem; color: var(--off); line-height: 2; font-weight: 300;
  text-align: justify; text-wrap: pretty; margin-bottom: 1.15rem;
}
.press-prose strong { color: var(--w); font-weight: 400; }
.press-note {
  font-family: var(--mono); font-size: 0.68rem; color: var(--dim); line-height: 1.8; font-weight: 300;
  margin: 0 0 1.25rem;
}
.press-facts { margin: 0; display: grid; gap: 0; }
.press-facts > div {
  display: grid; grid-template-columns: minmax(7rem, 32%) 1fr; gap: 1rem 1.5rem;
  padding: 0.85rem 0; border-bottom: 1px solid rgba(255,255,255,0.06); align-items: baseline;
}
.press-facts dt {
  font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--r); margin: 0;
}
.press-facts dd {
  font-family: var(--mono); font-size: 0.78rem; color: var(--off); margin: 0; line-height: 1.6; font-weight: 300;
}
.press-facts a { color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35); }
.press-facts a:hover { border-color: var(--r); }
.press-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.65rem; }
.press-link-card {
  display: flex; flex-direction: column; gap: 0.25rem;
  padding: 1rem 1.15rem; background: var(--bg2); border: 1px solid rgba(255,26,26,0.18);
  text-decoration: none; transition: border-color 0.2s, background 0.2s;
}
.press-link-card:hover { border-color: rgba(255,26,26,0.45); background: rgba(255,26,26,0.04); }
.press-link-name {
  font-family: var(--cond); font-size: 0.85rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--w);
}
.press-link-url {
  font-family: var(--mono); font-size: 0.62rem; color: var(--dim); letter-spacing: 0.04em;
  word-break: break-all;
}
.press-footer { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid rgba(255,26,26,0.15); }
.press-footer-ghost { font-size: 0.75rem !important; padding: 0.65rem 1.25rem !important; }

@media (max-width: 520px) {
  .press-facts > div { grid-template-columns: 1fr; gap: 0.35rem; }
}

/* ── CONTACT ── */
#contact { padding: 8rem 3rem; background: var(--bg); }
.contact-layout { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 8rem; align-items: start; }
.contact-photo {
  margin-bottom: 2rem; border: 1px solid rgba(255,26,26,0.2); overflow: hidden;
  max-height: 240px; aspect-ratio: 16 / 10;
}
.contact-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; display: block; }
.contact-big { font-family: var(--big); font-size: clamp(4rem,10vw,8rem); line-height: 0.85; text-transform: uppercase; margin-bottom: 2rem; }
.contact-big em { color: var(--r); font-style: normal; display: block; }
.contact-body { font-family: var(--mono); font-size: 0.78rem; color: var(--off); line-height: 1.9; margin-bottom: 2.5rem; font-weight: 300; }
.contact-items { display: flex; flex-direction: column; }
.c-item { display: flex; align-items: center; gap: 1.5rem; padding: 1.2rem 0; border-bottom: 1px solid rgba(255,26,26,0.1); }
.c-icon  { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; color: var(--r); min-width: 3rem; text-transform: uppercase; }
.c-text  { font-family: var(--mono); font-size: 0.78rem; color: var(--off); }
a.c-text { text-decoration: none; transition: color 0.2s; }
a.c-text:hover { color: var(--r); }
.c-label { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--dim); display: block; margin-bottom: 0.2rem; }
.locs { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.5rem; }
.loc { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; border: 1px solid rgba(255,26,26,0.25); padding: 0.35rem 0.8rem; color: var(--r); transition: all 0.2s; }
.loc:hover { background: rgba(255,26,26,0.08); }
.f-group   { margin-bottom: 2rem; }
.f-label   { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--dim); display: block; margin-bottom: 0.75rem; }
.f-input   { width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(255,255,255,0.1); padding: 0.75rem 0; color: var(--w); font-family: var(--mono); font-size: 0.82rem; font-weight: 300; outline: none; transition: border-color 0.2s, box-shadow 0.2s; }
.f-input:focus { border-color: var(--r); }
.f-input option { background: var(--bg1); color: var(--w); }

/* Enquiry: select + date — match site (dark panel, red accent) */
.contact-form { color-scheme: dark; }
.contact-form select.f-input--control,
.contact-form input[type="date"].f-input--control {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background-color: var(--bg1);
  border: 1px solid rgba(255,26,26,0.22);
  border-radius: 0;
  border-bottom: 1px solid rgba(255,26,26,0.22);
  padding: 0.8rem 2.5rem 0.8rem 0.9rem;
  min-height: 2.85rem;
  color: var(--off);
  font-family: var(--mono);
  font-size: 0.82rem;
  font-weight: 300;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s, color 0.2s;
}
.contact-form select.f-input--control:hover,
.contact-form input[type="date"].f-input--control:hover {
  border-color: rgba(255,26,26,0.45);
  color: var(--w);
}
.contact-form select.f-input--control:focus,
.contact-form input[type="date"].f-input--control:focus {
  border-color: var(--r);
  box-shadow: 0 0 0 1px rgba(255,26,26,0.25);
  color: var(--w);
}
.contact-form select.f-input--control {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath stroke='%23FF1A1A' stroke-width='1.5' stroke-linecap='round' d='M1.5 1.5L6 6l4.5-4.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 11px 7px;
}
.contact-form select.f-input--control option {
  background: var(--bg2);
  color: var(--w);
  padding: 0.5rem;
}
.contact-form select.f-input--control option[value=""] {
  color: var(--dim);
}
/* Date field: WebKit / Chromium */
.contact-form input[type="date"].f-input--control::-webkit-calendar-picker-indicator {
  opacity: 1;
  cursor: pointer;
  width: 1.35rem;
  height: 1.35rem;
  padding: 0.15rem;
  margin-left: 0.25rem;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FF1A1A' stroke-width='1.5' stroke-linecap='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='2'/%3E%3Cpath d='M3 10h18M8 3v4M16 3v4'/%3E%3C/svg%3E") center / contain no-repeat;
}
.contact-form input[type="date"].f-input--control::-webkit-datetime-edit-text { color: var(--dim); padding: 0 0.15em; }
.contact-form input[type="date"].f-input--control::-webkit-datetime-edit-month-field,
.contact-form input[type="date"].f-input--control::-webkit-datetime-edit-day-field,
.contact-form input[type="date"].f-input--control::-webkit-datetime-edit-year-field {
  color: var(--w);
}
.f-grid     { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.f-textarea { resize: vertical; min-height: 100px; }
.f-submit   { margin-top: 2.5rem; }
.btn-submit { width: 100%; font-family: var(--cond); font-size: 1.1rem; font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase; background: var(--r); color: var(--bg); padding: 1rem 2rem; border: 2px solid var(--r); cursor: crosshair; transition: all 0.2s; }
.btn-submit:hover { background: transparent; color: var(--r); }

/* ── FOOTER ── */
footer { background: var(--bg); border-top: 1px solid rgba(255,26,26,0.15); padding: 3rem; }
.footer-inner { max-width: 1400px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 2rem; }
.footer-logo { line-height: 0; flex-shrink: 0; }
.footer-logo-img {
  height: clamp(34px, 5.5vw, 46px); width: auto; max-width: min(280px, 90vw);
  object-fit: contain; object-position: left center;
}
.footer-rj { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--r); display: flex; align-items: center; gap: 0.75rem; }
.footer-rj::before, .footer-rj::after { content: '▶'; font-size: 0.4rem; }
.footer-links { display: flex; gap: 2rem; list-style: none; flex-wrap: wrap; }
.footer-links a { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--dim); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--r); }
.footer-socials { display: flex; gap: 1rem; }
.soc { width: 34px; height: 34px; border: 1px solid rgba(255,26,26,0.2); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 0.6rem; color: var(--dim); text-decoration: none; transition: all 0.2s; }
.soc:hover { border-color: var(--r); color: var(--r); }
.footer-tags-wrap {
  max-width: 1400px; margin: 0 auto; width: 100%; padding: 0 0 1.5rem;
  border-top: 1px solid rgba(255,26,26,0.18); text-align: center;
}
.footer-tags-label {
  font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--r); margin-bottom: 1rem; padding-top: 1.75rem; font-weight: 400;
}
.footer-tags {
  display: flex; flex-wrap: wrap; gap: 0.5rem 0.65rem; align-items: center;
  justify-content: center; list-style: none; margin: 0; padding: 0;
}
a.footer-tag {
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--w); text-decoration: none; border: 1px solid rgba(255,26,26,0.45);
  padding: 0.45rem 0.85rem; min-height: 36px; display: inline-flex; align-items: center; justify-content: center;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
a.footer-tag:hover {
  color: var(--r); border-color: var(--r); background: rgba(255,26,26,0.1);
}
.footer-copy { width: 100%; text-align: center; font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.15em; color: rgba(255,255,255,0.1); padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.04); }

/* ── MOBILE MENU ── */
.mob-menu { display: none; position: fixed; inset: 0; background: rgba(8,8,8,0.98); z-index: 490; flex-direction: column; align-items: flex-start; justify-content: center; padding: 3rem; gap: 1.5rem; }
.mob-menu.open { display: flex; }
.mob-menu a { font-family: var(--big); font-size: 3.5rem; text-transform: uppercase; color: var(--w); text-decoration: none; transition: color 0.2s; line-height: 1; }
.mob-menu a:hover { color: var(--r); }

/* ── REVEAL ANIMATION ── */
.reveal { opacity: 0; transform: translateY(40px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ═══════════════════════════════════════════
   RHYTHMOTISM PAGE  (rhythmotism.html)
═══════════════════════════════════════════ */

/* Page hero */
.rh-hero {
  min-height: 60vh; display: flex; flex-direction: column; justify-content: flex-end;
  padding: 8rem 3rem 4rem; position: relative; overflow: hidden; background: var(--bg);
  border-bottom: 1px solid rgba(255,26,26,0.15);
}
.rh-hero .scanlines { position: absolute; inset: 0; pointer-events: none; background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,26,26,0.012) 2px,rgba(255,26,26,0.012) 4px); }
.rh-eyebrow { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--r); display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.rh-eyebrow::before { content: ''; width: 1px; height: 40px; background: var(--r); }
.rh-big { font-family: var(--heavy); font-size: clamp(4rem,14vw,13rem); line-height: 0.85; letter-spacing: -0.03em; text-transform: uppercase; margin: 0; font-weight: 400; }
.rh-big .red { color: var(--r); }
.rh-big .outline { -webkit-text-stroke: 1px rgba(255,255,255,0.2); color: transparent; display: block; }
.rh-meta-row { display: flex; align-items: center; gap: 3rem; margin-top: 2.5rem; flex-wrap: wrap; }
.rh-meta-item { display: flex; flex-direction: column; gap: 0.2rem; }
.rh-meta-label { font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--dim); }
.rh-meta-val   { font-family: var(--cond); font-size: 1.1rem; font-weight: 700; text-transform: uppercase; }
.live-pill { display: flex; align-items: center; gap: 0.5rem; background: rgba(255,26,26,0.1); border: 1px solid rgba(255,26,26,0.3); padding: 0.4rem 0.9rem; }
.live-dot  { width: 6px; height: 6px; border-radius: 50%; background: var(--r); animation: blink 1.5s step-end infinite; }
.live-text { font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--r); }

/* Latest episode banner */
.ep-banner {
  max-width: 1400px; margin: 5rem auto 0;
  background: var(--bg1); border: 1px solid rgba(255,26,26,0.2);
  display: flex; gap: 3rem; align-items: center; padding: 2.5rem;
  position: relative; overflow: hidden;
}
.ep-banner::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--r); }
.ep-banner-num { font-family: var(--heavy); font-size: 8rem; color: rgba(255,26,26,0.07); line-height: 1; flex-shrink: 0; letter-spacing: -0.05em; }
.ep-banner-body { flex: 1; }
.ep-banner-tag { font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.3em; text-transform: uppercase; background: var(--r); color: var(--bg); padding: 0.25rem 0.75rem; display: inline-block; margin-bottom: 1rem; }
.ep-banner-title { font-family: var(--big); font-size: clamp(1.8rem,5vw,3.5rem); text-transform: uppercase; line-height: 0.9; margin-bottom: 0.75rem; }
.ep-banner-title em { color: var(--r); font-style: normal; }
.ep-banner-meta { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--dim); display: flex; gap: 2rem; flex-wrap: wrap; margin-bottom: 1.25rem; align-items: center; }
.ep-banner-meta a { color: var(--off); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35); transition: color 0.2s, border-color 0.2s; }
.ep-banner-meta a:hover { color: var(--r); border-color: var(--r); }
.ep-banner-cover { flex-shrink: 0; width: min(220px, 46vw); line-height: 0; border: 1px solid rgba(255,26,26,0.28); transition: border-color 0.2s, box-shadow 0.25s; }
.ep-banner-cover:hover { border-color: var(--r); box-shadow: 0 0 28px rgba(255,26,26,0.12); }
.ep-banner-cover img { width: 100%; height: auto; aspect-ratio: 1; object-fit: cover; display: block; }
.ep-banner-desc { font-family: var(--mono); font-size: 0.75rem; color: var(--off); line-height: 1.9; }
.ep-banner-desc-fa { font-family: var(--fa); font-size: 0.85rem; color: var(--off); direction: rtl; text-align: right; margin-top: 0.5rem; line-height: 1.8; display: block; }

/* Episodes section */
.episodes-wrap { padding: 5rem 3rem 8rem; background: var(--bg1); }
.ep-section-head { max-width: 1400px; margin: 0 auto 3rem; display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.ep-section-title { font-family: var(--big); font-size: clamp(2rem,5vw,4rem); text-transform: uppercase; margin: 0; font-weight: 400; }
.ep-section-title em { color: var(--r); font-style: normal; }
.ep-total { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--dim); }

.episodes-grid { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 1px; background: rgba(255,26,26,0.08); }
.ep-card { background: var(--bg1); padding: 0; position: relative; cursor: crosshair; transition: background 0.2s; overflow: hidden; }
.ep-card:hover { background: var(--bg2); }
.ep-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: transparent; transition: background 0.2s; z-index: 1; }
.ep-card:hover::before { background: var(--r); }
.ep-card:hover .ep-play { opacity: 1; transform: scale(1); }
.ep-card:hover .ep-ghost { color: rgba(255,26,26,0.15); }
.ep-card:hover .ep-thumb img { transform: scale(1.04); }

.ep-thumb { display: block; line-height: 0; overflow: hidden; background: var(--bg2); border-bottom: 1px solid rgba(255,26,26,0.12); }
.ep-thumb img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; transition: transform 0.4s ease; }

.ep-card-inner { padding: 2rem; }
.ep-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 1.25rem; }
.ep-ghost { font-family: var(--big); font-size: 3.5rem; color: rgba(255,255,255,0.04); line-height: 1; letter-spacing: -0.04em; transition: color 0.3s; }
.ep-play  { width: 38px; height: 38px; border: 1px solid var(--r); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--r); font-size: 0.75rem; opacity: 0; transform: scale(0.8); transition: all 0.25s; flex-shrink: 0; }

.ep-badge { font-family: var(--mono); font-size: 0.5rem; letter-spacing: 0.25em; text-transform: uppercase; background: rgba(255,26,26,0.1); color: var(--r); padding: 0.22rem 0.55rem; border: 1px solid rgba(255,26,26,0.2); display: inline-block; margin-bottom: 0.6rem; }
.ep-name { font-family: var(--cond); font-size: 1.25rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; line-height: 1.15; color: var(--w); margin-bottom: 0.3rem; }
.ep-title-link { color: inherit; text-decoration: none; transition: color 0.2s; }
.ep-title-link:hover { color: var(--r); }
.ep-name-fa { font-family: var(--fa); font-size: 0.95rem; font-weight: 700; color: var(--off); direction: rtl; text-align: right; display: block; margin-bottom: 0.75rem; line-height: 1.4; }
.ep-desc { font-family: var(--mono); font-size: 0.66rem; color: var(--dim); line-height: 1.85; margin-bottom: 1.25rem; font-weight: 300; }
.ep-foot { display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,0.04); padding-top: 1rem; }
.ep-dur  { font-family: var(--big); font-size: 1rem; color: rgba(255,255,255,0.14); }
.ep-date { font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--dim); }
.ep-rj   { font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.25); padding-bottom: 1px; transition: border-color 0.2s; }
.ep-rj:hover { border-color: var(--r); }

.ep-play {
  width: 38px; height: 38px; border: 1px solid var(--r); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--r); font-size: 0.75rem; opacity: 0; transform: scale(0.8);
  transition: all 0.25s; flex-shrink: 0;
  background: transparent; cursor: pointer; padding: 0; font-family: inherit;
}
.ep-card:hover .ep-play { opacity: 1; transform: scale(1); }
.ep-play:focus-visible { opacity: 1; transform: scale(1); outline: 2px solid var(--r); outline-offset: 2px; }

.ep-play-inline {
  font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--w); background: rgba(255,26,26,0.15); border: 1px solid rgba(255,26,26,0.45);
  padding: 0.35rem 0.65rem; cursor: pointer; transition: background 0.2s, color 0.2s;
}
.ep-play-inline:hover { background: var(--r); color: var(--bg); }

.ep-card.is-playing { box-shadow: inset 0 0 0 1px var(--r); }
.ep-card.is-playing .ep-play { opacity: 1; transform: scale(1); }

.ep-foot { flex-wrap: wrap; gap: 0.5rem 0.75rem; }

/* Fixed podcast player */
body.has-podcast-player { padding-bottom: 5.5rem; }
.podcast-player {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 600;
  background: rgba(8,8,8,0.97); border-top: 1px solid rgba(255,26,26,0.35);
  backdrop-filter: blur(14px);
}
.podcast-player.is-hidden { display: none; }
.podcast-player-bar {
  max-width: 1400px; margin: 0 auto; padding: 0.65rem 1.25rem;
  display: flex; align-items: center; gap: 1rem;
}
.pp-play {
  width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--r);
  background: var(--r); color: var(--bg); font-size: 0.85rem; cursor: pointer;
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  padding: 0; font-family: inherit; transition: filter 0.2s;
}
.pp-play:hover { filter: brightness(1.08); }
.pp-art {
  width: 52px; height: 52px; object-fit: cover; flex-shrink: 0;
  border: 1px solid rgba(255,26,26,0.25);
}
.pp-main { flex: 1; min-width: 0; }
.pp-title {
  font-family: var(--cond); font-size: 0.95rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 0.35rem;
}
.pp-row { display: flex; align-items: center; gap: 0.65rem; }
.pp-t { font-family: var(--mono); font-size: 0.58rem; color: var(--dim); flex-shrink: 0; min-width: 2.5rem; }
.pp-t:last-child { text-align: right; }
.pp-seek {
  flex: 1; height: 3px; -webkit-appearance: none; appearance: none;
  background: rgba(255,255,255,0.12); border-radius: 2px; cursor: pointer;
}
.pp-seek::-webkit-slider-thumb { -webkit-appearance: none; width: 12px; height: 12px; border-radius: 50%; background: var(--r); cursor: pointer; }
.pp-seek::-moz-range-thumb { width: 12px; height: 12px; border-radius: 50%; background: var(--r); border: 0; cursor: pointer; }
.pp-openrj {
  font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--r); text-decoration: none; border-bottom: 1px solid rgba(255,26,26,0.35);
  flex-shrink: 0; white-space: nowrap;
}
.pp-openrj:hover { border-color: var(--r); }
.pp-close {
  width: 36px; height: 36px; border: 0; background: transparent; color: var(--dim);
  cursor: pointer; font-size: 1rem; flex-shrink: 0; line-height: 1;
}
.pp-close:hover { color: var(--r); }
.pp-error {
  font-family: var(--mono); font-size: 0.62rem; color: var(--r); text-align: center;
  padding: 0 1rem 0.5rem; margin: 0;
}
.is-hidden { display: none !important; }

@media (hover: none) {
  .ep-card .ep-play { opacity: 0.9; transform: scale(1); }
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  #nav { padding: 1.2rem 1.5rem; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  #home,#venues,#about,#discography,#packages,#blog,#contact { padding: 5rem 1.5rem; }
  .home-venues { padding: 3.5rem 1.5rem 4rem; }
  .thank-page { padding: 8rem 1.5rem 4rem; }
  .press-page { padding: 6.5rem 1.5rem 4rem; }
  .blog-page-hero, .blog-page-tags, .blog-page-index { padding-left: 1.5rem; padding-right: 1.5rem; }
  .blog-page-hero { padding-top: 5.5rem; }
  #home { padding: 0 1.5rem 3rem; }
  .about-layout, .contact-layout { grid-template-columns: 1fr; gap: 3rem; }
  .about-left { border-right: none; padding-right: 0; border-bottom: 1px solid rgba(255,26,26,0.15); padding-bottom: 3rem; }
  .about-right { padding-left: 0; }
  .pkg-grid  { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .disco-row { grid-template-columns: 40px 1fr auto; gap: 1rem; }
  .disco-row--remix { grid-template-columns: minmax(44px, 48px) 1fr auto; }
  .disco-thumb { width: 44px; height: 44px; }
  .disco-row .d-platform, .disco-row .d-duration { display: none; }
  .f-grid { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-tags-wrap { text-align: left; }
  .footer-tags-label { padding-top: 1.5rem; }
  .footer-tags { justify-content: flex-start; }
  .footer-rj { display: none; }
  .rh-hero, .episodes-wrap { padding-left: 1.5rem; padding-right: 1.5rem; }
  .episodes-grid { grid-template-columns: 1fr; }
  .ep-banner { flex-direction: column; gap: 1.5rem; align-items: stretch; }
  .ep-banner-num { font-size: 5rem; }
  .ep-banner-cover { width: min(280px, 70vw); margin: 0 auto; }
  .podcast-player-bar { flex-wrap: wrap; padding: 0.75rem 1rem; }
  .disco-preview-inner { flex-wrap: wrap; gap: 1rem; }
  .disco-pp-body { flex-basis: 100%; order: 2; }
  .disco-pp-play { order: 1; }
  .disco-pp-full { order: 3; margin-left: auto; }
  .disco-header { grid-template-columns: 1fr; }
  .disco-header-photo { max-height: 200px; min-height: 160px; }
  .disco-header-main { flex-direction: column; align-items: flex-start; }
  .pkg-header { grid-template-columns: 1fr; }
  .pkg-header-photo { max-height: 200px; order: -1; }
  .blog-header-photo { max-height: 160px; }
  .blog-header-photo img { min-height: 120px; }
  .contact-photo { max-height: 200px; }
  .about-photo { max-height: 320px; }
  .pp-main { flex-basis: 100%; order: 1; }
  .pp-play { order: 0; }
  .pp-art { order: 0; }
  .pp-openrj, .pp-close { order: 0; }
}
