/* ============================================================
   LA RED — Rediseño Home (oscuro / cinematográfico / streaming)
   Sistema visual anclado en el turquesa de marca.
   ============================================================ */

:root{
  /* Brand + accent (tweakable) */
  --accent: #2ec9ce;
  --accent-strong: #1fb3b8;
  --accent-ink: #042024;          /* texto sobre turquesa */
  --accent-glow: rgba(46,201,206,.45);
  --live: #ff3b46;

  /* Dark surfaces */
  --bg: #07090b;
  --bg-2: #0b0f12;
  --surface: #11171b;
  --surface-2: #161f24;
  --surface-3: #1d282e;
  --line: rgba(255,255,255,.09);
  --line-strong: rgba(255,255,255,.16);

  /* Text */
  --text: #f3f6f7;
  --text-2: #b7c2c6;
  --text-3: #76858c;

  /* Type */
  --font-display: "Saira Condensed", "Archivo", sans-serif;
  --font-body: "Archivo", system-ui, sans-serif;

  /* Metrics */
  --maxw: 1320px;
  --pad: clamp(18px, 4vw, 56px);
  --radius: 14px;
  --radius-lg: 20px;
  --header-h: 118px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* Scrollbars (carousels) */
.no-scrollbar{ scrollbar-width:none; }
.no-scrollbar::-webkit-scrollbar{ display:none; }

/* ---------- Reusable bits ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }

.eyebrow{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:700;
  font-size:13px;
  color:var(--accent);
}

.tag{
  display:inline-flex; align-items:center; gap:6px; flex-shrink:0;
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  font-size:11px;
  line-height:1;
  padding:6px 14px 5px;
  border-radius:5px;
  white-space:nowrap;
  overflow:visible;
  background:var(--accent);
  color:var(--accent-ink);
}
.tag--ghost{ background:rgba(255,255,255,.08); color:var(--text); backdrop-filter:blur(4px); }
.tag--news{ background:rgba(46,201,206,.16); color:var(--accent); }

.live-dot{
  width:8px; height:8px; border-radius:50%; background:var(--live);
  box-shadow:0 0 0 0 rgba(255,59,70,.6);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(255,59,70,.55); }
  70%{ box-shadow:0 0 0 7px rgba(255,59,70,0); }
  100%{ box-shadow:0 0 0 0 rgba(255,59,70,0); }
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-display);
  text-transform:uppercase; letter-spacing:.05em; font-weight:700;
  font-size:15px; line-height:1;
  padding:14px 22px; border-radius:9px;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--primary{
  background:var(--accent); color:var(--accent-ink);
  box-shadow:0 6px 24px -8px var(--accent-glow);
}
.btn--primary:hover{ background:var(--accent-strong); box-shadow:0 10px 30px -8px var(--accent-glow); }
.btn--live{ background:var(--live); color:#fff; box-shadow:0 6px 24px -8px rgba(255,59,70,.5); }
.btn--live:hover{ filter:brightness(1.07); }
.btn--ghost{
  background:rgba(255,255,255,.06); color:var(--text);
  border:1px solid var(--line-strong); backdrop-filter:blur(6px);
}
.btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:var(--text-3); }
.btn--sm{ padding:10px 16px; font-size:13px; }

/* Section header */
.section{ padding-block:clamp(40px,6vw,72px); }
.section__head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:24px;
  margin-bottom:26px;
}
.section__title{
  font-family:var(--font-display);
  font-weight:700; text-transform:uppercase; letter-spacing:.01em;
  font-size:clamp(28px,3.6vw,44px);
  line-height:.95; margin:0;
}
.section__title small{
  display:block; font-family:var(--font-body); text-transform:none; letter-spacing:0;
  font-weight:500; font-size:15px; color:var(--text-3); margin-top:9px;
}
.section__title .bar{ color:var(--accent); }
.seemore{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em;
  font-weight:700; font-size:13px; color:var(--text-2);
  display:inline-flex; align-items:center; gap:7px; padding-bottom:4px;
  border-bottom:2px solid transparent; transition:color .2s, border-color .2s;
}
.seemore:hover{ color:var(--accent); border-color:var(--accent); }

