/* =====================================================================
   STUDIO 33 RADIO & TV  —  La Frecuencia de la Conciencia
   Premium · Latin / spiritual · cinematic · bilingual (ES/EN)
   ===================================================================== */
:root{
  --bg:#03060b; --bg-2:#07101b; --bg-3:#0a1624;
  --card:rgba(255,255,255,.045); --card-border:rgba(231,185,107,.14); --glass:rgba(18,14,10,.6);
  --gold:#e7b96b; --gold-2:#f6dca0; --amber:#d99a44; --rose:#c97b6a; --signal:#2f9ee8; --signal-2:#0b315d;
  --gold-grad:linear-gradient(135deg,#f6dca0 0%,#e7b96b 45%,#c8893b 100%);
  --text:#f6efe4; --muted:#bcae9c; --muted-2:#8c8072;
  --radius:20px; --radius-sm:13px; --maxw:1180px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.8); --glow:0 0 42px -6px rgba(231,185,107,.45);
  --display:"Cinzel",serif; --serif:"Cormorant Garamond",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; }
body{ font-family:var(--sans); background:var(--bg); color:var(--text); line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
body.gate-open{ overflow:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
svg{ fill:currentColor; }
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:22px; }
.amber{ color:var(--gold); }
.scroll-progress{ position:fixed; inset:0 auto auto 0; z-index:100; height:3px; width:0; background:var(--gold-grad); box-shadow:0 0 18px rgba(231,185,107,.8); transform-origin:left center; }
.site-ambient{ position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; background:
  radial-gradient(70% 45% at 12% 18%, rgba(217,154,68,.1), transparent 60%),
  radial-gradient(60% 40% at 88% 44%, rgba(201,123,106,.08), transparent 65%); }
.frequency-line{ position:absolute; left:-10vw; width:120vw; height:1px; opacity:.18; background:linear-gradient(90deg, transparent, rgba(231,185,107,.65), transparent); transform:rotate(-8deg); animation:frequencyDrift 14s ease-in-out infinite; }
.frequency-line--one{ top:22%; }
.frequency-line--two{ top:52%; animation-delay:-5s; transform:rotate(7deg); }
.frequency-line--three{ top:78%; animation-delay:-9s; }
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } *{ scroll-behavior:auto !important; } }