/* Poster fallback (always behind imgs) — sistema de póster tipográfico */
.media{
  position:relative; overflow:hidden;
  --ph-a:#16313a; --ph-b:#0a1317;
  background:linear-gradient(145deg, var(--ph-a) 0%, var(--ph-b) 78%);
}
.media::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 100% at 86% 4%, color-mix(in srgb, var(--accent) 34%, transparent), transparent 56%),
    repeating-linear-gradient(122deg, rgba(255,255,255,.035) 0 1.5px, transparent 1.5px 11px);
}
.media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:2;
  color:transparent; font-size:0;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.media__fallback{
  position:absolute; inset:0; z-index:1; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:16px;
}
.media__fallback::before{
  content:""; position:absolute; width:62%; aspect-ratio:1; border-radius:50%;
  border:1.5px solid color-mix(in srgb, var(--accent) 26%, transparent);
  opacity:.6;
}
.media__fallback span{
  position:relative;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.02em;
  font-weight:800; font-size:clamp(17px,2.1vw,28px); line-height:.92;
  color:rgba(255,255,255,.92); text-wrap:balance;
  text-shadow:0 2px 18px rgba(0,0,0,.4);
}
/* variación de color por posición para dar ritmo */
.carousel__track > *:nth-child(3n+2) .media{ --ph-a:#1b2a3c; --ph-b:#0b1118; }
.carousel__track > *:nth-child(3n+3) .media{ --ph-a:#132b2c; --ph-b:#0a1413; }
.headlines .hl:nth-child(2n) .media{ --ph-a:#1b2a3c; --ph-b:#0b1118; }
/* placeholders pequeños: texto más discreto, sin anillo */
.hl__media .media__fallback::before{ display:none; }
.hl__media .media__fallback span{ font-size:12.5px; font-weight:700; letter-spacing:.05em; opacity:.78; }
/* leads con titular propio: el placeholder solo aporta textura */
.lead .media__fallback span,
.sport-lead .media__fallback span{ display:none; }
.livecard__thumb .media__fallback span{ display:none; }

/* ============================================================
   TOP UTILITY BAR
   ============================================================ */
.utility{
  background:#04070a; border-bottom:1px solid var(--line);
  font-size:12.5px;
}
.utility .wrap{ display:flex; align-items:center; justify-content:space-between; height:38px; }
.utility__group{ display:flex; align-items:center; gap:8px; color:var(--text-3); }
.utility__group strong{ color:var(--accent); font-weight:700; }
.utility__chip{
  display:inline-flex; align-items:center; gap:6px; color:var(--text-2);
  padding:4px 8px; border-radius:6px; transition:background .2s,color .2s;
}
.utility__chip:hover{ background:rgba(255,255,255,.06); color:var(--text); }
.utility__social{ display:flex; align-items:center; gap:4px; }
.utility__social a{
  width:28px; height:28px; display:grid; place-items:center; border-radius:6px;
  color:var(--text-2); transition:background .2s, color .2s;
}
.utility__social a:hover{ background:var(--accent); color:var(--accent-ink); }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(7,9,11,.72);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
  transition:background .3s ease, border-color .3s;
}
.header.scrolled{ background:rgba(7,9,11,.94); }
.header .wrap{ display:flex; align-items:center; gap:28px; height:80px; }
.brand{ display:flex; align-items:center; gap:0; flex-shrink:0; }
.brand img{ height:46px; width:auto; }
.nav{ display:flex; align-items:center; gap:8px; margin-left:14px; }
.nav a{
  position:relative; flex-shrink:0;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em;
  font-weight:600; font-size:16px; color:var(--text-2);
  padding:10px 15px; border-radius:8px; transition:color .2s, background .2s; white-space:nowrap;
}
.nav a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.nav a.active{ color:var(--text); }
.nav a.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:2px; height:2px;
  background:var(--accent); border-radius:2px;
}
.header__right{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.iconbtn{
  width:42px; height:42px; display:grid; place-items:center; border-radius:10px;
  color:var(--text-2); border:1px solid var(--line); transition:.2s;
}
.iconbtn:hover{ color:var(--text); border-color:var(--line-strong); background:rgba(255,255,255,.04); }
.btn-envivo{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--live); color:#fff;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em;
  font-weight:700; font-size:15px; padding:11px 18px; border-radius:10px;
  box-shadow:0 6px 22px -8px rgba(255,59,70,.6); transition:.2s;
}
.btn-envivo:hover{ filter:brightness(1.08); transform:translateY(-1px); }
.btn-envivo .live-dot{ background:#fff; box-shadow:0 0 0 0 rgba(255,255,255,.6); animation:pulseW 1.8s infinite; }
@keyframes pulseW{
  0%{ box-shadow:0 0 0 0 rgba(255,255,255,.5);} 70%{ box-shadow:0 0 0 6px rgba(255,255,255,0);} 100%{ box-shadow:0 0 0 0 rgba(255,255,255,0);}
}
.menu-toggle{ display:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; }
.hero__stage{ position:relative; height:clamp(560px, 82vh, 800px); }
.hero__slide{
  position:absolute; inset:0; opacity:0; z-index:1; pointer-events:none;
  transition:opacity .7s ease;
}
.hero__slide.active{ opacity:1; z-index:2; pointer-events:auto; }
.hero__bg{ position:absolute; inset:0; overflow:hidden; }
.hero__bg img, .hero__bg .ph{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.02); transform-origin:50% 50%; will-change:transform; }
.hero__bg .ph{
  position:absolute; inset:0;
  background:
    radial-gradient(85% 95% at 80% 12%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 58%),
    linear-gradient(120deg, #15272e 0%, #0a1014 58%, #070a0c 100%);
}
.hero__bg .ph::after{
  content:""; position:absolute; right:-6%; top:-14%; width:62vh; height:62vh; max-width:760px; max-height:760px;
  border-radius:50%; border:2px solid color-mix(in srgb, var(--accent) 22%, transparent);
  box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 8%, transparent) inset;
  opacity:.7;
}
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(5,7,9,.92) 0%, rgba(5,7,9,.62) 38%, rgba(5,7,9,.12) 68%, rgba(5,7,9,.45) 100%),
    linear-gradient(0deg, rgba(5,7,9,.96) 2%, rgba(5,7,9,.25) 36%, transparent 60%);
}
.hero__inner{
  position:relative; z-index:2; height:100%;
  display:flex; flex-direction:column; justify-content:center;
  padding-top:clamp(30px,6vh,64px);
  padding-bottom:clamp(82px,12vh,112px);
}
.hero__progress{ position:absolute; top:0; left:0; right:0; height:4px; background:rgba(255,255,255,.14); z-index:6; }
.hero__progress i{ display:block; height:100%; width:0; background:var(--accent); box-shadow:0 0 16px var(--accent-glow); }
.hero__eyebrow{ display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.hero__eyebrow .dot{ width:5px; height:5px; border-radius:50%; background:var(--text-3); }
.hero__meta{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-weight:600; font-size:13px; color:var(--text-2); white-space:nowrap; flex-shrink:0; }
.hero__title{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(46px, 6.6vw, 94px); line-height:.9; letter-spacing:-.01em;
  margin:0 0 4px; max-width:15ch;
  text-shadow:0 14px 50px rgba(0,0,0,.5);
}
.hero__desc{ max-width:52ch; color:var(--text-2); font-size:clamp(15px,1.5vw,18px); line-height:1.5; margin:20px 0 28px; }
.hero__actions{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* Live card (floating) */
.livecard{
  position:absolute; z-index:4; right:var(--pad); top:clamp(28px,5vh,52px);
  width:300px; background:rgba(10,15,18,.72);
  border:1px solid var(--line-strong); border-radius:16px;
  backdrop-filter:blur(16px); padding:16px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
}
.livecard__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.livecard__live{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-weight:700; font-size:12px; color:#fff; }
.livecard__ch{ font-family:var(--font-display); font-weight:700; font-size:12px; letter-spacing:.1em; color:var(--accent); }
.livecard__thumb{ position:relative; height:120px; border-radius:11px; overflow:hidden; margin-bottom:13px; }
.livecard__play{
  position:absolute; inset:0; margin:auto; width:52px; height:52px; border-radius:50%;
  background:rgba(46,201,206,.92); color:var(--accent-ink); display:grid; place-items:center;
  box-shadow:0 8px 28px -6px var(--accent-glow); transition:transform .2s;
}
.livecard__thumb:hover .livecard__play{ transform:scale(1.08); }
.livecard__now{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:20px; line-height:1; margin-bottom:4px; }
.livecard__sub{ font-size:12.5px; color:var(--text-3); margin-bottom:12px; }
.livecard__bar{ height:4px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; margin-bottom:6px; }
.livecard__bar i{ display:block; height:100%; width:62%; background:var(--live); border-radius:3px; }
.livecard__time{ display:flex; justify-content:space-between; font-size:11px; color:var(--text-3); font-variant-numeric:tabular-nums; }

/* Hero rail (slide switcher) */
.hero__rail{
  position:absolute; z-index:5; left:0; right:0; bottom:0;
  border-top:1px solid var(--line);
  background:linear-gradient(0deg, rgba(7,9,11,.92), rgba(7,9,11,.35));
  backdrop-filter:blur(8px);
}
.hero__rail .wrap{ display:flex; align-items:stretch; gap:10px; padding-block:14px; overflow-x:auto; }
.railitem{
  flex:1 1 0; min-width:150px;
  display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:11px;
  border:1px solid transparent; text-align:left; transition:.2s; position:relative;
}
.railitem:hover{ background:rgba(255,255,255,.05); }
.railitem.active{ background:rgba(255,255,255,.07); border-color:var(--line-strong); }
.railitem__thumb{ width:58px; height:38px; border-radius:7px; flex-shrink:0; }
.railitem__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:15px; line-height:.95; color:var(--text); }
.railitem__s{ font-size:11px; color:var(--text-3); margin-top:3px; }
.railitem.active::after{ content:""; position:absolute; left:12px; right:12px; top:-1px; height:2px; background:var(--accent); }
.railitem__prog{ position:absolute; left:12px; right:12px; top:-1px; height:2px; background:rgba(255,255,255,.14); display:none; }
.railitem.active .railitem__prog{ display:block; }
.railitem__prog i{ display:block; height:100%; width:0; background:var(--accent); }
.railitem__prog i.run{ width:100%; transition:width var(--slidedur,7000ms) linear; }

/* ============================================================
   PROGRAMACIÓN (TV timeline del día)
   ============================================================ */
.guide{ background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.guide__head{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-bottom:34px; flex-wrap:wrap; }
.guide__now{
  display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-weight:700; font-size:14px;
  background:var(--surface-2); border:1px solid var(--line); border-radius:999px; padding:8px 15px;
}
.guide__now b{ color:var(--accent); font-variant-numeric:tabular-nums; }
.guide__track{
  display:flex; gap:10px; overflow-x:auto; padding-bottom:12px; scroll-snap-type:x proximity;
}
.slot{
  scroll-snap-align:start;
  flex:0 0 auto; width:208px;
  background:var(--surface); border:1px solid var(--line); border-radius:13px;
  padding:14px; transition:.2s; position:relative; overflow:hidden;
}
.slot:hover{ border-color:var(--line-strong); background:var(--surface-2); transform:translateY(-3px); }
.slot.past{ opacity:.45; }
.slot.now{ border-color:var(--accent); background:linear-gradient(180deg, rgba(46,201,206,.12), var(--surface)); }
.slot__time{ font-family:var(--font-display); font-weight:700; font-size:14px; color:var(--text-2); letter-spacing:.04em; font-variant-numeric:tabular-nums; }
.slot.now .slot__time{ color:var(--accent); }
.slot__name{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:19px; line-height:1; margin:10px 0 4px; }
.slot__cat{ font-size:11.5px; color:var(--text-3); }
.slot__live{ position:absolute; top:12px; right:12px; display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display); font-weight:700; font-size:10px; letter-spacing:.1em; color:var(--live); }
.slot__bar{ height:3px; border-radius:2px; background:rgba(255,255,255,.1); margin-top:12px; overflow:hidden; display:none; }
.slot.now .slot__bar{ display:block; }
.slot__bar i{ display:block; height:100%; width:48%; background:var(--accent); }

/* ============================================================
   CAROUSEL (estrenos / programas / capítulos)
   ============================================================ */
.carousel{ position:relative; }
.carousel__track{ display:flex; gap:18px; overflow-x:auto; padding:4px 4px 14px; scroll-snap-type:x mandatory; }
.carousel__track > *{ scroll-snap-align:start; flex:0 0 auto; }
.cbtn{
  position:absolute; top:38%; z-index:6; width:48px; height:48px; border-radius:50%;
  background:rgba(10,15,18,.85); border:1px solid var(--line-strong); color:var(--text);
  display:grid; place-items:center; backdrop-filter:blur(6px);
  box-shadow:0 10px 30px -10px rgba(0,0,0,.7); transition:.2s; opacity:0;
}
.carousel:hover .cbtn{ opacity:1; }
.cbtn:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.cbtn--prev{ left:-10px; } .cbtn--next{ right:-10px; }
.cbtn[disabled]{ opacity:0 !important; pointer-events:none; }

/* Estreno card (16:9 still) */
.show{ width:clamp(300px, 34vw, 392px); }
.show__media{ aspect-ratio:16/10; border-radius:var(--radius); }
.show__media .badge{
  position:absolute; left:12px; top:12px; z-index:2;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-weight:700; font-size:11px;
  background:rgba(7,9,11,.7); border:1px solid var(--line-strong); color:#fff; padding:6px 10px; border-radius:7px; backdrop-filter:blur(6px);
}
.show__media .play{
  position:absolute; right:12px; bottom:12px; z-index:2; width:44px; height:44px; border-radius:50%;
  background:rgba(46,201,206,.92); color:var(--accent-ink); display:grid; place-items:center; opacity:0; transform:translateY(6px);
  transition:.25s; box-shadow:0 8px 24px -6px var(--accent-glow);
}
.show:hover .show__media .play{ opacity:1; transform:translateY(0); }
.show:hover .show__media img{ transform:scale(1.06); }
.show__cat{ margin-top:13px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:11.5px; color:var(--accent); }
.show__title{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:22px; line-height:.98; margin:7px 0 6px; }
.show__when{ font-size:13px; color:var(--text-3); }

/* Programa poster (portrait) */
.poster{ width:clamp(180px, 20vw, 230px); }
.poster__media{ aspect-ratio:3/4; border-radius:var(--radius); }
.poster__media .play{
  position:absolute; inset:0; margin:auto; width:54px; height:54px; border-radius:50%;
  background:rgba(46,201,206,.92); color:var(--accent-ink); display:grid; place-items:center;
  opacity:0; transform:scale(.85); transition:.25s; box-shadow:0 8px 28px -6px var(--accent-glow); z-index:3;
}
.poster:hover .play{ opacity:1; transform:scale(1); }
.poster:hover .poster__media img{ transform:scale(1.06); }
.poster__scrim{ position:absolute; inset:0; background:linear-gradient(0deg, #000 0%, rgba(0,0,0,.82) 22%, rgba(0,0,0,.3) 48%, transparent 70%); z-index:2; }
.poster__cap{ position:absolute; left:14px; right:14px; bottom:13px; z-index:3; }
.poster__name{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:20px; line-height:.95; }
.poster__slot{ font-size:11.5px; color:var(--text-2); margin-top:4px; }
.poster__tag{ position:absolute; left:11px; top:11px; z-index:3; }

/* ============================================================
   NOTICIAS (editorial)
   ============================================================ */
.tabs{ display:flex; gap:6px; background:var(--surface); border:1px solid var(--line); padding:5px; border-radius:12px; }
.tabs button{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-weight:700; font-size:14px;
  color:var(--text-3); padding:9px 16px; border-radius:8px; transition:.2s;
}
.tabs button:hover{ color:var(--text); }
.tabs button.active{ background:var(--accent); color:var(--accent-ink); }

.news-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:26px; }
.news-grid[hidden]{ display:none; }
.lead{ position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:440px; display:flex; }
.lead .media{ position:absolute; inset:0; }
.lead__scrim{ position:absolute; inset:0; background:linear-gradient(0deg, rgba(5,7,9,.95) 6%, rgba(5,7,9,.35) 45%, transparent 75%); z-index:1; }
.lead__body{ position:relative; z-index:2; margin-top:auto; padding:30px; }
.lead__title{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:clamp(26px,3vw,40px); line-height:.98; margin:14px 0 0; max-width:18ch; }
.lead:hover .media img{ transform:scale(1.04); }

.headlines{ display:flex; flex-direction:column; }
.hl{
  display:grid; grid-template-columns:104px 1fr; gap:16px; align-items:center;
  padding:16px 0; border-top:1px solid var(--line); transition:.2s;
}
.hl:first-child{ border-top:none; padding-top:0; }
.hl:hover{ transform:translateX(4px); }
.hl__media{ aspect-ratio:16/11; border-radius:9px; }
.hl:hover .hl__media img{ transform:scale(1.06); }
.hl__cat{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:10.5px; color:var(--accent); }
.hl__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:17px; line-height:1.04; margin-top:5px; }
.hl:hover .hl__t{ color:var(--accent); }

/* ============================================================
   DEPORTES band
   ============================================================ */
.sports{ background:linear-gradient(180deg, var(--bg-2), var(--bg)); border-top:1px solid var(--line); }
.sports-grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:26px; align-items:stretch; }
.sport-lead{ position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:420px; display:flex; }
.sport-lead .media{ position:absolute; inset:0; }
.sport-lead__scrim{ position:absolute; inset:0; background:linear-gradient(0deg, rgba(5,7,9,.95), rgba(5,7,9,.2) 55%, transparent); z-index:1; }
.sport-lead__body{ position:relative; z-index:2; margin-top:auto; padding:30px; }
.sport-lead__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:clamp(24px,2.6vw,36px); line-height:.98; margin:12px 0 0; max-width:20ch; }
.sport-list{ display:flex; flex-direction:column; gap:2px; }
.sport-item{ display:flex; gap:16px; padding:16px 4px; border-top:1px solid var(--line); align-items:flex-start; transition:.2s; }
.sport-item:first-child{ border-top:none; }
.sport-item:hover{ background:rgba(255,255,255,.03); padding-left:12px; border-radius:10px; }
.sport-item__n{ font-family:var(--font-display); font-weight:700; font-size:26px; color:var(--accent); line-height:1; width:34px; flex-shrink:0; }
.sport-item__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:18px; line-height:1.02; }
.sport-item:hover .sport-item__t{ color:var(--accent); }

/* ============================================================
   CAPÍTULOS / EMISIONES
   ============================================================ */
.episode{ width:clamp(280px,30vw,360px); }
.episode__media{ aspect-ratio:16/9; border-radius:var(--radius); }
.episode__media .dur{ position:absolute; right:10px; bottom:10px; z-index:2; font-family:var(--font-display); font-weight:700; font-size:12px; background:rgba(7,9,11,.82); padding:4px 8px; border-radius:6px; }
.episode__media .play{ position:absolute; inset:0; margin:auto; width:50px; height:50px; border-radius:50%; background:rgba(255,255,255,.94); color:#06181a; display:grid; place-items:center; opacity:0; transition:.25s; }
.episode:hover .play{ opacity:1; }
.episode:hover .episode__media img{ transform:scale(1.05); }
.episode__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:17px; margin-top:12px; }
.episode__s{ font-size:12.5px; color:var(--text-3); margin-top:3px; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:#04070a; border-top:1px solid var(--line); padding-block:56px 30px; }
.foot__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; }
.foot__brand img{ height:64px; margin-bottom:16px; }
.foot__brand p{ color:var(--text-3); font-size:13.5px; max-width:30ch; }
.foot h4{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-size:13px; color:var(--accent); margin:0 0 14px; }
.foot ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.foot ul a{ color:var(--text-2); font-size:13.5px; transition:color .2s; }
.foot ul a:hover{ color:var(--accent); }
.foot__contact div{ margin-bottom:14px; }
.foot__contact span{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--text-3); margin-bottom:3px; }
.foot__contact b{ font-weight:600; font-size:14px; }
.foot__bottom{
  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  margin-top:40px; padding-top:22px; border-top:1px solid var(--line);
  font-size:12.5px; color:var(--text-3);
}
.foot__social{ display:flex; gap:8px; }
.foot__social a{ width:34px; height:34px; display:grid; place-items:center; border-radius:8px; border:1px solid var(--line); color:var(--text-2); transition:.2s; }
.foot__social a:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{
  position:fixed; inset:0; z-index:200; background:rgba(4,7,10,.82); backdrop-filter:blur(10px);
  display:flex; align-items:flex-start; justify-content:center; padding-top:18vh;
  opacity:0; visibility:hidden; transition:.3s;
}
.search-overlay.open{ opacity:1; visibility:visible; }
.search-box{ width:min(680px,92vw); }
.search-box input{
  width:100%; background:transparent; border:none; border-bottom:2px solid var(--line-strong);
  color:var(--text); font-family:var(--font-display); font-size:clamp(28px,5vw,52px); font-weight:600;
  padding:14px 4px; outline:none; text-transform:uppercase;
}
.search-box input::placeholder{ color:var(--text-3); }
.search-box input:focus{ border-color:var(--accent); }
.search-hint{ margin-top:18px; color:var(--text-3); font-size:13px; display:flex; gap:10px; flex-wrap:wrap; }
.search-hint b{ color:var(--text-2); font-weight:600; }
.search-close{ position:absolute; top:24px; right:24px; width:46px; height:46px; border-radius:50%; border:1px solid var(--line-strong); color:var(--text-2); display:grid; place-items:center; }
.search-close:hover{ color:var(--text); border-color:var(--text); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px){
  .news-grid{ grid-template-columns:1fr; }
  .sports-grid{ grid-template-columns:1fr; }
  .lead{ min-height:360px; }
  .livecard{ display:none; }
}
@media (max-width: 860px){
  .nav{ display:none; }
  .menu-toggle{ display:grid; }
  .foot__top{ grid-template-columns:1fr 1fr; gap:28px; }
  .hero__rail .wrap{ flex-wrap:nowrap; }
  .railitem__s{ display:none; }
}
@media (max-width: 560px){
  .utility__group:first-child span.hide-sm{ display:none; }
  .foot__top{ grid-template-columns:1fr; }
  .hero__inner{ padding-bottom:120px; }
  .header__right .btn-envivo span.lbl{ display:none; }
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
}