/* ---- Sacred-geometry decorative motif (sun / mandala) ---- */
.motif{ position:absolute; pointer-events:none; opacity:.5; }
.motif svg{ display:block; }
.divider{ display:flex; align-items:center; justify-content:center; gap:16px; margin:0 auto 30px; color:var(--gold); opacity:.8; }
.divider::before, .divider::after{ content:""; height:1px; width:60px; background:linear-gradient(90deg,transparent,var(--gold)); }
.divider::after{ background:linear-gradient(270deg,transparent,var(--gold)); }
.divider svg{ width:26px; height:26px; }
@keyframes spin{ to{ transform:rotate(360deg); } }
@keyframes float{ 50%{ transform:translateY(-30px) translateX(20px); } }
@keyframes eq{ 50%{ transform:scaleY(.35); } }
@keyframes pulse{ 70%{ box-shadow:0 0 0 9px rgba(255,90,77,0);} 100%{ box-shadow:0 0 0 0 rgba(255,90,77,0);} }
@keyframes frequencyDrift{ 0%,100%{ transform:translateX(-4vw) rotate(-8deg); opacity:.1; } 50%{ transform:translateX(6vw) rotate(-3deg); opacity:.25; } }
@keyframes softGlow{ 0%,100%{ opacity:.35; transform:scale(.96); } 50%{ opacity:.7; transform:scale(1.04); } }
@keyframes shimmer{ to{ transform:translateX(120%); } }
@keyframes globeSpin{ to{ background-position:180px 0, 0 0, 0 0; } }
@keyframes gatePulse{ 0%,100%{ opacity:.34; transform:scale(.96); } 50%{ opacity:.75; transform:scale(1.04); } }
@keyframes pinPulse{ 70%{ box-shadow:0 0 0 13px rgba(231,185,107,0); } 100%{ box-shadow:0 0 0 0 rgba(231,185,107,0); } }
@keyframes tunePulse{ 0%,100%{ box-shadow:0 28px 80px -34px #000, 0 0 44px -26px rgba(231,185,107,.9), inset 0 1px rgba(255,255,255,.08); } 50%{ box-shadow:0 34px 96px -32px #000, 0 0 82px -18px rgba(231,185,107,1), inset 0 1px rgba(255,255,255,.12); } }
@keyframes consoleSweep{ 0%{ transform:translateX(-28%) skewX(-12deg); opacity:.12; } 50%{ opacity:.36; } 100%{ transform:translateX(28%) skewX(-12deg); opacity:.12; } }

/* ---- Buttons ---- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; padding:.85em 1.5em; border-radius:999px; font-weight:600; font-size:.95rem; letter-spacing:.2px; transition:transform .25s ease, box-shadow .25s ease, background .25s ease; white-space:nowrap; }
.btn--gold{ background:var(--gold-grad); color:#241606; box-shadow:var(--glow); }
.btn--gold:hover{ transform:translateY(-2px); box-shadow:0 0 56px -4px rgba(231,185,107,.6); }
.btn--glass{ background:var(--card); border:1px solid var(--card-border); color:var(--text); backdrop-filter:blur(8px); }
.btn--glass:hover{ transform:translateY(-2px); border-color:rgba(231,185,107,.5); }
.btn--ghost{ border:1px solid rgba(231,185,107,.4); color:var(--gold); }
.btn--ghost:hover{ background:rgba(231,185,107,.1); transform:translateY(-2px); }
.btn--full{ width:100%; }
.dot{ width:8px; height:8px; border-radius:50%; background:#ff5a4d; display:inline-block; box-shadow:0 0 0 0 rgba(255,90,77,.7); animation:pulse 1.8s infinite; }
.onair-pill{ display:inline-flex; align-items:center; gap:.5em; padding:.5em .95em; border-radius:999px; font-size:.72rem; font-weight:700; letter-spacing:1.5px; border:1px solid rgba(255,90,77,.4); background:rgba(255,90,77,.08); color:#ffd9d4; }
.onair-tag{ display:inline-flex; align-items:center; gap:.5em; font-size:.7rem; font-weight:700; letter-spacing:2px; color:#ffb3ab; }
.kicker{ display:inline-block; font-family:var(--display); font-size:.7rem; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.section__head{ max-width:680px; margin:0 auto 50px; text-align:center; }
.section__head h2{ font-family:var(--serif); font-size:clamp(2rem,4.6vw,3.2rem); font-weight:600; line-height:1.1; letter-spacing:.3px; }
.section__head p{ color:var(--muted); margin-top:14px; font-size:1.05rem; }

/* ---- Navbar ---- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:60; transition:background .35s ease, border-color .35s ease; }
.nav.scrolled{ background:rgba(8,7,6,.85); backdrop-filter:blur(14px); border-bottom:1px solid var(--card-border); }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; padding-block:14px; gap:16px; }
.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand__mark{ display:grid; place-items:center; width:42px; height:42px; border-radius:12px; font-family:var(--display); font-weight:700; font-size:1.1rem; color:#241606; background:var(--gold-grad); box-shadow:var(--glow); }
.brand__mark--logo{ border-radius:50%; overflow:hidden; padding:2px; background:#070b16; border:1px solid rgba(231,185,107,.55); }
.brand__mark--logo img{ width:100%; height:100%; object-fit:cover; border-radius:inherit; }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__text strong{ font-family:var(--display); font-size:.95rem; letter-spacing:2px; }
.brand__text small{ font-size:.62rem; letter-spacing:3px; color:var(--gold); margin-top:4px; }
.nav__links{ display:flex; gap:22px; }
.nav__links a{ font-size:.86rem; color:var(--muted); font-weight:500; position:relative; transition:color .25s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--gold-grad); transition:width .25s ease; }
.nav__links a:hover{ color:var(--text); } .nav__links a:hover::after{ width:100%; }
.nav__actions{ display:flex; align-items:center; gap:12px; }
.lang-toggle{ display:inline-flex; align-items:center; border:1px solid var(--card-border); border-radius:999px; overflow:hidden; font-size:.72rem; font-weight:700; letter-spacing:1px; }
.lang-toggle button{ padding:.45em .7em; color:var(--muted); transition:.2s; }
.lang-toggle button.active{ background:var(--gold-grad); color:#241606; }
.hamburger{ display:none; flex-direction:column; gap:5px; padding:6px; }
.hamburger span{ width:24px; height:2px; background:var(--text); border-radius:2px; transition:.3s; }
.hamburger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---- Frequency gate ---- */
.frequency-gate{ position:fixed; inset:0; z-index:120; display:grid; place-items:center; padding:24px; overflow:hidden; background:
  radial-gradient(70% 58% at 50% 34%, rgba(47,158,232,.26), transparent 67%),
  radial-gradient(48% 42% at 50% 54%, rgba(231,185,107,.18), transparent 66%),
  linear-gradient(180deg, #02050a 0%, #061222 58%, #02050a 100%); transition:opacity .55s ease, visibility .55s ease, transform .55s ease; }
.frequency-gate.minimized{ opacity:0; visibility:hidden; transform:scale(.94); pointer-events:none; }
.tune-overlay{ position:absolute; inset:0; z-index:12; display:grid; place-items:center; background:radial-gradient(circle at 50% 50%, rgba(2,5,10,.08), rgba(2,5,10,.34) 68%, rgba(2,5,10,.54)); transition:opacity .34s ease, visibility .34s ease, transform .34s ease; }
.tune-overlay.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; transform:scale(1.04); }
#tuneCanvas{ position:absolute; inset:0; width:100%; height:100%; opacity:.5; }
.tune-button{ position:relative; z-index:2; display:grid; justify-items:center; padding:20px 30px; min-width:min(330px,calc(100vw - 52px)); border-radius:999px; border:1px solid rgba(231,185,107,.38); background:rgba(2,5,10,.58); color:var(--text); box-shadow:0 28px 80px -34px #000, 0 0 58px -24px rgba(231,185,107,.95), inset 0 1px rgba(255,255,255,.08); backdrop-filter:blur(18px); transition:border-color .35s ease, box-shadow .35s ease; animation:tunePulse 2.2s ease-in-out infinite; }
.tune-button:hover{ animation-play-state:paused; transform:translateY(-3px) scale(1.015); border-color:rgba(246,220,160,.72); box-shadow:0 34px 90px -34px #000, 0 0 74px -20px rgba(231,185,107,1); }
.tune-button span{ font-family:var(--display); font-size:clamp(1.12rem,2.6vw,1.45rem); letter-spacing:3.4px; text-transform:uppercase; color:var(--gold-2); }
.tune-button small{ color:var(--muted); font-size:.78rem; letter-spacing:.3px; }
.gate-bg{ position:absolute; inset:0; pointer-events:none; }
.gate-orbit{ position:absolute; left:50%; top:50%; translate:-50% -50%; border-radius:50%; border:1px solid rgba(231,185,107,.16); animation:spin 50s linear infinite; }
.gate-orbit--one{ width:min(76vw,760px); aspect-ratio:1; }
.gate-orbit--two{ width:min(96vw,980px); aspect-ratio:1; animation-duration:76s; animation-direction:reverse; }
.gate-orbit--three{ width:min(116vw,1180px); aspect-ratio:1; animation-duration:112s; opacity:.6; }
.gate-shell{ position:relative; width:min(1220px,100%); min-height:min(790px,calc(100svh - 48px)); display:grid; grid-template-columns:.82fr 1.18fr; grid-template-rows:1fr auto; gap:26px; align-items:center; border:1px solid rgba(255,255,255,.08); border-radius:34px; padding:clamp(22px,4vw,48px); background:linear-gradient(145deg, rgba(4,12,24,.66), rgba(2,5,10,.58)); box-shadow:0 36px 130px -48px #000, inset 0 1px rgba(255,255,255,.08); backdrop-filter:blur(24px); overflow:hidden; }
.gate-shell::before{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, transparent, rgba(231,185,107,.1), transparent); transform:translateX(-120%); animation:shimmer 8s ease-in-out infinite; pointer-events:none; }
.gate-copy{ position:relative; z-index:2; }
.gate-logo{ width:112px; aspect-ratio:1; object-fit:cover; border-radius:50%; border:1px solid rgba(231,185,107,.48); box-shadow:var(--glow); margin-bottom:24px; }
.gate-copy h1{ font-family:var(--display); font-size:clamp(2.35rem,6vw,5.3rem); line-height:.98; letter-spacing:1px; max-width:620px; text-wrap:balance; }
.gate-copy p{ color:var(--muted); max-width:560px; margin-top:20px; font-size:1.05rem; }
.gate-map{ position:relative; min-height:460px; display:grid; place-items:center; z-index:2; }
.gate-globe{ position:relative; width:min(52vw,560px); aspect-ratio:1; border-radius:50%; overflow:hidden; border:1px solid rgba(231,185,107,.38); background:
  radial-gradient(circle at 34% 26%, rgba(255,255,255,.2), transparent 16%),
  radial-gradient(circle at 52% 52%, #102c55 0%, #07152b 64%, #02050a 100%);
  box-shadow:inset -44px -28px 70px rgba(0,0,0,.72), inset 22px 12px 46px rgba(255,255,255,.08), 0 0 120px -24px rgba(35,116,172,.95), 0 0 86px -24px rgba(231,185,107,.82); }
.gate-globe::before{ content:""; position:absolute; inset:-18%; border-radius:50%; background:conic-gradient(from 20deg, transparent 0 18deg, rgba(231,185,107,.12) 21deg, transparent 25deg 62deg, rgba(41,139,205,.14) 66deg, transparent 70deg); animation:spin 32s linear infinite; pointer-events:none; }
.gate-globe canvas{ position:absolute; inset:0; z-index:2; width:100%; height:100%; display:block; cursor:grab; touch-action:none; }
.gate-globe canvas:active{ cursor:grabbing; }
.globe-atmosphere{ position:absolute; inset:-1px; z-index:4; border-radius:50%; pointer-events:none; background:
  radial-gradient(circle at 32% 22%, rgba(255,255,255,.22), transparent 17%),
  radial-gradient(circle at 50% 50%, transparent 58%, rgba(231,185,107,.16) 72%, rgba(231,185,107,.36) 98%),
  linear-gradient(125deg, rgba(255,255,255,.12), transparent 31%, rgba(0,0,0,.38) 74%); mix-blend-mode:screen; }
.globe-pin-layer{ position:absolute; inset:0; z-index:6; pointer-events:none; }
.globe-pin{ position:absolute; width:14px; height:14px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 0 rgba(231,185,107,.72), 0 0 20px rgba(231,185,107,.9); translate:-50% -50%; animation:pinPulse 2s infinite; opacity:0; transition:opacity .18s ease, transform .18s ease; }
.globe-pin::after{ content:attr(data-label); position:absolute; left:16px; top:50%; translate:0 -50%; white-space:nowrap; font-size:.65rem; letter-spacing:1.2px; text-transform:uppercase; color:var(--gold-2); background:rgba(2,5,10,.68); border:1px solid rgba(231,185,107,.22); border-radius:999px; padding:.25rem .48rem; backdrop-filter:blur(8px); }
.globe-pin.is-visible{ opacity:1; }
.globe-pin.is-active{ transform:scale(1.28); background:#fff1c7; }
.globe-hint{ position:absolute; left:50%; bottom:18px; z-index:7; translate:-50% 0; white-space:nowrap; padding:.42rem .7rem; border-radius:999px; border:1px solid rgba(231,185,107,.18); background:rgba(2,5,10,.62); color:var(--muted); font-size:.68rem; letter-spacing:.3px; backdrop-filter:blur(10px); }
.gate-globe.is-loading::after{ content:"Sintonizando mapa..."; position:absolute; inset:auto 50% 50px auto; z-index:8; translate:50% 0; color:var(--gold); font-size:.72rem; letter-spacing:2px; text-transform:uppercase; }
.gate-tuning{ position:absolute; inset:auto 5% 3%; height:70px; display:flex; align-items:end; justify-content:center; gap:7px; opacity:.86; }
.gate-tuning span{ width:5px; min-height:18px; border-radius:3px; background:var(--gold-grad); animation:eq 1.1s ease-in-out infinite; }
.gate-tuning span:nth-child(2n){ animation-duration:.78s; }
.gate-tuning span:nth-child(3n){ animation-duration:1.35s; }
.gate-destinations{ grid-column:1/-1; display:grid; grid-template-columns:repeat(5,1fr); gap:10px; position:relative; z-index:3; }
.gate-destination{ min-height:76px; text-align:left; border:1px solid rgba(255,255,255,.1); border-radius:16px; padding:14px; background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02)); overflow:hidden; position:relative; transition:transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease; box-shadow:inset 0 1px rgba(255,255,255,.06); }
.gate-destination::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 0%, rgba(231,185,107,.18), transparent 50%); opacity:0; transition:opacity .25s ease; }
.gate-destination:hover,.gate-destination.preview,.gate-destination.active{ transform:translateY(-4px); border-color:rgba(231,185,107,.54); background:rgba(231,185,107,.09); box-shadow:0 20px 45px -30px rgba(231,185,107,.85), inset 0 1px rgba(255,255,255,.1); }
.gate-destination:hover::before,.gate-destination.preview::before,.gate-destination.active::before{ opacity:1; }
.gate-destination.preview:not(.active){ border-color:rgba(41,139,205,.48); }
.gate-destination span,.gate-destination strong{ position:relative; display:block; }
.gate-destination span{ font-family:var(--serif); font-size:1.02rem; line-height:1.05; color:var(--text); }
.gate-destination strong{ color:var(--gold); font-size:.62rem; letter-spacing:1.2px; text-transform:uppercase; margin-top:8px; }
.gate-status{ grid-column:1/-1; margin:0; color:var(--muted); text-align:center; position:relative; z-index:3; min-height:1.4em; }
.gate-enter{ display:none; }  /* shown only on touch/mobile (revealed by JS); desktop never displays it */

/* ---- Hero ---- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; padding-top:104px; padding-bottom:70px; overflow:hidden; isolation:isolate; background:#02050a; }
.hero::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none; background:
  radial-gradient(58% 42% at 50% 38%, transparent 0 52%, rgba(2,5,10,.18) 66%, rgba(2,5,10,.86) 100%),
  linear-gradient(180deg, rgba(2,5,10,.1) 0%, rgba(2,5,10,.18) 42%, rgba(2,5,10,.92) 100%); }
.hero__shader{ position:absolute; inset:0; z-index:0; width:100%; height:100%; background:
  radial-gradient(72% 46% at 50% 32%, rgba(18,88,142,.52), transparent 62%),
  radial-gradient(52% 38% at 54% 42%, rgba(231,185,107,.2), transparent 64%),
  #02050a; }
.hero__shader.shader-fallback{ background:
  radial-gradient(70% 45% at 50% 34%, rgba(37,131,203,.46), transparent 60%),
  radial-gradient(55% 42% at 50% 48%, rgba(231,185,107,.24), transparent 64%),
  linear-gradient(140deg,#02050a,#07152b 48%,#03060b); }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.45; }
.orb--1{ width:520px; height:520px; top:-120px; right:-80px; background:radial-gradient(circle, rgba(231,185,107,.5), transparent 70%); animation:float 12s ease-in-out infinite; }
.orb--2{ width:460px; height:460px; bottom:-160px; left:-120px; background:radial-gradient(circle, rgba(201,137,59,.4), transparent 70%); animation:float 15s ease-in-out infinite reverse; }
.hero__sun{ position:absolute; top:48%; left:50%; width:min(128vw,1180px); aspect-ratio:1; transform:translate(-50%,-50%); z-index:1; opacity:.13; color:var(--gold); animation:spin 120s linear infinite; }
.hero__content{ position:relative; z-index:2; text-align:center; display:grid; justify-items:center; width:100%; }
.eyebrow{ display:inline-flex; align-items:center; gap:.6em; padding:.5em 1.1em; border-radius:999px; border:1px solid rgba(231,185,107,.2); background:rgba(2,5,10,.42); font-size:.78rem; color:var(--muted); letter-spacing:1px; margin-bottom:16px; backdrop-filter:blur(14px); box-shadow:0 18px 50px -32px #000; }
.hero-globe{ position:relative; width:clamp(250px,36vw,470px); aspect-ratio:1; border-radius:50%; display:grid; place-items:center; margin:0 auto clamp(18px,3vw,34px); color:var(--text); filter:drop-shadow(0 34px 70px rgba(0,0,0,.62)); transition:transform .45s cubic-bezier(.2,.8,.2,1), filter .45s ease; }
.hero-globe:hover{ transform:translateY(-5px) scale(1.015); filter:drop-shadow(0 40px 90px rgba(47,158,232,.32)); }
body.is-playing .hero-globe{ filter:drop-shadow(0 34px 80px rgba(47,158,232,.36)) drop-shadow(0 0 44px rgba(231,185,107,.22)); }
body.is-playing .hero-globe__aura{ animation:softGlow 2.4s ease-in-out infinite; }
.hero-globe canvas{ position:absolute; inset:7%; z-index:3; width:86%; height:86%; border-radius:50%; display:block; }
.hero-globe__aura{ position:absolute; inset:4%; border-radius:50%; z-index:4; pointer-events:none; background:
  radial-gradient(circle at 30% 24%, rgba(255,255,255,.16), transparent 15%),
  radial-gradient(circle at 50% 50%, transparent 58%, rgba(47,158,232,.2) 72%, rgba(231,185,107,.36) 100%),
  linear-gradient(145deg, rgba(255,255,255,.08), transparent 36%, rgba(0,0,0,.48) 80%); box-shadow:inset -38px -28px 70px rgba(0,0,0,.5); }
.hero-globe__ring{ position:absolute; inset:-4%; border:1px solid rgba(231,185,107,.18); border-radius:50%; animation:spin 38s linear infinite; }
.hero-globe__ring--two{ inset:-11%; border-color:rgba(47,158,232,.18); animation-duration:58s; animation-direction:reverse; }
.hero__title{ font-family:var(--display); font-weight:700; font-size:clamp(2.35rem,7vw,5.8rem); line-height:.98; letter-spacing:1.4px; max-width:1100px; text-wrap:balance; }
.hero__subtitle{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,3.4vw,2rem); color:var(--gold); margin-top:16px; letter-spacing:1px; }
.hero__lead{ max-width:680px; margin:18px auto 0; color:rgba(246,239,228,.72); font-size:1.05rem; text-wrap:balance; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:30px; }
.hero__live{ display:none; }
.hero__live-meta{ display:none; }
.equalizer{ display:flex; align-items:flex-end; gap:3px; height:30px; }
.equalizer span{ width:3px; background:var(--gold-grad); border-radius:2px; animation:eq 1s ease-in-out infinite; }
.equalizer span:nth-child(odd){ animation-duration:.8s; } .equalizer span:nth-child(3n){ animation-duration:1.3s; }
.equalizer span:nth-child(1){height:40%} .equalizer span:nth-child(2){height:75%} .equalizer span:nth-child(3){height:55%}
.equalizer span:nth-child(4){height:90%} .equalizer span:nth-child(5){height:35%} .equalizer span:nth-child(6){height:70%}
.equalizer span:nth-child(7){height:50%} .equalizer span:nth-child(8){height:85%} .equalizer span:nth-child(9){height:45%} .equalizer span:nth-child(10){height:65%}
.scroll-hint{ display:none; }
.scroll-hint span{ display:none; }
@keyframes scrolldot{ 0%{ opacity:0; top:8px; } 40%{ opacity:1; } 80%{ opacity:0; top:22px; } }

/* ---- Sections ---- */
.section{ padding-block:clamp(70px,10vw,116px); position:relative; overflow:hidden; }
.section--alt{ background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 50%, var(--bg) 100%); }

/* ---- Removed old Media Hub ---- */
.media-hub{ display:none !important; }
.hub-shell,.hub-tabs,.hub-panels,.hub-panel{ display:none; }
/*
.hub-shell{ display:grid; grid-template-columns:1fr; gap:18px; padding:18px; border:1px solid var(--card-border); border-radius:var(--radius); background:rgba(11,9,7,.72); box-shadow:0 22px 70px -42px #000; overflow:hidden; position:relative; }
.hub-shell::before{ content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(90deg, transparent, rgba(231,185,107,.1), transparent); transform:translateX(-120%); animation:shimmer 9s ease-in-out infinite; }
.hub-shell__intro{ display:grid; grid-template-columns:minmax(0,1fr); gap:4px; position:relative; }
.hub-shell__intro h2{ font-family:var(--serif); font-size:clamp(1.55rem,3vw,2.25rem); font-weight:600; line-height:1.1; }
.hub-shell__intro p{ max-width:720px; color:var(--muted); font-size:.96rem; }
.hub-tabs{ display:grid; grid-template-columns:repeat(5,1fr); gap:8px; position:relative; }
.hub-tab{ min-height:42px; border-radius:999px; border:1px solid var(--card-border); background:rgba(255,255,255,.035); color:var(--muted); font-weight:700; font-size:.78rem; letter-spacing:.6px; transition:background .25s ease, color .25s ease, transform .25s ease, border-color .25s ease; }
.hub-tab:hover{ color:var(--text); border-color:rgba(231,185,107,.42); transform:translateY(-1px); }
.hub-tab.active{ background:var(--gold-grad); color:#241606; border-color:transparent; box-shadow:0 0 34px -12px rgba(231,185,107,.7); }
.hub-panels{ position:relative; min-height:138px; border-radius:16px; overflow:hidden; border:1px solid rgba(231,185,107,.1); background:linear-gradient(135deg, rgba(231,185,107,.08), rgba(255,255,255,.025)); }
.hub-panel{ position:absolute; inset:0; display:grid; align-content:center; gap:6px; padding:20px 24px; opacity:0; transform:translateY(14px); pointer-events:none; transition:opacity .35s ease, transform .35s ease; }
.hub-panel.active{ opacity:1; transform:none; pointer-events:auto; }
.hub-panel h3{ font-family:var(--serif); font-size:1.45rem; font-weight:600; }
.hub-panel p{ color:var(--muted); max-width:760px; }
.hub-panel__tag{ color:var(--gold); font-size:.72rem; text-transform:uppercase; letter-spacing:2px; font-weight:800; }
*/

/* ---- Radio player ---- */
.radio{ display:grid; gap:24px; }
.player{ display:grid; grid-template-columns:minmax(260px,320px) minmax(0,1fr); gap:34px; align-items:stretch; background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); backdrop-filter:blur(10px); position:relative; overflow:hidden; }
.player::before{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(80% 120% at 0% 0%, rgba(231,185,107,.12), transparent 55%); }
.player::after{ content:""; position:absolute; inset:-20% -35%; pointer-events:none; background:repeating-linear-gradient(90deg, transparent 0 26px, rgba(231,185,107,.08) 26px 27px, transparent 27px 54px), linear-gradient(90deg, transparent, rgba(47,158,232,.13), rgba(231,185,107,.09), transparent); mix-blend-mode:screen; animation:consoleSweep 7s ease-in-out infinite alternate; opacity:.72; }
.player__art{ position:relative; z-index:2; aspect-ratio:1; border-radius:var(--radius-sm); overflow:hidden; display:grid; place-items:center; background:linear-gradient(140deg,#06182f,#0e0b08); border:1px solid var(--card-border); width:100%; color:var(--text); }
.player__art-glow{ position:absolute; width:150%; height:150%; border-radius:50%; background:conic-gradient(from 0deg, rgba(231,185,107,.0), rgba(231,185,107,.4), rgba(231,185,107,0)); filter:blur(10px); animation:spin 14s linear infinite; }
.player__art-mark{ position:relative; font-family:var(--display); font-weight:700; font-size:3.2rem; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.player__logo{ display:none; }
.player__globe-card{ cursor:pointer; transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease; }
.player__globe-card:hover{ transform:translateY(-3px); border-color:rgba(231,185,107,.5); box-shadow:0 0 70px -34px rgba(231,185,107,.9); }
.player__globe-card canvas{ position:absolute; inset:8%; z-index:2; width:84%; height:84%; border-radius:50%; display:block; }
.player-globe__atmosphere{ position:absolute; inset:8%; z-index:4; border-radius:50%; pointer-events:none; background:
  radial-gradient(circle at 30% 22%, rgba(255,255,255,.18), transparent 16%),
  radial-gradient(circle at 50% 50%, transparent 59%, rgba(231,185,107,.2) 76%, rgba(231,185,107,.44) 100%),
  linear-gradient(135deg, rgba(255,255,255,.1), transparent 35%, rgba(0,0,0,.52) 82%); }
.player__body{ position:relative; z-index:2; display:flex; flex-direction:column; justify-content:center; min-width:0; }
.player__now{ font-family:var(--serif); font-size:1.9rem; font-weight:600; margin-top:8px; }
.player__sub{ color:var(--muted); margin-bottom:12px; }
.track-row{ display:flex; align-items:center; justify-content:space-between; gap:14px; width:min(100%,520px); margin:0 0 10px; color:var(--gold-2); font-size:.78rem; letter-spacing:.8px; text-transform:uppercase; font-weight:800; }
.track-row span:first-child{ overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.track-row span:last-child{ flex-shrink:0; color:var(--muted); font-weight:700; letter-spacing:.4px; }
.signal-board{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; margin-top:18px; max-width:760px; }
.signal-card{ position:relative; min-height:118px; padding:16px; border-radius:18px; border:1px solid rgba(231,185,107,.14); background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(255,255,255,.015)); box-shadow:inset 0 1px rgba(255,255,255,.06); overflow:hidden; }
.signal-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 18% 0%,rgba(47,158,232,.18),transparent 48%); opacity:.75; pointer-events:none; }
.signal-card--active{ border-color:rgba(255,94,84,.34); background:linear-gradient(145deg,rgba(255,94,84,.08),rgba(231,185,107,.035)); }
.signal-card span{ position:relative; display:block; color:var(--gold); font-size:.68rem; letter-spacing:1.6px; text-transform:uppercase; font-weight:800; margin-bottom:10px; }
.signal-card strong{ position:relative; display:block; font-family:var(--serif); font-size:1.08rem; line-height:1.05; font-weight:650; color:var(--text); }
.signal-card small{ position:relative; display:block; color:var(--muted); line-height:1.35; font-size:.78rem; margin-top:8px; }
.signal-board,.signal-card{ display:none !important; }
.rotation-panel{ margin-top:12px; }
.rotation-panel{ display:grid; grid-template-columns:132px minmax(0,1fr); gap:18px; align-items:start; margin-top:16px; max-width:760px; padding:18px; border-radius:20px; border:1px solid rgba(231,185,107,.14); background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(255,255,255,.018)); box-shadow:inset 0 1px rgba(255,255,255,.06); }
.rotation-panel__media{ position:relative; }
.rotation-panel__media img{ width:132px; aspect-ratio:1/1; object-fit:cover; border-radius:18px; border:1px solid rgba(231,185,107,.18); background:linear-gradient(145deg,rgba(7,16,27,.96),rgba(14,24,36,.88)); box-shadow:0 12px 30px -18px rgba(0,0,0,.9); }
.rotation-panel__body{ min-width:0; }
.rotation-panel__eyebrow{ display:block; color:var(--gold); font-size:.68rem; letter-spacing:1.8px; text-transform:uppercase; font-weight:800; margin-bottom:8px; }
.rotation-panel__body h3{ font-family:var(--serif); font-size:1.35rem; line-height:1.12; font-weight:650; color:var(--text); }
.rotation-panel__body p{ color:var(--muted); font-size:.9rem; line-height:1.45; margin-top:8px; }
.rotation-panel__facts{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-top:14px; }
.rotation-fact{ padding:12px 14px; border-radius:16px; border:1px solid rgba(231,185,107,.12); background:rgba(255,255,255,.02); }
.rotation-fact--wide{ grid-column:1 / -1; }
.rotation-fact span{ display:block; color:var(--muted-2); font-size:.64rem; letter-spacing:1.4px; text-transform:uppercase; font-weight:800; margin-bottom:6px; }
.rotation-fact strong{ display:block; color:var(--text); font-size:.95rem; line-height:1.3; font-weight:600; }
.rotation-panel__links{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.rotation-panel__links .chip{ min-height:40px; }
.rotation-panel.is-empty .rotation-panel__links{ opacity:.58; pointer-events:none; }
.rotation-panel.is-loading .rotation-panel__media img{ filter:saturate(.82) brightness(.9); }
.rotation-panel.is-loading .rotation-panel__eyebrow::after{ content:" · loading"; color:var(--muted-2); }

.player__volume{ display:flex; align-items:center; gap:8px; }
.mute-btn{ color:var(--muted); transition:color .2s; } .mute-btn:hover{ color:var(--text); }
#volume{ -webkit-appearance:none; appearance:none; width:110px; height:4px; border-radius:4px; background:rgba(255,255,255,.15); outline:none; }
#volume::-webkit-slider-thumb{ -webkit-appearance:none; width:15px; height:15px; border-radius:50%; background:var(--gold); box-shadow:var(--glow); cursor:pointer; }
#volume::-moz-range-thumb{ width:15px; height:15px; border:none; border-radius:50%; background:var(--gold); cursor:pointer; }
.player__status{ font-size:.82rem; color:var(--muted-2); }
.radio__links{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.chip{ display:inline-flex; align-items:center; gap:.5em; padding:.6em 1.2em; border-radius:999px; background:var(--card); border:1px solid var(--card-border); font-size:.85rem; color:var(--muted); transition:.25s; }
.chip:hover{ color:var(--text); border-color:rgba(231,185,107,.5); transform:translateY(-2px); }
.chip--live{ color:#ffd9d4; border-color:rgba(255,90,77,.4); }

/* ---- Podcast ---- */
.episodes{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.episode{ display:flex; gap:18px; align-items:center; background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius-sm); padding:16px; transition:.3s; cursor:pointer; }
.episode:hover{ border-color:rgba(231,185,107,.4); transform:translateY(-3px); }
.episode__art{ position:relative; width:84px; height:84px; border-radius:12px; flex-shrink:0; background-size:cover; background-position:center; overflow:hidden; }
.episode__art::after{ content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(231,185,107,.25), rgba(0,0,0,.5)); }
.episode__play{ position:absolute; inset:0; z-index:2; display:grid; place-items:center; color:#fff; }
.episode__play svg{ filter:drop-shadow(0 2px 6px rgba(0,0,0,.6)); }
.episode.playing .episode__art{ box-shadow:0 0 0 2px var(--gold); }
.episode__info{ min-width:0; }
.episode__cat{ font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold); font-weight:700; }
.episode__title{ font-family:var(--serif); font-size:1.25rem; font-weight:600; margin-top:2px; }
.episode__meta{ color:var(--muted-2); font-size:.82rem; margin-top:4px; }

/* ---- TV ---- */
.tv-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.vcard{ background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); overflow:hidden; transition:transform .3s ease, border-color .3s ease; }
.vcard:hover{ transform:translateY(-4px); border-color:rgba(231,185,107,.4); }
.vcard--feature{ grid-row:span 2; }
.vcard__media{ position:relative; aspect-ratio:16/9; display:grid; place-items:center; background-size:cover; background-position:center; cursor:pointer; }
.vcard--feature .vcard__media{ aspect-ratio:16/12; }
.vcard__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,7,6,.15), rgba(8,7,6,.7)); transition:.3s; }
.vcard:hover .vcard__media::after{ background:linear-gradient(180deg, rgba(8,7,6,.05), rgba(8,7,6,.55)); }
.vcard__play{ position:relative; z-index:2; display:grid; place-items:center; width:64px; height:64px; border-radius:50%; background:rgba(8,7,6,.5); border:1px solid rgba(231,185,107,.6); color:var(--gold); backdrop-filter:blur(6px); transition:.25s; }
.vcard:hover .vcard__play{ background:var(--gold-grad); color:#241606; transform:scale(1.08); }
.vcard__badge{ position:absolute; top:14px; left:14px; z-index:2; padding:.35em .8em; border-radius:999px; font-size:.68rem; font-weight:700; letter-spacing:1.5px; background:var(--gold-grad); color:#241606; }
.vcard__media iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; z-index:3; }
.vcard__info{ padding:18px 20px; }
.vcard__cat{ font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:700; }
.vcard__info h3{ font-family:var(--serif); font-size:1.35rem; font-weight:600; margin-top:6px; }
.vcard__info p{ color:var(--muted); font-size:.92rem; margin-top:6px; }
.tv-grid--legacy[hidden]{ display:none !important; }
.tv-theater{ display:grid; grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr); gap:22px; align-items:stretch; margin-bottom:24px; }
.theater-stage{ position:relative; min-height:420px; border-radius:var(--radius); overflow:hidden; border:1px solid rgba(231,185,107,.22); background:#0c0907 center/cover no-repeat; box-shadow:var(--shadow); isolation:isolate; }
.theater-stage::before{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(8,7,6,.1), rgba(8,7,6,.76)); pointer-events:none; }
.theater-stage::after{ content:""; position:absolute; inset:auto 0 0; z-index:2; height:46%; background:repeating-linear-gradient(90deg, rgba(231,185,107,.16) 0 1px, transparent 1px 22px); opacity:.28; transform:skewY(-4deg); pointer-events:none; }
.theater-stage iframe{ position:absolute; inset:0; z-index:5; width:100%; height:100%; border:0; }
.theater-poster{ position:absolute; inset:0; z-index:3; display:grid; align-content:end; gap:14px; padding:28px; cursor:pointer; }
.theater-poster__play{ width:76px; height:76px; display:grid; place-items:center; border-radius:50%; background:var(--gold-grad); color:#241606; box-shadow:0 0 54px -6px rgba(231,185,107,.75); transition:transform .25s ease; }
.theater-poster:hover .theater-poster__play{ transform:scale(1.06); }
.theater-poster__label{ display:inline-flex; width:max-content; align-items:center; gap:8px; padding:.45em .8em; border-radius:999px; background:rgba(8,7,6,.68); border:1px solid rgba(231,185,107,.35); color:var(--gold); font-size:.72rem; font-weight:800; letter-spacing:1.7px; text-transform:uppercase; backdrop-filter:blur(8px); }
.theater-side{ display:flex; flex-direction:column; justify-content:center; gap:14px; border:1px solid var(--card-border); border-radius:var(--radius); background:linear-gradient(150deg, rgba(255,255,255,.055), rgba(231,185,107,.07)); padding:28px; position:relative; overflow:hidden; }
.theater-side::before{ content:""; position:absolute; width:210px; height:210px; right:-90px; top:-90px; border-radius:50%; background:radial-gradient(circle, rgba(231,185,107,.22), transparent 70%); animation:softGlow 8s ease-in-out infinite; }
.theater-side h3{ font-family:var(--serif); font-size:clamp(1.7rem,3.2vw,2.35rem); line-height:1.08; font-weight:600; position:relative; }
.theater-side p{ color:var(--muted); position:relative; }
.theater-actions{ display:flex; flex-wrap:wrap; gap:12px; position:relative; }
.theater-note{ color:var(--muted-2); font-size:.82rem; border-top:1px solid rgba(231,185,107,.12); padding-top:14px; position:relative; }
.video-filters{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:28px 0 18px; }
.video-filter{ padding:.62em 1.1em; border-radius:999px; border:1px solid var(--card-border); background:rgba(255,255,255,.035); color:var(--muted); font-size:.78rem; font-weight:800; letter-spacing:1px; text-transform:uppercase; transition:.25s; }
.video-filter.active,.video-filter:hover{ background:var(--gold-grad); color:#241606; border-color:transparent; transform:translateY(-2px); }
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.video-card{ border:1px solid var(--card-border); border-radius:var(--radius-sm); overflow:hidden; background:var(--card); cursor:pointer; transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.video-card:hover{ transform:translateY(-4px); border-color:rgba(231,185,107,.45); box-shadow:0 20px 48px -34px rgba(231,185,107,.6); }
.video-card.active{ border-color:rgba(231,185,107,.7); box-shadow:var(--glow); }
.video-card__thumb{ position:relative; aspect-ratio:16/9; background-size:cover; background-position:center; }
.video-card__thumb::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,7,6,.08), rgba(8,7,6,.7)); }
.video-card__play{ position:absolute; inset:auto 14px 12px auto; z-index:2; width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#241606; background:var(--gold-grad); }
.video-card__body{ padding:16px; }
.video-card__cat{ color:var(--gold); font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; font-weight:800; }
.video-card__body h3{ font-family:var(--serif); font-size:1.25rem; line-height:1.15; margin-top:6px; font-weight:600; }
.video-card__body p{ color:var(--muted); font-size:.88rem; margin-top:6px; }

/* ---- Schedule grid ---- */
.schedule-wrap{ overflow-x:auto; padding-bottom:8px; }
.schedule{ display:grid; grid-template-columns:90px repeat(7, minmax(120px,1fr)); gap:8px; min-width:760px; }
.sch-cell{ background:var(--card); border:1px solid var(--card-border); border-radius:10px; padding:12px 10px; font-size:.84rem; }
.sch-head{ font-family:var(--display); font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); text-align:center; background:transparent; border:none; }
.sch-time{ display:flex; align-items:center; justify-content:center; font-size:.72rem; color:var(--muted-2); letter-spacing:1px; background:transparent; border:none; }
.sch-prog{ font-weight:600; color:var(--text); }
.sch-prog span{ display:block; font-weight:400; font-size:.72rem; color:var(--muted-2); margin-top:2px; }
.sch-cell.live{ border-color:rgba(231,185,107,.5); background:linear-gradient(135deg, rgba(231,185,107,.14), var(--card)); }

/* ---- About ---- */
.about{ display:grid; grid-template-columns:1.1fr .9fr; gap:54px; align-items:center; }
.about__text h2{ font-family:var(--serif); font-size:clamp(1.9rem,4vw,2.8rem); font-weight:600; line-height:1.12; }
.about__text p{ color:var(--muted); margin-top:18px; }
.stats{ display:flex; gap:34px; margin-top:32px; flex-wrap:wrap; }
.stat strong{ display:block; font-family:var(--serif); font-size:2.2rem; color:var(--gold); line-height:1; }
.stat span{ font-size:.82rem; color:var(--muted-2); letter-spacing:.5px; }
.about__cards{ display:grid; gap:16px; }
.mini-card{ background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius-sm); padding:22px 24px; transition:.3s; }
.mini-card:hover{ border-color:rgba(231,185,107,.4); transform:translateX(4px); }
.mini-card h3{ font-family:var(--serif); font-size:1.3rem; color:var(--gold); font-weight:600; }
.mini-card p{ color:var(--muted); font-size:.93rem; margin-top:6px; }

/* ---- Founder ---- */
.founder{ display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; align-items:center; }
.founder__portrait{ position:relative; aspect-ratio:4/5; max-width:380px; }
.founder__glow{ position:absolute; inset:-14%; color:var(--gold); opacity:.4; animation:spin 90s linear infinite; }
.founder__frame{ position:relative; height:100%; border-radius:24px; border:1px solid var(--card-border); background:linear-gradient(150deg,#2a1d10,#0d0a07); display:grid; place-items:center; overflow:hidden; }
.founder__frame::before{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, transparent 48%, rgba(8,7,6,.82) 100%); pointer-events:none; }
.founder__frame::after{ content:attr(data-cap); position:absolute; bottom:16px; left:0; right:0; z-index:2; text-align:center; font-size:.7rem; letter-spacing:2px; color:var(--gold-2); text-shadow:0 2px 12px rgba(0,0,0,.7); }
.founder__frame img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.founder__frame span{ font-family:var(--display); font-weight:700; font-size:4.4rem; letter-spacing:2px; background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; display:flex; align-items:flex-start; }
.founder__frame span small{ font-size:1.5rem; margin-top:.4em; }
.founder__text h2{ font-family:var(--serif); font-size:clamp(2rem,4.4vw,3rem); font-weight:600; }
.founder__text p{ color:var(--muted); margin-top:16px; }
.founder__text blockquote{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--gold); margin-top:26px; padding-left:20px; border-left:3px solid var(--gold); line-height:1.4; }