/* ============================================================
   PÁGINAS DE DETALLE — comunes
   ============================================================ */
.crumbs{ display:flex; align-items:center; gap:9px; flex-wrap:wrap;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:600; font-size:12px; color:var(--text-3); }
.crumbs a{ color:var(--text-3); transition:color .2s; }
.crumbs a:hover{ color:var(--accent); }
.crumbs svg{ opacity:.5; }
.crumbs b{ color:var(--text-2); font-weight:600; }

.backlink{ display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:13px; color:var(--text-2); transition:.2s; }
.backlink:hover{ color:var(--accent); gap:11px; }

/* ============================================================
   NOTICIA (artículo)
   ============================================================ */
.article{ padding:40px 0 0; }
.article__head{ max-width:880px; margin:0 auto; text-align:left; }
.article__cat{ display:inline-block; margin:22px 0 16px; }
.article__title{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(34px, 4.6vw, 60px); line-height:1.06; letter-spacing:-.01em; margin:0;
  text-wrap:pretty;
}
.article__standfirst{ font-size:clamp(18px,2vw,22px); line-height:1.5; color:var(--text-2); margin:42px 0 0; max-width:64ch; }
.article__meta{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin:26px 0 0; padding-bottom:26px; border-bottom:1px solid var(--line); }
.byline{ display:flex; align-items:center; gap:12px; }
.byline__av{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--accent-strong)); display:grid; place-items:center; color:var(--accent-ink); font-family:var(--font-display); font-weight:800; font-size:16px; }
.byline__who b{ font-weight:600; font-size:14px; display:block; }
.byline__who span{ font-size:12.5px; color:var(--text-3); }
.article__share{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.shbtn{ width:38px; height:38px; border-radius:9px; border:1px solid var(--line); color:var(--text-2); display:grid; place-items:center; transition:.2s; }
.shbtn:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }

.article__figure{ max-width:1120px; margin:34px auto 0; }
.article__figure .media{ aspect-ratio:16/9; border-radius:var(--radius-lg); }
.article__figure figcaption{ margin-top:12px; font-size:13px; color:var(--text-3); padding-inline:4px; }

.article__body{ max-width:720px; margin:38px auto 0; }
.article__body p{ font-size:18.5px; line-height:1.75; color:#d7dfe2; margin:0 0 24px; }
.article__body p:first-child::first-letter{
  float:left; font-family:var(--font-display); font-weight:800; font-size:74px; line-height:.78;
  padding:6px 14px 0 0; color:var(--accent);
}
.article__body h2{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:26px; margin:38px 0 16px; }
.article__body a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.pullquote{ margin:34px 0; padding:6px 0 6px 26px; border-left:3px solid var(--accent); }
.pullquote p{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:clamp(22px,2.6vw,30px); line-height:1.05; color:var(--text); margin:0; }
.article__tags{ max-width:720px; margin:10px auto 0; display:flex; gap:9px; flex-wrap:wrap; }
.chip{ font-size:12.5px; color:var(--text-2); border:1px solid var(--line-strong); padding:7px 13px; border-radius:999px; transition:.2s; }
.chip:hover{ border-color:var(--accent); color:var(--accent); }
.article__foot{ max-width:720px; margin:32px auto 0; padding-top:26px; border-top:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* ============================================================
   PROGRAMA (ficha)
   ============================================================ */
.showhero{ position:relative; min-height:clamp(560px,80vh,760px); display:flex; }
.showhero__bg{ position:absolute; inset:0; }
.showhero__bg .media{ position:absolute; inset:0; }
.showhero__scrim{ position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(90deg, rgba(5,7,9,.95) 0%, rgba(5,7,9,.6) 42%, rgba(5,7,9,.15) 72%, rgba(5,7,9,.5) 100%),
    linear-gradient(0deg, rgba(5,7,9,.97) 4%, rgba(5,7,9,.2) 42%, transparent 66%); }
.showhero__content{ position:relative; z-index:2; margin-top:auto; padding-bottom:54px; }
.showhero__genres{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.showhero__title{ font-family:var(--font-display); font-weight:800; text-transform:uppercase;
  font-size:clamp(52px,8vw,116px); line-height:.84; letter-spacing:-.01em; margin:0; text-shadow:0 14px 50px rgba(0,0,0,.5); max-width:16ch; }
.showhero__sub{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin:20px 0 0;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-weight:600; font-size:14px; color:var(--text-2); }
.showhero__sub .star{ color:var(--accent); }
.showhero__synopsis{ max-width:60ch; color:var(--text-2); font-size:clamp(15px,1.5vw,18px); line-height:1.6; margin:20px 0 28px; }
.showhero__cta{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

.facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--surface); }
.fact{ padding:20px 22px; border-right:1px solid var(--line); }
.fact:last-child{ border-right:none; }
.fact span{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--text-3); margin-bottom:7px; }
.fact b{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:19px; line-height:1; }

.eptabs{ display:flex; gap:6px; background:var(--surface); border:1px solid var(--line); padding:5px; border-radius:12px; }
.eptabs button{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.05em; font-weight:700; font-size:13.5px; color:var(--text-3); padding:9px 15px; border-radius:8px; transition:.2s; }
.eptabs button.active{ background:var(--accent); color:var(--accent-ink); }
.eplist{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.epcard .media{ aspect-ratio:16/9; border-radius:var(--radius); }
.epcard .media .dur{ position:absolute; right:10px; bottom:10px; z-index:3; font-family:var(--font-display); font-weight:700; font-size:12px; background:rgba(7,9,11,.82); padding:4px 8px; border-radius:6px; }
.epcard .media .num{ position:absolute; left:10px; top:10px; z-index:3; font-family:var(--font-display); font-weight:700; font-size:12px; background:var(--accent); color:var(--accent-ink); padding:4px 9px; border-radius:6px; }
.epcard .media .play{ position:absolute; inset:0; margin:auto; width:50px; height:50px; border-radius:50%; background:rgba(255,255,255,.94); color:#06181a; display:grid; place-items:center; opacity:0; transition:.25s; z-index:3; }
.epcard:hover .media .play{ opacity:1; }
.epcard:hover .media img{ transform:scale(1.05); }
.epcard__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:17px; margin-top:12px; }
.epcard__d{ font-size:13px; color:var(--text-3); margin-top:4px; line-height:1.4; }

@media (max-width: 900px){
  .facts{ grid-template-columns:repeat(2,1fr); }
  .fact:nth-child(2){ border-right:none; }
  .fact:nth-child(1),.fact:nth-child(2){ border-bottom:1px solid var(--line); }
  .eplist{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 600px){
  .eplist{ grid-template-columns:1fr; }
  .article__body p:first-child::first-letter{ font-size:60px; }
}

/* ============================================================
   PÁGINA DE PROGRAMACIÓN (parrilla / guía semanal)
   ============================================================ */
.proghead{
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(120% 130% at 88% -10%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 56%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
}
.proghead::after{
  content:""; position:absolute; right:-8%; top:-30%; width:54vh; height:54vh; max-width:640px; max-height:640px;
  border-radius:50%; border:2px solid color-mix(in srgb, var(--accent) 18%, transparent); opacity:.6; pointer-events:none;
}
.proghead .wrap{ position:relative; z-index:1; padding-block:clamp(28px,4vw,44px) clamp(22px,3vw,30px); }
.proghead__title{
  font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em;
  font-size:clamp(40px,6vw,80px); line-height:.86; margin:14px 0 0;
}
.proghead__title .bar{ color:var(--accent); }
.proghead__sub{ color:var(--text-2); font-size:clamp(15px,1.6vw,18px); margin:16px 0 0; max-width:56ch; }

/* Featured "ahora en vivo" strip */
.prognow{
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:clamp(16px,2.4vw,30px);
  margin-top:clamp(24px,3vw,34px);
  background:rgba(10,15,18,.6); border:1px solid var(--line-strong); border-radius:var(--radius-lg);
  padding:clamp(14px,1.6vw,18px); backdrop-filter:blur(10px);
}
.prognow__thumb{ width:clamp(120px,16vw,184px); aspect-ratio:16/10; border-radius:12px; flex-shrink:0; }
.prognow__thumb .play{
  position:absolute; inset:0; margin:auto; width:48px; height:48px; border-radius:50%;
  background:rgba(46,201,206,.94); color:var(--accent-ink); display:grid; place-items:center;
  box-shadow:0 8px 28px -6px var(--accent-glow); transition:transform .2s;
}
.prognow__thumb:hover .play{ transform:scale(1.08); }
.prognow__live{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.14em; font-weight:700; font-size:12px; color:#fff; }
.prognow__name{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(24px,3vw,38px); line-height:.95; margin:10px 0 6px; }
.prognow__meta{ font-size:13.5px; color:var(--text-3); }
.prognow__bar{ height:5px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; margin-top:14px; max-width:420px; }
.prognow__bar i{ display:block; height:100%; width:0; background:var(--live); border-radius:3px; }
.prognow__next{ text-align:right; padding-left:18px; border-left:1px solid var(--line); min-width:160px; }
.prognow__next span{ display:block; font-size:10.5px; text-transform:uppercase; letter-spacing:.14em; color:var(--text-3); margin-bottom:8px; }
.prognow__next b{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:20px; line-height:1; display:block; }
.prognow__next small{ display:block; font-size:12px; color:var(--text-3); margin-top:6px; }

/* Day selector */
.daybar{ position:sticky; top:79px; z-index:40;
  background:rgba(7,9,11,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.dayrow{ display:flex; gap:9px; overflow-x:auto; padding-block:14px; }
.daychip{
  flex:0 0 auto; min-width:88px; text-align:center;
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  padding:11px 16px 12px; transition:.2s;
}
.daychip:hover{ border-color:var(--line-strong); background:var(--surface-2); }
.daychip.active{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }
.daychip__d{ display:block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:12px; opacity:.78; }
.daychip.active .daychip__d{ opacity:.9; }
.daychip__n{ display:block; font-family:var(--font-display); font-weight:800; font-size:24px; line-height:1; margin-top:5px; font-variant-numeric:tabular-nums; }
.daychip__today{ display:block; font-size:9.5px; text-transform:uppercase; letter-spacing:.14em; font-weight:700; margin-top:5px; color:var(--accent); }
.daychip.active .daychip__today{ color:var(--accent-ink); }

/* Filter row */
.progfilter{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-bottom:8px; }
.progfilter__cats{ display:flex; gap:7px; flex-wrap:wrap; }
.catchip{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-weight:700; font-size:12px;
  color:var(--text-2); background:var(--surface); border:1px solid var(--line); padding:8px 14px; border-radius:999px; transition:.2s;
}
.catchip:hover{ border-color:var(--line-strong); color:var(--text); }
.catchip.active{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }

/* EPG day panel */
.epg{ display:block; }
.epg[hidden]{ display:none; }
.daypart{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.16em; font-weight:700; font-size:13px;
  color:var(--accent); display:flex; align-items:center; gap:14px; margin:34px 0 14px;
}
.daypart:first-child{ margin-top:6px; }
.daypart::after{ content:""; flex:1; height:1px; background:var(--line); }

.epg-row{
  display:grid; grid-template-columns:120px 1fr auto; align-items:center; gap:22px;
  padding:17px 20px 17px 18px; border-radius:13px; border:1px solid transparent; transition:.18s;
  position:relative;
}
.epg-row + .epg-row{ margin-top:2px; }
.epg-row:hover{ background:var(--surface); border-color:var(--line); }
.epg-row.past{ opacity:.42; }
.epg-row.now{ background:linear-gradient(100deg, rgba(46,201,206,.13), var(--surface) 70%); border-color:var(--accent); opacity:1; }
.epg-time{ display:flex; flex-direction:column; gap:3px; }
.epg-time b{ font-family:var(--font-display); font-weight:700; font-size:22px; line-height:1; font-variant-numeric:tabular-nums; }
.epg-row.now .epg-time b{ color:var(--accent); }
.epg-time span{ font-size:11px; color:var(--text-3); font-variant-numeric:tabular-nums; }
.epg-main{ min-width:0; }
.epg-name{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:clamp(19px,2vw,24px); line-height:1; margin:0; display:flex; align-items:center; gap:11px; flex-wrap:wrap; }
.epg-name .tag{ transform:translateY(-1px); }
.epg-desc{ font-size:13.5px; color:var(--text-3); margin-top:7px; line-height:1.4; max-width:70ch; }
.epg-cat{ display:inline-block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:11px; color:var(--text-2); margin-top:9px; }
.epg-liveprog{ height:4px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; margin-top:11px; max-width:320px; }
.epg-liveprog i{ display:block; height:100%; width:0; background:var(--accent); border-radius:3px; }
.epg-act{ display:flex; align-items:center; gap:9px; flex-shrink:0; }
.epg-remind{
  width:42px; height:42px; border-radius:11px; border:1px solid var(--line); color:var(--text-2);
  display:grid; place-items:center; transition:.2s;
}
.epg-remind:hover{ border-color:var(--accent); color:var(--accent); }
.epg-remind.on{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }
.epg-watch{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.05em; font-weight:700; font-size:13px;
  padding:11px 16px; border-radius:11px; transition:.2s; white-space:nowrap;
}
.epg-watch--live{ background:var(--live); color:#fff; }
.epg-watch--live:hover{ filter:brightness(1.08); }
.epg-watch--ghost{ background:rgba(255,255,255,.06); color:var(--text); border:1px solid var(--line-strong); }
.epg-watch--ghost:hover{ background:rgba(255,255,255,.12); }

@media (max-width: 820px){
  .prognow{ grid-template-columns:1fr; text-align:left; }
  .prognow__thumb{ width:100%; max-width:280px; }
  .prognow__next{ text-align:left; padding-left:0; border-left:none; border-top:1px solid var(--line); padding-top:14px; }
  .daybar{ top:0; }
}
@media (max-width: 640px){
  .epg-row{ grid-template-columns:84px 1fr; gap:14px; padding:15px 12px; }
  .epg-act{ grid-column:2; justify-content:flex-start; margin-top:4px; }
  .epg-time b{ font-size:19px; }
}

/* ============================================================
   LA SEMANA EN LA RED (estrenos · week strip)
   ============================================================ */
.weekstrip{ display:grid; grid-template-columns:repeat(7,1fr); gap:12px; }
.weekday{
  display:flex; flex-direction:column; background:var(--surface);
  border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:.2s;
}
.weekday:hover{ border-color:var(--line-strong); transform:translateY(-3px); }
.weekday.today{ border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset; }
.weekday__hd{ display:flex; align-items:center; justify-content:space-between; padding:11px 13px 10px; }
.weekday__d{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:12px; color:var(--text-2); white-space:nowrap; }
.weekday__media .media__fallback::before{ display:none; }
.weekday__media .media__fallback span{ font-size:13px; font-weight:700; letter-spacing:.04em; opacity:.85; }
.weekday.today .weekday__d{ color:var(--accent); }
.weekday__n{ font-family:var(--font-display); font-weight:800; font-size:19px; line-height:1; font-variant-numeric:tabular-nums; }
.weekday__media{ aspect-ratio:5/4; position:relative; }
.weekday__time{
  position:absolute; left:9px; bottom:9px; z-index:2;
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-weight:700; font-size:10.5px;
  background:rgba(7,9,11,.78); border:1px solid var(--line-strong); color:#fff; padding:4px 8px; border-radius:6px; backdrop-filter:blur(5px);
}
.weekday__play{ position:absolute; inset:0; margin:auto; width:42px; height:42px; border-radius:50%; background:rgba(46,201,206,.92); color:var(--accent-ink); display:grid; place-items:center; opacity:0; transform:scale(.85); transition:.22s; z-index:2; box-shadow:0 8px 24px -6px var(--accent-glow); }
.weekday:hover .weekday__play{ opacity:1; transform:scale(1); }
.weekday:hover .weekday__media img{ transform:scale(1.06); }
.weekday__body{ padding:12px 13px 16px; display:flex; flex-direction:column; gap:6px; flex:1; }
.weekday__cat{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:10px; color:var(--accent); }
.weekday__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:16px; line-height:.98; }
.weekday__g{ font-size:11.5px; color:var(--text-3); margin-top:auto; }
.weekday.today .weekday__hd{ background:linear-gradient(180deg, rgba(46,201,206,.14), transparent); }

/* ============================================================
   SEÑAL EN VIVO (live band con player)
   ============================================================ */
.livenow{ background:linear-gradient(180deg, var(--bg-2), var(--bg)); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.livenow__grid{ display:grid; grid-template-columns:1.7fr 1fr; gap:clamp(20px,2.6vw,34px); align-items:stretch; }
.player{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line-strong); }
.player .media{ position:absolute; inset:0; }
.player__ratio{ aspect-ratio:16/9; }
.player__badge{ position:absolute; left:16px; top:16px; z-index:3; display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:12px; color:#fff; background:rgba(7,9,11,.6); border:1px solid var(--line-strong); padding:7px 12px; border-radius:8px; backdrop-filter:blur(6px); }
.player__hd{ position:absolute; right:16px; top:16px; z-index:3; font-family:var(--font-display); font-weight:700; font-size:12px; letter-spacing:.1em; color:var(--accent); background:rgba(7,9,11,.6); border:1px solid var(--line-strong); padding:7px 11px; border-radius:8px; backdrop-filter:blur(6px); }
.player__big{ position:absolute; inset:0; margin:auto; width:74px; height:74px; border-radius:50%; background:rgba(46,201,206,.94); color:var(--accent-ink); display:grid; place-items:center; z-index:3; box-shadow:0 12px 40px -8px var(--accent-glow); transition:transform .2s; }
.player:hover .player__big{ transform:scale(1.07); }
.player__bottom{ position:absolute; left:0; right:0; bottom:0; z-index:3; padding:22px; background:linear-gradient(0deg, rgba(5,7,9,.92), transparent); }
.player__cat{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:11px; color:var(--accent); }
.player__name{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(24px,3vw,38px); line-height:.95; margin:7px 0 12px; }
.player__bar{ height:5px; border-radius:3px; background:rgba(255,255,255,.16); overflow:hidden; max-width:520px; }
.player__bar i{ display:block; height:100%; width:0; background:var(--live); border-radius:3px; }
.player__time{ display:flex; gap:14px; margin-top:9px; font-size:11.5px; color:var(--text-2); font-variant-numeric:tabular-nums; }

.upnext{ display:flex; flex-direction:column; }
.upnext__hd{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:13px; color:var(--text-3); margin-bottom:6px; }
.uprow{ display:grid; grid-template-columns:64px 1fr auto; align-items:center; gap:14px; padding:13px 0; border-top:1px solid var(--line); transition:.2s; }
.uprow:hover{ padding-left:6px; }
.uprow__time{ font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--accent); font-variant-numeric:tabular-nums; }
.uprow__name{ display:block; font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:16px; line-height:1; }
.uprow__cat{ font-size:11px; color:var(--text-3); margin-top:4px; }
.uprow__go{ width:34px; height:34px; border-radius:9px; border:1px solid var(--line); color:var(--text-3); display:grid; place-items:center; transition:.2s; }
.uprow:hover .uprow__go{ color:var(--accent); border-color:var(--accent); }
.estelares{ margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.estelares span{ font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--text-3); }
.estelares__chips{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.estelar{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.04em; font-weight:700; font-size:12px; color:var(--text-2); background:var(--surface-2); border:1px solid var(--line); padding:8px 13px; border-radius:999px; transition:.2s; }
.estelar:hover{ border-color:var(--accent); color:var(--accent); }

/* ============================================================
   TELESERIES (continuar viendo)
   ============================================================ */
.serieswrap{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.serie{ display:grid; grid-template-columns:172px 1fr; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:.2s; }
.serie:hover{ border-color:var(--line-strong); transform:translateY(-2px); }
.serie__media{ position:relative; min-height:172px; }
.serie__media .play{ position:absolute; inset:0; margin:auto; width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,.94); color:#06181a; display:grid; place-items:center; opacity:0; transition:.22s; z-index:2; }
.serie:hover .serie__media .play{ opacity:1; }
.serie:hover .serie__media img{ transform:scale(1.05); }
.serie__media .ribbon{ position:absolute; left:10px; top:10px; z-index:2; }
.serie__body{ padding:16px 18px 16px; display:flex; flex-direction:column; }
.serie__cat{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:.12em; font-weight:700; font-size:10.5px; color:var(--accent); }
.serie__t{ font-family:var(--font-display); text-transform:uppercase; font-weight:700; font-size:21px; line-height:.98; margin:7px 0 5px; }
.serie__meta{ font-size:12.5px; color:var(--text-3); }
.serie__prog{ margin-top:auto; }
.serie__bar{ height:4px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; margin:12px 0 7px; }
.serie__bar i{ display:block; height:100%; background:var(--accent); border-radius:3px; }
.serie__cont{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.serie__ep{ font-size:11.5px; color:var(--text-2); font-variant-numeric:tabular-nums; }
.serie__play{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:.05em; font-weight:700; font-size:12px; color:var(--accent); }
.serie__play:hover{ gap:9px; }

@media (max-width: 1080px){
  .livenow__grid{ grid-template-columns:1fr; }
  .serieswrap{ grid-template-columns:1fr; }
}
@media (max-width: 920px){
  .weekstrip{ display:flex; overflow-x:auto; padding-bottom:8px; }
  .weekday{ flex:0 0 188px; }
}
@media (max-width: 560px){
  .serie{ grid-template-columns:124px 1fr; }
  .serie__media{ min-height:150px; }
  .serie__t{ font-size:18px; }
  .uprow{ grid-template-columns:54px 1fr auto; }
}