/* ---- Programming cards ---- */
.prog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.prog-card{ background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:28px 26px; transition:.3s; position:relative; overflow:hidden; }
.prog-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold-grad); transform:scaleX(0); transform-origin:left; transition:transform .35s ease; }
.prog-card:hover{ transform:translateY(-5px); border-color:rgba(231,185,107,.4); }
.prog-card:hover::before{ transform:scaleX(1); }
.prog-card__icon{ display:grid; place-items:center; width:50px; height:50px; border-radius:14px; background:rgba(231,185,107,.12); color:var(--gold); font-size:1.4rem; margin-bottom:16px; }
.prog-card h3{ font-family:var(--serif); font-size:1.5rem; font-weight:600; }
.prog-card p{ color:var(--muted); font-size:.93rem; margin-top:6px; }
.prog-card__time{ display:inline-block; margin-top:16px; font-size:.74rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted-2); }

/* ---- Sponsors ---- */
.featured-sponsor{ display:grid; grid-template-columns:auto 1fr auto; gap:26px; align-items:center; background:linear-gradient(135deg, rgba(231,185,107,.14), var(--card)); border:1px solid rgba(231,185,107,.3); border-radius:var(--radius); padding:26px 30px; margin-bottom:30px; box-shadow:var(--shadow); }
.featured-sponsor__logo{ width:130px; height:90px; border-radius:14px; overflow:hidden; display:grid; place-items:center; background:#0e0b08; border:1px solid var(--card-border); }
.featured-sponsor__logo img{ width:100%; height:100%; object-fit:contain; padding:8px; }
.featured-sponsor__logo span{ font-family:var(--display); font-size:1.4rem; color:var(--gold); text-align:center; padding:6px; line-height:1.1; }
.featured-sponsor__body .tag{ font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:700; }
.featured-sponsor__body h3{ font-family:var(--serif); font-size:1.7rem; font-weight:600; margin-top:4px; }
.featured-sponsor__body p{ color:var(--muted); font-size:.95rem; margin-top:4px; }
.sponsor-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(170px,1fr)); gap:16px; margin-bottom:46px; }
.sponsor-card{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; aspect-ratio:16/10; background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius-sm); padding:18px; transition:.3s; text-align:center; }
.sponsor-card:hover{ transform:translateY(-4px); border-color:rgba(231,185,107,.45); box-shadow:var(--glow); }
.sponsor-card img{ max-height:60px; width:auto; object-fit:contain; }
.sponsor-card__name{ font-family:var(--serif); font-size:1.15rem; color:var(--text); line-height:1.1; }
.sponsor-card__cat{ font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted-2); }

/* Sponsor visuals: real sponsor thumbnails instead of blank logo blocks */
.featured-sponsor{ grid-template-columns:minmax(220px,300px) 1fr auto; align-items:stretch; }
.featured-sponsor__logo{ width:100%; min-height:150px; height:100%; border-radius:18px; background:#080b10; }
.featured-sponsor__logo img{ width:100%; height:100%; object-fit:cover; padding:0; }
.sponsor-grid{ grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); }
.sponsor-card{ align-items:stretch; justify-content:flex-start; gap:0; aspect-ratio:auto; min-height:230px; padding:0; overflow:hidden; background:linear-gradient(145deg,rgba(255,255,255,.05),rgba(255,255,255,.018)); }
.sponsor-card img{ width:100%; height:132px; max-height:none; object-fit:cover; padding:0; border-bottom:1px solid rgba(231,185,107,.14); background:#0a0d13; }
.sponsor-card > span:not(.sponsor-card__name):not(.sponsor-card__cat){ display:grid; place-items:center; width:100%; height:132px; font-family:var(--display); font-size:1.35rem; color:var(--gold); border-bottom:1px solid rgba(231,185,107,.14); background:radial-gradient(circle at 50% 20%,rgba(231,185,107,.18),rgba(255,255,255,.025)); }
.sponsor-card__name{ display:block; padding:14px 14px 4px; font-size:1.12rem; }
.sponsor-card__cat{ display:block; padding:0 14px 14px; }
@media (max-width:700px){ .featured-sponsor{ grid-template-columns:1fr; } .featured-sponsor__logo{ min-height:190px; } .sponsor-card{ min-height:220px; } }

.advertise{ display:flex; align-items:center; justify-content:space-between; gap:26px; flex-wrap:wrap; background:linear-gradient(135deg,#221813,#100d09); border:1px solid var(--card-border); border-radius:var(--radius); padding:34px 38px; }
.advertise__text h3{ font-family:var(--serif); font-size:1.8rem; font-weight:600; }
.advertise__text p{ color:var(--muted); margin-top:8px; max-width:560px; }
.media-kit{ display:grid; grid-template-columns:.9fr 1.1fr; gap:22px; align-items:stretch; margin:6px 0 30px; }
.media-kit__copy{ border:1px solid rgba(231,185,107,.18); border-radius:var(--radius); padding:28px; background:linear-gradient(150deg, rgba(231,185,107,.1), rgba(255,255,255,.035)); position:relative; overflow:hidden; }
.media-kit__copy::after{ content:""; position:absolute; width:190px; height:190px; right:-70px; bottom:-70px; border-radius:50%; background:radial-gradient(circle, rgba(231,185,107,.18), transparent 70%); }
.media-kit__copy h3{ font-family:var(--serif); font-size:clamp(1.7rem,3vw,2.25rem); line-height:1.1; font-weight:600; }
.media-kit__copy p{ color:var(--muted); margin-top:12px; }
.placement-preview{ display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.placement-preview span{ padding:.55em .85em; border-radius:999px; background:rgba(8,7,6,.45); border:1px solid rgba(231,185,107,.2); color:var(--gold-2); font-size:.78rem; font-weight:700; }
.package-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.package-card{ min-height:100%; border:1px solid var(--card-border); border-radius:var(--radius-sm); padding:22px 18px; background:rgba(255,255,255,.04); transition:.25s ease; }
.package-card:hover{ transform:translateY(-4px); border-color:rgba(231,185,107,.42); }
.package-card--featured{ background:linear-gradient(145deg, rgba(231,185,107,.18), rgba(255,255,255,.04)); border-color:rgba(231,185,107,.36); }
.package-card__tier{ color:var(--gold); text-transform:uppercase; font-size:.68rem; letter-spacing:1.8px; font-weight:800; }
.package-card h4{ font-family:var(--serif); font-size:1.3rem; line-height:1.1; margin-top:8px; font-weight:600; }
.package-card p{ color:var(--muted); font-size:.88rem; margin-top:8px; }


/* ---- Sponsor / Advertising Media Kit Upgrade ---- */
.sponsor-head p{ max-width:820px; }
.sponsor-hero{ display:grid; grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr); gap:22px; align-items:stretch; margin-bottom:22px; }
.sponsor-hero__copy{ position:relative; overflow:hidden; border:1px solid rgba(231,185,107,.18); border-radius:var(--radius); padding:34px; background:linear-gradient(145deg,rgba(231,185,107,.12),rgba(255,255,255,.035)); box-shadow:var(--shadow); }
.sponsor-hero__copy::after{ content:""; position:absolute; width:260px; height:260px; right:-100px; bottom:-100px; border-radius:50%; background:radial-gradient(circle,rgba(231,185,107,.2),transparent 68%); pointer-events:none; }
.sponsor-hero__copy h3{ font-family:var(--serif); font-size:clamp(2rem,4vw,3.2rem); line-height:1.02; font-weight:600; max-width:720px; }
.sponsor-hero__copy p{ color:var(--muted); margin-top:14px; max-width:720px; }
.sponsor-hero__actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.sponsor-hero__panel{ position:relative; min-height:280px; border:1px solid rgba(231,185,107,.2); border-radius:var(--radius); padding:28px; overflow:hidden; background:radial-gradient(circle at 50% 30%,rgba(47,158,232,.22),transparent 38%),linear-gradient(145deg,rgba(8,7,6,.92),rgba(22,17,11,.72)); display:flex; flex-direction:column; justify-content:flex-end; box-shadow:var(--shadow); }
.sponsor-hero__panel::before{ content:""; position:absolute; inset:20px; border:1px solid rgba(231,185,107,.16); border-radius:50%; opacity:.7; }
.sponsor-hero__panel strong{ position:relative; font-family:var(--serif); font-size:1.6rem; font-weight:650; }
.sponsor-hero__panel p{ position:relative; color:var(--muted); margin-top:8px; }
.channel-orbit{ position:absolute; inset:22px; animation:slowSpin 28s linear infinite; }
.channel-orbit span{ position:absolute; display:inline-flex; align-items:center; justify-content:center; min-width:84px; min-height:34px; padding:0 12px; border-radius:999px; color:var(--gold-2); border:1px solid rgba(231,185,107,.24); background:rgba(8,7,6,.58); font-size:.72rem; letter-spacing:1px; text-transform:uppercase; font-weight:800; animation:slowSpin 28s linear infinite reverse; }
.channel-orbit span:nth-child(1){ top:6%; left:42%; }
.channel-orbit span:nth-child(2){ top:42%; right:2%; }
.channel-orbit span:nth-child(3){ bottom:8%; left:36%; }
.channel-orbit span:nth-child(4){ top:42%; left:0; }
.sponsor-placements{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; margin:18px 0 26px; }
.placement-card{ position:relative; min-height:220px; padding:22px; border-radius:var(--radius-sm); border:1px solid rgba(231,185,107,.14); background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(255,255,255,.015)); overflow:hidden; transition:.25s ease; }
.placement-card:hover{ transform:translateY(-5px); border-color:rgba(231,185,107,.38); box-shadow:var(--glow); }
.placement-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 20% 0%,rgba(231,185,107,.2),transparent 42%); opacity:.75; }
.placement-card--radio::after,.placement-card--tv::after,.placement-card--web::after,.placement-card--community::after{ content:""; position:absolute; right:-30px; bottom:-30px; width:130px; height:130px; border-radius:50%; border:1px solid rgba(231,185,107,.18); background:rgba(255,255,255,.025); }
.placement-card span,.placement-card h3,.placement-card p{ position:relative; }
.placement-card span{ color:var(--gold); font-size:.66rem; letter-spacing:1.8px; text-transform:uppercase; font-weight:800; }
.placement-card h3{ font-family:var(--serif); font-size:1.5rem; line-height:1.05; margin-top:14px; font-weight:650; }
.placement-card p{ color:var(--muted); font-size:.9rem; margin-top:10px; }
.sponsor-showcase{ display:grid; grid-template-columns:.75fr 1.25fr; gap:22px; align-items:start; margin:24px 0 32px; }
.sponsor-showcase__text{ border:1px solid rgba(231,185,107,.14); border-radius:var(--radius); padding:28px; background:rgba(255,255,255,.035); }
.sponsor-showcase__text h3{ font-family:var(--serif); font-size:2rem; line-height:1.05; font-weight:600; }
.sponsor-showcase__text p{ color:var(--muted); margin-top:12px; }
.sponsor-showcase__logos .featured-sponsor{ margin-bottom:16px; }
.sponsor-showcase__logos .sponsor-grid{ margin-bottom:0; }
.media-kit--impact{ margin-top:4px; }
.package-grid--impact .package-card{ min-height:210px; }
.sponsor-benefits{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:0 0 28px; }
.sponsor-benefits article{ border:1px solid rgba(231,185,107,.14); border-radius:var(--radius-sm); padding:20px; background:rgba(255,255,255,.035); }
.sponsor-benefits span{ display:block; color:var(--gold); font-size:.66rem; letter-spacing:1.8px; text-transform:uppercase; font-weight:800; margin-bottom:10px; }
.sponsor-benefits strong{ display:block; font-family:var(--serif); font-size:1.25rem; line-height:1.18; font-weight:600; color:var(--text); }
.advertise--impact{ background:linear-gradient(135deg,rgba(231,185,107,.16),rgba(16,13,9,.92)); box-shadow:var(--shadow); }

/* ---- Join / Podcast Request Utility ---- */
.join-grid{ display:grid; grid-template-columns:minmax(0,.86fr) minmax(0,1.14fr); gap:18px; align-items:stretch; }
.join-card{ position:relative; padding:22px; border-radius:22px; border:1px solid rgba(231,185,107,.14); background:linear-gradient(145deg,rgba(255,255,255,.05),rgba(255,255,255,.018)); box-shadow:var(--shadow); overflow:hidden; }
.join-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 15% 0%,rgba(231,185,107,.16),transparent 48%), radial-gradient(circle at 92% 8%,rgba(47,158,232,.12),transparent 42%); pointer-events:none; }
.join-card > *{ position:relative; }
.join-card--feature{ border-color:rgba(231,185,107,.22); }
.join-card__tag{ display:inline-flex; align-items:center; gap:8px; color:var(--gold); font-size:.68rem; letter-spacing:1.8px; text-transform:uppercase; font-weight:800; margin-bottom:12px; }
.join-card h3{ font-family:var(--serif); font-size:clamp(1.45rem,3vw,2rem); line-height:1.05; margin-bottom:10px; }
.join-card p{ color:var(--muted); font-size:.94rem; line-height:1.55; margin-bottom:16px; }
.join-card small{ display:block; color:var(--muted-2); font-size:.75rem; margin-top:10px; line-height:1.4; }
.join-card__split{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.field select{ width:100%; border:1px solid rgba(231,185,107,.17); border-radius:14px; padding:13px 14px; background:rgba(5,8,13,.74); color:var(--text); outline:none; font-family:inherit; }
.field select:focus{ border-color:rgba(231,185,107,.45); box-shadow:0 0 0 3px rgba(231,185,107,.08); }
.hidden-field{ position:absolute !important; left:-9999px !important; width:1px !important; height:1px !important; overflow:hidden !important; }
@media (max-width:860px){
  .join-grid{ grid-template-columns:1fr; }
  .join-card__split{ grid-template-columns:1fr; gap:0; }
}
@media (max-width:520px){
  .join-card{ padding:18px; border-radius:20px; }
  .join-card h3{ font-size:1.45rem; }
}

@media (max-width:980px){
  .sponsor-hero,.sponsor-showcase,.media-kit{ grid-template-columns:1fr; }
  .sponsor-placements{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .sponsor-benefits{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  .sponsor-hero__copy,.sponsor-hero__panel,.sponsor-showcase__text{ padding:22px; }
  .sponsor-placements{ grid-template-columns:1fr; }
  .placement-card{ min-height:auto; }
  .channel-orbit{ animation:none; }
  .channel-orbit span{ animation:none; }
}

/* ---- Gallery ---- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:180px; gap:14px; }
.gtile{ position:relative; border-radius:var(--radius-sm); overflow:hidden; background-size:cover; background-position:center; background-color:#16110b; border:1px solid var(--card-border); }
.gtile::before{ content:""; position:absolute; inset:0; background:linear-gradient(140deg, rgba(231,185,107,.18), rgba(8,7,6,.55)); mix-blend-mode:multiply; }
.gtile::after{ content:attr(data-label); position:absolute; inset:auto 0 0 0; padding:14px; font-size:.8rem; letter-spacing:1px; color:var(--text); background:linear-gradient(transparent, rgba(0,0,0,.7)); opacity:0; transform:translateY(8px); transition:.3s; }
.gtile:hover::after{ opacity:1; transform:none; }
.gtile:hover{ border-color:rgba(231,185,107,.5); }
.gtile--lg{ grid-column:span 2; grid-row:span 2; }
.gtile--wide{ grid-column:span 2; }

/* ---- Contact ---- */
.contact{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
.contact__info h2{ font-family:var(--serif); font-size:clamp(2rem,4.4vw,3rem); font-weight:600; }
.contact__info > p{ color:var(--muted); margin-top:14px; }
.contact__list{ list-style:none; margin-top:30px; display:grid; gap:18px; }
.contact__list li{ display:flex; flex-direction:column; gap:2px; }
.contact__list span:first-child{ font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); }
.contact__list a, .contact__list li > span:last-child{ font-size:1.1rem; color:var(--text); }
.contact__list a:hover{ color:var(--gold); }
.contact__social{ display:flex; gap:18px; margin-top:28px; }
.contact__social a{ font-size:.88rem; color:var(--muted); }
.contact__social a:hover{ color:var(--gold); }
.contact__form{ background:var(--card); border:1px solid var(--card-border); border-radius:var(--radius); padding:30px; backdrop-filter:blur(10px); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.8rem; letter-spacing:1px; color:var(--muted); margin-bottom:8px; }
.field input, .field textarea{ width:100%; padding:13px 15px; border-radius:12px; background:rgba(0,0,0,.3); border:1px solid var(--card-border); color:var(--text); font-family:inherit; font-size:.95rem; transition:.25s; resize:vertical; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(231,185,107,.15); }
.field input::placeholder, .field textarea::placeholder{ color:var(--muted-2); }
.field.invalid input, .field.invalid textarea{ border-color:#ff5a4d; }
.form-note{ margin-top:14px; font-size:.9rem; min-height:1.2em; text-align:center; }
.form-note.ok{ color:var(--gold-2); } .form-note.err{ color:#ff8c82; }

/* ---- Persistent mini player ---- */
.mini-player{ position:fixed; left:50%; bottom:18px; z-index:70; width:min(1280px, calc(100vw - 28px)); display:grid; grid-template-columns:52px auto 50px minmax(190px,300px) minmax(260px,1fr) 132px minmax(78px,auto) auto; gap:14px; align-items:center; padding:10px 18px 10px 10px; border-radius:999px; border:1px solid rgba(231,185,107,.3); background:rgba(2,5,10,.88); box-shadow:0 18px 60px -26px #000, 0 0 52px -28px rgba(231,185,107,.9), inset 0 1px rgba(255,255,255,.06); backdrop-filter:blur(18px); transform:translate(-50%, 120%); opacity:0; pointer-events:none; transition:transform .35s ease, opacity .35s ease; }
.mini-player.visible{ transform:translate(-50%,0); opacity:1; pointer-events:auto; }
.mini-player__globe{ position:relative; width:52px; height:52px; border-radius:50%; display:grid; place-items:center; background:#061224; border:1px solid rgba(231,185,107,.35); box-shadow:0 0 34px -14px rgba(35,116,172,.9); overflow:hidden; flex-shrink:0; }
.mini-globe{ width:42px; height:42px; border-radius:50%; background:
  radial-gradient(circle at 32% 25%, rgba(255,255,255,.25), transparent 16%),
  repeating-linear-gradient(90deg, rgba(35,116,172,.55) 0 8px, rgba(7,21,43,.95) 8px 18px, rgba(231,185,107,.22) 18px 19px),
  radial-gradient(circle, #123b5f, #07152b 70%);
  box-shadow:inset -12px -8px 22px rgba(0,0,0,.58), 0 0 22px -8px rgba(231,185,107,.85);
  animation:globeSpin 11s linear infinite; }

.mini-player__globe.has-cover .mini-player__globe.has-cover .mini-globe{ opacity:0; transform:scale(.86); }

.mini-player__signal{ display:inline-flex; align-items:center; gap:8px; color:#ffd9d4; font-size:.68rem; letter-spacing:1.6px; font-weight:800; }
.mini-player__play{ width:50px; height:50px; display:grid; place-items:center; border-radius:50%; background:var(--gold-grad); color:#241606; box-shadow:var(--glow); }
.mini-player__play .ic-pause{ display:none; }
.mini-player__play.playing .ic-play{ display:none; }
.mini-player__play.playing .ic-pause{ display:block; }
.mini-player__meta{ min-width:0; display:flex; flex-direction:column; line-height:1.18; }
.mini-player__meta strong{ overflow:hidden; white-space:nowrap; text-overflow:ellipsis; font-family:var(--serif); font-size:1.12rem; font-weight:600; line-height:1.06; }
.mini-player__meta span{ overflow:hidden; white-space:nowrap; text-overflow:ellipsis; color:var(--muted); font-size:.86rem; }
.mini-player__progress{ position:relative; width:100%; height:3px; margin:6px 0 4px; border-radius:999px; overflow:hidden; background:rgba(255,255,255,.1); box-shadow:inset 0 0 0 1px rgba(255,255,255,.04); }
.mini-player__progress span{ position:absolute; inset:0 auto 0 0; width:0; border-radius:inherit; background:var(--gold-grad); box-shadow:0 0 18px rgba(231,185,107,.7); transition:width .18s linear; }
.mini-player__meta em{ overflow:hidden; white-space:nowrap; text-overflow:ellipsis; color:var(--gold-2); font-style:normal; font-size:.7rem; letter-spacing:.9px; text-transform:uppercase; margin-top:2px; }
.mini-player__meta strong.song-pop{ animation:songPop .48s ease both; }
@keyframes songPop{
  0%{ opacity:.35; transform:translateY(4px); }
  100%{ opacity:1; transform:translateY(0); }
}

.mini-player__volume{ display:flex; align-items:center; gap:8px; min-width:0; }
.mini-player__volume #volume{ width:96px; }
.mini-player__status{ color:var(--muted); font-size:.72rem; white-space:nowrap; }
.mini-player__link{ color:var(--gold); font-size:.78rem; font-weight:800; white-space:nowrap; }
.mini-player__waveform-wrap{ position:relative; min-width:0; height:48px; border-radius:17px; overflow:hidden; border:1px solid rgba(231,185,107,.16); background:linear-gradient(90deg,rgba(21,80,125,.26),rgba(231,185,107,.08),rgba(255,255,255,.03)); box-shadow:inset 0 1px rgba(255,255,255,.06), 0 0 36px -24px rgba(47,158,232,.9); }
.mini-player__waveform{ position:absolute; inset:0; }
.live-visualizer-canvas{ display:block; width:100%; height:100%; }
.mini-player__sweep{ position:absolute; inset:-20% auto -20% -35%; width:32%; transform:skewX(-18deg); background:linear-gradient(90deg,transparent,rgba(246,220,160,.18),transparent); opacity:0; pointer-events:none; }
.mini-player.is-playing .mini-player__sweep,
body.is-playing .mini-player__sweep{ opacity:1; animation:wave-sweep 2.4s linear infinite; }
.mini-player__waveform{ pointer-events:none; }
.player__ambient{ position:relative; height:44px; margin-top:18px; border-radius:999px; overflow:hidden; border:1px solid rgba(231,185,107,.1); background:linear-gradient(90deg,rgba(47,158,232,.08),rgba(231,185,107,.04)); }
.player__ambient span{ position:absolute; top:50%; left:-20%; width:45%; height:1px; background:linear-gradient(90deg,transparent,rgba(246,220,160,.42),transparent); animation:ambient-line 4s linear infinite; }
.player__ambient span:nth-child(2){ animation-delay:1.25s; top:36%; opacity:.75; }
.player__ambient span:nth-child(3){ animation-delay:2.5s; top:64%; opacity:.55; }
@keyframes wave-sweep{ from{ transform:translateX(0) skewX(-18deg); } to{ transform:translateX(440%) skewX(-18deg); } }
@keyframes ambient-line{ from{ transform:translateX(0); } to{ transform:translateX(320%); } }

/* ---- Footer ---- */
.footer{ background:var(--bg-3); border-top:1px solid var(--card-border); padding-top:50px; }
.footer__inner{ display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; padding-bottom:34px; border-bottom:1px solid var(--card-border); }
.footer__brand p{ color:var(--gold); font-family:var(--serif); font-style:italic; margin-top:12px; }
.footer__nav{ display:flex; gap:26px; flex-wrap:wrap; }
.footer__nav a{ color:var(--muted); font-size:.9rem; transition:color .2s; }
.footer__nav a:hover{ color:var(--gold); }
.footer__bottom{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-block:24px; font-size:.82rem; color:var(--muted-2); }

/* ---- Responsive ---- */
@media (max-width:980px){ .nav__links{ gap:16px; } }

.tv-headline{ position:relative; }
.tv-channel-strip{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:18px; }
.tv-channel-strip span{ padding:.48em .8em; border-radius:999px; border:1px solid rgba(231,185,107,.18); background:rgba(255,255,255,.035); color:var(--muted); font-size:.72rem; letter-spacing:1.2px; text-transform:uppercase; font-weight:800; }
.tv-hub{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; padding:24px; margin-bottom:22px; border:1px solid rgba(231,185,107,.16); border-radius:var(--radius); background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(231,185,107,.04)); box-shadow:inset 0 1px rgba(255,255,255,.06); }
.tv-hub__intro{ max-width:700px; }
.tv-hub__intro h3{ font-family:var(--serif); font-size:clamp(1.8rem,3.5vw,2.7rem); line-height:1.02; font-weight:650; margin-top:8px; }
.tv-hub__intro p{ color:var(--muted); margin-top:10px; max-width:680px; }
.tv-hub__cta{ display:flex; flex-wrap:wrap; gap:12px; justify-content:flex-end; }
.theater-poster__caption{ display:block; max-width:680px; color:var(--text); font-family:var(--serif); font-size:clamp(1.6rem,3vw,2.4rem); line-height:1.05; text-shadow:0 8px 24px rgba(0,0,0,.85); }
.theater-note{ display:grid; gap:4px; padding:14px; border:1px solid rgba(231,185,107,.12); border-radius:16px; background:rgba(0,0,0,.12); }
.theater-note strong{ color:var(--gold); font-size:.72rem; text-transform:uppercase; letter-spacing:1.5px; }
.video-card__episode{ position:absolute; top:12px; left:12px; z-index:3; padding:.32em .62em; border-radius:999px; color:#241606; background:var(--gold-grad); font-weight:900; font-size:.68rem; letter-spacing:1px; }
.video-card__link{ display:inline-flex; margin-top:12px; color:var(--gold); font-size:.72rem; letter-spacing:1.3px; text-transform:uppercase; font-weight:800; }
.tv-utility{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; margin-top:18px; }
.tv-utility article{ padding:18px; border-radius:18px; border:1px solid rgba(231,185,107,.14); background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,.014)); }
.tv-utility span{ display:block; color:var(--gold); font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; font-weight:800; margin-bottom:8px; }
.tv-utility strong{ display:block; color:var(--text); font-family:var(--serif); font-size:1.12rem; line-height:1.2; font-weight:600; }

@media (max-width:900px){
  .gate-shell{ grid-template-columns:1fr; min-height:auto; }
  .gate-map{ min-height:340px; }
  .gate-globe{ width:min(76vw,420px); }
  .gate-destinations{ grid-template-columns:repeat(2,1fr); }
  .about, .founder, .contact{ grid-template-columns:1fr; gap:34px; }
  .founder__portrait{ max-width:300px; margin-inline:auto; }
  .prog-grid{ grid-template-columns:repeat(2,1fr); }
  .episodes{ grid-template-columns:1fr; }
  .tv-theater,.media-kit{ grid-template-columns:1fr; }
  .video-grid{ grid-template-columns:repeat(2,1fr); }
  .package-grid{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  html{ scroll-padding-top:104px; }
  /* Mobile perf: backdrop-blur over the animated globes is very expensive.
     Use solid-ish backgrounds instead and drop the heavy blurred orbs. */
  .tune-button{ backdrop-filter:none; background:rgba(2,5,10,.86); }
  .orb{ display:none; }

  /* ---- Mobile frequency gate: let it breathe, scroll, and give a thumb-friendly flow ---- */
  .frequency-gate{ overflow-y:auto; -webkit-overflow-scrolling:touch; place-items:start center; padding:16px 14px calc(20px + env(safe-area-inset-bottom)); }
  .gate-shell{ backdrop-filter:none; background:linear-gradient(160deg, rgba(4,12,24,.96), rgba(2,5,10,.95)); display:flex; flex-direction:column; gap:16px; min-height:auto; padding:22px 18px; border-radius:24px; }
  .gate-copy{ text-align:center; order:1; }
  .gate-logo{ width:72px; margin:0 auto 12px; }
  .gate-copy h1{ font-size:clamp(1.55rem,7.4vw,2.15rem); line-height:1.04; margin-inline:auto; }
  .gate-copy p{ font-size:.92rem; margin:10px auto 0; max-width:46ch; }
  .gate-map{ order:2; min-height:auto; }
  .gate-globe{ backdrop-filter:none; width:min(62vw,280px); }
  .gate-destinations{ order:3; grid-template-columns:1fr 1fr; gap:10px; }
  .gate-destination{ min-height:64px; padding:12px 14px; }
  .gate-destination span{ font-size:.98rem; }
  .gate-status{ order:4; font-size:.9rem; }
  /* Prominent commit button, pinned within the scrolling gate so it's always reachable */
  .gate-enter:not([hidden]){ display:block; order:5; position:sticky; bottom:0; z-index:6; width:100%; margin-top:2px; padding:16px; border:none; border-radius:16px; font-family:var(--display); font-size:1.02rem; letter-spacing:1.4px; text-transform:uppercase; color:#241606; background:var(--gold-grad); box-shadow:0 -10px 26px -12px rgba(2,5,10,.95), 0 16px 40px -14px rgba(231,185,107,.7); cursor:pointer; transition:transform .15s ease; }
  .gate-enter:not([hidden]):active{ transform:translateY(1px) scale(.995); }
  .nav__links{ position:fixed; inset:0 0 0 auto; width:min(80vw,330px); flex-direction:column; justify-content:center; gap:24px; padding:40px; background:rgba(8,7,6,.98); backdrop-filter:blur(16px); border-left:1px solid var(--card-border); transform:translateX(100%); transition:transform .35s cubic-bezier(.2,.7,.2,1); }
  .nav__links.open{ transform:none; }
  .nav__links a{ font-size:1.1rem; }
  .hamburger{ display:flex; }
  .hero{ padding-top:100px; }
  .hero-globe{ width:min(76vw,340px); }
  .hero__title{ font-size:clamp(2.1rem,12vw,4.1rem); }
  .hero__lead{ font-size:.98rem; }
  .player{ grid-template-columns:1fr; text-align:center; }
  .player__art{ max-width:240px; margin-inline:auto; }
  .track-row{ margin-inline:auto; }
  .signal-board{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
  .signal-card{ min-height:auto; text-align:left; }
  .rotation-panel{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
  .rotation-panel__media img{ width:min(100%,220px); margin-inline:auto; }
  .rotation-panel__body{ text-align:left; }
  .rotation-panel__facts{ grid-template-columns:1fr; }
  .rotation-fact--wide{ grid-column:auto; }
  .mini-player{ grid-template-columns:52px 42px minmax(0,1fr) auto; border-radius:24px; align-items:center; }
  .mini-player__globe{ grid-column:1; }
  .mini-player__play{ grid-column:2; width:42px; height:42px; }
  .mini-player__meta{ grid-column:3; }
  .mini-player__volume{ grid-column:4; }
  .mini-player__waveform-wrap{ grid-column:1 / -1; grid-row:2; height:42px; }
  .mini-player__signal{ display:none; }
  .mini-player__link{ display:none; }
  .mini-player__status{ display:none; }
  .mini-player__volume #volume{ width:74px; }
  .tv-grid{ grid-template-columns:1fr; }
  .tv-hub{ flex-direction:column; align-items:flex-start; }
  .tv-hub__cta{ justify-content:flex-start; }
  .tv-utility{ grid-template-columns:1fr; }
  .vcard--feature{ grid-row:auto; }
  .theater-stage{ min-height:300px; }
  .video-grid{ grid-template-columns:1fr; }
  .prog-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .gtile--lg{ grid-column:span 2; grid-row:span 1; }
  .gtile--wide{ grid-column:span 2; }
  .featured-sponsor{ grid-template-columns:1fr; text-align:center; justify-items:center; }
  .advertise{ flex-direction:column; text-align:center; align-items:center; padding:30px 24px; }
  .footer__inner, .footer__bottom{ flex-direction:column; align-items:flex-start; }

  /* ---- Mobile rhythm & comfortable touch targets ---- */
  .section__head{ margin-bottom:36px; }
  .section__head p, .hero__lead{ font-size:1rem; }
  .hero__cta{ flex-direction:column; align-items:stretch; width:100%; max-width:360px; margin-inline:auto; }
  .hero__cta .btn{ width:100%; }
  .btn{ min-height:48px; }
  .chip{ min-height:42px; }
  .video-filter{ min-height:42px; }
  .lang-toggle button{ min-height:38px; }
  .nav__links a{ min-height:44px; display:flex; align-items:center; }
  .schedule-wrap{ -webkit-overflow-scrolling:touch; }
}
@media (max-width:420px){
  .frequency-gate{ padding:12px 12px calc(16px + env(safe-area-inset-bottom)); }
  .gate-shell{ padding:18px; border-radius:22px; }
  .gate-logo{ width:68px; margin:0 auto 10px; }
  .gate-map{ min-height:auto; }
  .gate-globe{ width:min(68vw,260px); }
  .gate-destinations{ grid-template-columns:1fr 1fr; gap:8px; }
  .gate-destination{ min-height:62px; padding:11px 13px; }
  .hero__cta .btn{ width:100%; }
  .hero-globe{ width:min(82vw,300px); }
  .hero__live{ flex-direction:column; border-radius:20px; }
  .stats{ gap:22px; }
  .mini-player{ grid-template-columns:44px 42px 1fr auto; border-radius:22px; gap:10px; padding:9px; }
  .mini-player__globe{ width:44px; height:44px; }
  .mini-player__meta strong{ font-size:.98rem; }
  .mini-player__meta span{ font-size:.76rem; }
  .mini-player__meta em{ font-size:.62rem; }
  .mini-player__signal{ display:none; }
  .mini-player__link{ display:none; }
  .mini-player__volume #volume{ display:none; }
}
@media (prefers-reduced-motion:reduce){
  .orb,.hero__sun,.hero-globe__ring,.hero-globe__aura,.player__art-glow,.founder__glow,.frequency-line,.theater-side::before,.player::after,.dot,.equalizer span,.gate-orbit,.gate-globe,.mini-globe,.gate-tuning span,.globe-pin,.tune-button,.mini-player__sweep,.player__ambient span{ animation:none !important; }
  .mini-player,.video-card,.btn{ transition:none !important; }
}
