/* =========================================================================
   Mundial 2026 — Propuesta "CANCHA" (v2)
   Estética estadio/marcador deportivo · Bebas Neue display + Inter body
   Independiente de style.css — coexiste con la propuesta original.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --wc-red:   #E61D25;
  --wc-blue:  #2A398D;
  --wc-green: #3CAC3B;
  --wc-gold:  #FFC72C;
  --logo:     #B20641;

  --ink:      #0B1130;
  --ink-2:    #1a2247;
  --muted:    #5d6478;
  --bg:       #ffffff;
  --bg-soft:  #f5f7fb;
  --bg-dark:  #0B1130;
  --border:   #e3e6ee;

  --max:      1280px;
  --radius:   4px;
  --radius-lg: 10px;

  --font-display: "Bebas Neue", "Impact", "Arial Narrow", sans-serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  font-size: 16px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--wc-blue); text-decoration: none; }
a:hover { color: var(--wc-red); }

img { max-width: 100%; display: block; }

/* ---------- Header ---------- */
.cancha-header {
  background: #fff;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 2px 12px rgba(11, 17, 48, .04);
}
.cancha-header__banner {
  display: block;
  max-width: var(--max);
  margin: 0 auto;
  line-height: 0;
}
.cancha-header__banner img {
  display: block;
  width: 100%;
  height: auto;
}
.cancha-header::after {
  content: "";
  display: block;
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--wc-green) 0% 33.33%,
    var(--wc-red)   33.33% 66.66%,
    var(--wc-blue)  66.66% 100%
  );
}

/* ---------- Main ---------- */
.cancha-main {
  max-width: var(--max);
  margin: 0 auto;
  padding: 1.5rem 1.25rem 3rem;
}

/* ---------- Ad slots ---------- */
.ad {
  display: flex;
  align-items: center;
  justify-content: center;
}
.ad--leaderboard { width: 100%; max-width: 970px; min-height: 90px;  margin: 0 auto 1.25rem; }
.ad--billboard   { width: 100%; max-width: 970px; min-height: 250px; margin: 1.5rem auto; }
.ad--halfpage    { width: 100%; max-width: 728px; min-height: 90px;  margin: 1.5rem auto; }
.ad--rect        { width: 100%; max-width: 300px; min-height: 250px; margin: 1.25rem auto; }
/* Colapsa slots vacíos en flujo principal (BB1/LB1/halfpage) para no dejar hueco. */
.ad:empty, .ad > div:empty { display: none; }
/* Excepción: los 3 rectángulos del aside derecho deben mantener su caja reservada
   aunque GAM no llene alguno — así el usuario siempre ve los 3 huecos para anuncios. */
.cancha-aside .ad,
.cancha-aside .ad > div { display: flex !important; }

/* ---------- Hero (note 1) ---------- */
.cancha-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  min-height: 520px;
  background: var(--bg-dark);
  display: block;
  color: #fff;
  isolation: isolate;
  margin-bottom: 1rem;
}
.cancha-hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.cancha-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(11,17,48,0) 0%, rgba(11,17,48,0.85) 100%),
    linear-gradient(90deg, rgba(42,57,141,0.45) 0%, rgba(11,17,48,0) 60%);
  z-index: 1;
}
.cancha-hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 6px;
  background: linear-gradient(
    90deg,
    var(--wc-green) 0% 33.33%,
    var(--wc-red)   33.33% 66.66%,
    var(--wc-blue)  66.66% 100%
  );
  z-index: 2;
}
.cancha-hero__body {
  position: relative;
  z-index: 2;
  padding: 2rem 2.25rem 2.5rem;
  max-width: 820px;
  margin-top: auto;
  /* Push the body to the bottom */
}
.cancha-hero {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.cancha-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  line-height: 1;
  letter-spacing: 0.01em;
  margin: 0.5rem 0 0.75rem;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0,0,0,0.35);
}
.cancha-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.85);
}

/* ---------- Featured grid (notas 2-5) ---------- */
.cancha-featured-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}
.cancha-feat {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.cancha-feat:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(11,17,48,0.10);
}
.cancha-feat::before {
  content: "";
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 4px;
  z-index: 2;
}
.cancha-feat--red::before    { background: var(--wc-red); }
.cancha-feat--blue::before   { background: var(--wc-blue); }
.cancha-feat--green::before  { background: var(--wc-green); }

.cancha-feat__media {
  aspect-ratio: 16/10;
  background: #eef0f6;
  overflow: hidden;
}
.cancha-feat__media img {
  width: 100%; height: 100%; object-fit: cover;
}
.cancha-feat__body {
  padding: 1rem 1rem 1.1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  flex: 1;
}
.cancha-feat__title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  line-height: 1.1;
  letter-spacing: 0.01em;
  color: var(--ink);
  margin: 0;
}
.cancha-feat:hover .cancha-feat__title { color: var(--wc-red); }

/* ---------- Section dorsal badge ---------- */
.dorsal {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.2rem 0.55rem;
  font-family: var(--font-display);
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: var(--ink);
  border-radius: 2px;
  width: fit-content;
}
.dorsal--red    { background: var(--wc-red); }
.dorsal--blue   { background: var(--wc-blue); }
.dorsal--green  { background: var(--wc-green); }

/* ---------- Date meta ---------- */
.cancha-date {
  font-size: 0.78rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ---------- Section title ---------- */
.cancha-section-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0 0 1rem;
  font-family: var(--font-display);
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  color: var(--ink);
  text-transform: uppercase;
}
.cancha-section-title::before {
  content: "";
  width: 6px; height: 28px;
  background: var(--wc-red);
  border-radius: 2px;
}

/* ---------- Listing wrapper (lista + sidebar 300×250) ---------- */
.cancha-listing {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 1.5rem;
  align-items: start;
  margin-bottom: 1.5rem;
}
.cancha-listing__main { min-width: 0; }

.cancha-aside {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: sticky;
  top: 240px; /* mayor que la altura del header sticky (banner + franja tricolor) para que el primer ad no quede tapado */
}
.cancha-aside .ad--rect { margin: 0; }

/* ---------- News list (2 col grid de tarjetas) ---------- */
.cancha-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}
.ad--inline-mobile {
  display: none; /* desktop: oculto en todos lados */
  width: 100%;
  max-width: none; /* anula el max-width de .ad--rect si conviven */
  min-height: 50px; /* LM1: tamaño más chico que sirve GAM */
  margin: 0 0 0.75rem; /* solo separa de lo que sigue, no del header */
  padding: 0;
}
.cancha-list .ad--inline-mobile {
  grid-column: 1 / -1;
  margin: 0;
}
.cancha-card {
  position: relative;
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 1rem;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.cancha-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(11,17,48,0.08);
}
.cancha-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 4px;
  z-index: 2;
  background: var(--wc-red);
}
.cancha-card--blue::before  { background: var(--wc-blue); }
.cancha-card--green::before { background: var(--wc-green); }

.cancha-card__media {
  background: #eef0f6;
  overflow: hidden;
}
.cancha-card__media img {
  width: 100%; height: 100%; object-fit: cover;
}
.cancha-card__body {
  padding: 0.9rem 1rem 0.9rem 0.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  justify-content: center;
}
.cancha-card__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--ink);
  margin: 0;
}
.cancha-card:hover .cancha-card__title { color: var(--wc-red); }

/* ---------- Empty / fallback ---------- */
.cancha-empty {
  padding: 3rem 1rem;
  text-align: center;
  color: var(--muted);
  border: 1px dashed var(--border);
  border-radius: var(--radius-lg);
}

/* ---------- Article ---------- */
.cancha-article-hero {
  position: relative;
  min-height: 460px;
  background: var(--bg-dark);
  color: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  isolation: isolate;
}
.cancha-article-hero img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  z-index: 0;
}
.cancha-article-hero::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,17,48,0) 0%, rgba(11,17,48,0.92) 95%);
  z-index: 1;
}
.cancha-article-hero::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 5px;
  background: linear-gradient(
    90deg,
    var(--wc-green) 0% 33.33%,
    var(--wc-red)   33.33% 66.66%,
    var(--wc-blue)  66.66% 100%
  );
  z-index: 2;
}
.cancha-article-hero__body {
  position: relative;
  z-index: 2;
  padding: 2rem 2.25rem 2.5rem;
  max-width: 880px;
}
.cancha-article-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.2vw, 3.2rem);
  line-height: 1.05;
  margin: 0.5rem 0 0.75rem;
  color: #fff;
}
.cancha-article-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.85);
}
.cancha-article-hero__caption {
  position: absolute;
  right: 1rem; bottom: 12px;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.7);
  text-align: right;
  z-index: 2;
  max-width: 60%;
}

.cancha-article-body {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--ink-2);
}
.cancha-article-body p { margin: 0 0 1.1rem; }
.cancha-article-body p:empty { display: none; }
.cancha-article-body h2,
.cancha-article-body h3 {
  font-family: var(--font-display);
  letter-spacing: 0.02em;
  color: var(--ink);
  line-height: 1.15;
  margin: 1.5rem 0 0.6rem;
}
.cancha-article-body h2 { font-size: 1.8rem; }
.cancha-article-body h3 { font-size: 1.4rem; }
.cancha-article-body a { color: var(--wc-blue); border-bottom: 1px solid currentColor; }
.cancha-article-body a:hover { color: var(--wc-red); }
.cancha-article-body blockquote {
  margin: 1.4rem 0;
  padding: 0.5rem 1.2rem;
  border-left: 4px solid var(--wc-green);
  background: var(--bg-soft);
  font-style: italic;
  color: var(--ink-2);
}
.cancha-article-body img,
.cancha-article-body figure img {
  border-radius: var(--radius);
  margin: 1rem auto;
}
.cancha-article-body iframe,
.cancha-article-body video {
  width: 100% !important;
  height: 360px !important;
  max-width: 100%;
  display: block;
  margin: 1rem auto;
  border: 0;
  border-radius: var(--radius);
  background: #000;
}
.cancha-article-body video { object-fit: contain; }

.cancha-article-back {
  max-width: 760px;
  margin: 2rem auto 0;
}
.cancha-article-back a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1rem;
  background: var(--wc-blue);
  color: #fff;
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
  font-size: 0.92rem;
}
.cancha-article-back a:hover { background: var(--wc-red); color: #fff; }

/* "Lee también" inside CKEditor body */
.cancha-article-body .doom-related {
  margin: 1.5rem 0;
  padding: 1rem;
  border: 1px solid var(--border);
  border-left: 4px solid var(--wc-blue);
  border-radius: var(--radius);
  background: #fff;
}
.cancha-article-body .doom-related .article--inText {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 0.85rem;
  align-items: center;
}
.cancha-article-body .doom-related figure { margin: 0; }
.cancha-article-body .doom-related .article--info { font-size: 0.95rem; }

/* ---------- Footer ---------- */
.cancha-footer {
  background: var(--bg-dark);
  color: rgba(255,255,255,0.85);
  margin-top: 3rem;
  padding: 2.5rem 1.25rem 1.5rem;
}
.cancha-footer__inner {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.cancha-footer__country {
  border-top: 4px solid;
  padding-top: 0.75rem;
}
.cancha-footer__country--can { border-color: var(--wc-red); }
.cancha-footer__country--usa { border-color: var(--wc-blue); }
.cancha-footer__country--mex { border-color: var(--wc-green); }
.cancha-footer__country h3 {
  font-family: var(--font-display);
  letter-spacing: 0.06em;
  margin: 0 0 0.25rem;
  font-size: 1.3rem;
  color: #fff;
}
.cancha-footer__country p {
  margin: 0;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.65);
}
.cancha-footer__bottom {
  max-width: var(--max);
  margin: 0 auto;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 1rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.6);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.cancha-footer a { color: rgba(255,255,255,0.85); }
.cancha-footer a:hover { color: #fff; }

/* ---------- 404 ---------- */
.cancha-404 {
  max-width: 720px;
  margin: 3rem auto;
  padding: 3rem 2rem;
  background: #fff;
  border: 1px solid var(--border);
  border-top: 6px solid var(--wc-red);
  border-radius: var(--radius-lg);
  text-align: center;
}
.cancha-404 h1 {
  font-family: var(--font-display);
  font-size: 5rem;
  margin: 0;
  letter-spacing: 0.04em;
  color: var(--ink);
}
.cancha-404 h1 span:nth-child(1) { color: var(--wc-green); }
.cancha-404 h1 span:nth-child(2) { color: var(--wc-red); }
.cancha-404 h1 span:nth-child(3) { color: var(--wc-blue); }
.cancha-404 p { color: var(--muted); margin: 0.5rem 0 1.5rem; }
.cancha-404 a {
  display: inline-block;
  padding: 0.6rem 1.2rem;
  background: var(--wc-red);
  color: #fff;
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
  font-size: 0.95rem;
}

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
  .cancha-featured-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  /* El sidebar de ads se cae debajo de la lista */
  .cancha-listing {
    grid-template-columns: 1fr;
  }
  .cancha-aside {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
  }
}
@media (max-width: 900px) {
  .cancha-list { grid-template-columns: 1fr; }
  .cancha-footer__inner { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .cancha-hero { min-height: 380px; }
  .cancha-hero__body { padding: 1.5rem 1.25rem 1.75rem; }
  .cancha-featured-row { grid-template-columns: 1fr; }
  .cancha-card {
    grid-template-columns: 130px 1fr;
    gap: 0.75rem;
  }
  .cancha-card__title { font-size: 1.05rem; }
  /* En mobile el sidebar desaparece — el ad LM1 (320×50) toma el top y, si quedara alguno inline, también se muestra. */
  .cancha-aside { display: none; }
  /* !important porque la regla global .ad > div:empty { display: none } y el inline display:none
     que GPT aplica con collapseEmptyDivs() podrían colapsar el wrapper cuando no hay fill. */
  .ad--inline-mobile,
  .ad--inline-mobile > div { display: flex !important; }
  /* BB1 y LB1 están definidos solo con tamaños desktop (970×250 / 970×90 / 728×90 / 468×60).
     En mobile GPT no encuentra match y devuelve slot vacío — los ocultamos para no dejar hueco. */
  .ad--billboard,
  .ad--leaderboard { display: none; }
  .ad--halfpage { min-height: 60px; }
  .cancha-article-hero { min-height: 320px; }
  .cancha-article-body iframe,
  .cancha-article-body video { height: 240px !important; }
}

/* =========================================================================
   Panel Quiniela — partidos del Mundial leídos de los .json publicados
   ========================================================================= */
.quiniela-panel {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.5rem 1.75rem;
  margin: 0 0 2rem;
  box-shadow: 0 6px 18px rgba(11,17,48,.04);
}
.quiniela-panel__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1.1rem;
  border-bottom: 2px solid var(--bg-soft);
  padding-bottom: 0.85rem;
}
.quiniela-panel__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--ink);
}
.quiniela-panel__kicker {
  display: block;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wc-red);
  margin-bottom: 0.35rem;
}
.quiniela-panel__cta {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: var(--wc-blue);
  padding: 0.55rem 1rem;
  border-radius: 999px;
  transition: background .15s ease, transform .15s ease;
  white-space: nowrap;
}
.quiniela-panel__cta:hover {
  background: var(--wc-red);
  color: #fff;
  transform: translateY(-1px);
}
.quiniela-panel__actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.quiniela-panel__cta--ghost {
  background: transparent;
  color: var(--ink);
  border: 2px solid var(--ink);
  padding: 0.4rem 0.9rem;
}
.quiniela-panel__cta--ghost:hover {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  transform: translateY(-1px);
}
.quiniela-panel__updated {
  margin: 1rem 0 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  text-align: right;
}

/* ---- Hero del partido destacado ---- */
.quiniela-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(60,172,59,.32) 0%, transparent 60%),
    radial-gradient(120% 80% at 100% 100%, rgba(230,29,37,.28) 0%, transparent 60%),
    linear-gradient(135deg, #0B1130 0%, #1a2247 100%);
  color: #fff;
  padding: 1.25rem 1.5rem 1.5rem;
  margin-bottom: 1.5rem;
  isolation: isolate;
}
.quiniela-hero::before {
  /* Líneas tipo cancha sobre el fondo */
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 49.5%, rgba(255,255,255,.06) 49.5%, rgba(255,255,255,.06) 50.5%, transparent 50.5%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.06) 0 70px, transparent 71px);
  z-index: 0;
}
.quiniela-hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 5px;
  background: linear-gradient(
    90deg,
    var(--wc-green) 0% 33.33%,
    var(--wc-gold)  33.33% 50%,
    var(--wc-red)   50% 83.33%,
    var(--wc-blue)  83.33% 100%
  );
  z-index: 2;
}
.quiniela-hero__bar {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.1rem;
  font-family: var(--font-display);
  letter-spacing: 0.12em;
}
.quiniela-hero__status {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem;
  background: var(--wc-red);
  color: #fff;
  font-size: 0.85rem;
  border-radius: 2px;
  text-transform: uppercase;
}
.quiniela-hero.is-final .quiniela-hero__status { background: var(--wc-blue); }
.quiniela-hero__status::before {
  content: "";
  width: 8px; height: 8px;
  background: #fff;
  border-radius: 50%;
  animation: cancha-pulse 1.4s infinite;
}
.quiniela-hero.is-final .quiniela-hero__status::before { animation: none; }
.quiniela-hero__time {
  font-size: 0.95rem;
  color: rgba(255,255,255,.85);
  font-variant-numeric: tabular-nums;
}
.quiniela-hero__matchup {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 0 1rem;
}
.quiniela-hero__center {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 110px;
}
.quiniela-hero__venue {
  position: relative;
  z-index: 1;
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,.8);
}

/* ---- Bloque equipo (compartido hero + cards) ---- */
.qmatch__team {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}
.qmatch__team--right { flex-direction: row-reverse; text-align: right; }
.qmatch__logo {
  width: 56px;
  height: 56px;
  object-fit: contain;
  background: rgba(255,255,255,.9);
  border-radius: 6px;
  padding: 4px;
  flex-shrink: 0;
}
.qmatch__crest {
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  background: var(--wc-gold);
  color: var(--ink);
  border-radius: 6px;
  flex-shrink: 0;
}
.qmatch__name {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.4vw, 1.9rem);
  line-height: 1.05;
  letter-spacing: 0.02em;
  color: #fff;
  min-width: 0;
  word-break: break-word;
}

/* ---- VS + Marcador ---- */
.qvs {
  font-family: var(--font-display);
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: var(--wc-gold);
  background: rgba(0,0,0,.25);
  padding: 0.25rem 0.75rem;
  border-radius: 4px;
}
.qvs--sm {
  font-size: 1rem;
  color: var(--muted);
  background: transparent;
  padding: 0 .35rem;
}
.qscore {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #fff;
  color: var(--ink);
  padding: 0.25rem 1rem;
  border-radius: 4px;
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  box-shadow: 0 2px 0 rgba(0,0,0,.2);
}
.qscore--lg { padding: 0.4rem 1.25rem; }
.qscore__num { font-size: 2.5rem; line-height: 1; }
.qscore__sep { color: var(--muted); font-size: 1.6rem; }

/* ---- Subtítulos ---- */
.quiniela-subtitle {
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 1.5rem 0 0.9rem;
  padding-left: 0.6rem;
  border-left: 4px solid var(--wc-red);
  line-height: 1;
}

/* ---- Grid de próximos partidos ---- */
.quiniela-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}
.qcard {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 0.9rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  transition: border-color .15s ease, transform .15s ease;
}
.qcard:hover {
  border-color: var(--wc-blue);
  transform: translateY(-1px);
}
.qcard__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.qcard__time { font-weight: 700; color: var(--ink); font-variant-numeric: tabular-nums; }
.qcard__venue { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 60%; }
.qcard__matchup {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 0.5rem;
}
.qcard .qmatch__logo,
.qcard .qmatch__crest { width: 36px; height: 36px; font-size: 0.95rem; }
.qcard .qmatch__name { font-size: 1.05rem; color: var(--ink); }

/* ---- Lista de resultados ---- */
.quiniela-results {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.qresult {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 0.7rem 1rem;
  border-bottom: 1px solid var(--border);
}
.qresult:last-child { border-bottom: 0; }
.qresult:nth-child(even) { background: var(--bg-soft); }
.qresult__team {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  min-width: 0;
}
.qresult__team--home { flex-direction: row-reverse; justify-content: flex-start; }
.qresult__team--away { justify-content: flex-start; }
.qresult__name {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  color: var(--ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.qresult__logo {
  width: 32px;
  height: 32px;
  object-fit: contain;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px;
  flex-shrink: 0;
}
.qresult__crest {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  background: var(--wc-gold);
  color: var(--ink);
  border-radius: 4px;
  flex-shrink: 0;
}
.qresult__score {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  background: var(--ink);
  color: #fff;
  padding: 0.15rem 0.75rem;
  border-radius: 4px;
  min-width: 80px;
  justify-content: center;
}
.qresult__score strong { font-weight: 400; }
.qresult__score .is-winner { color: var(--wc-gold); }
.qresult__date {
  font-size: 0.72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ---- Slider de próximos partidos (Swiper) ---- */
.quiniela-slider {
  position: relative;
  margin: 0 0 0.5rem;
}
.quiniela-swiper {
  padding: 0.25rem 0 2.4rem; /* deja aire para la paginación abajo */
}
.quiniela-swiper .swiper-slide {
  height: auto; /* todas las cards igualan altura del slide más alto */
}
.quiniela-swiper__prev,
.quiniela-swiper__next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--wc-blue);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(11,17,48,.08);
  transition: background .15s ease, color .15s ease, border-color .15s ease, opacity .15s ease;
  display: grid;
  place-items: center;
  padding: 0 0 2px;
}
.quiniela-swiper__prev:hover,
.quiniela-swiper__next:hover {
  background: var(--wc-blue);
  color: #fff;
  border-color: var(--wc-blue);
}
.quiniela-swiper__prev { left: -14px; }
.quiniela-swiper__next { right: -14px; }
.quiniela-swiper__prev.swiper-button-disabled,
.quiniela-swiper__next.swiper-button-disabled {
  opacity: 0.35;
  cursor: default;
  pointer-events: none;
}
.quiniela-swiper__pagination.swiper-pagination-bullets {
  bottom: 0;
}
.quiniela-swiper__pagination .swiper-pagination-bullet {
  background: var(--ink);
  opacity: 0.25;
  transition: opacity .15s ease, background .15s ease;
}
.quiniela-swiper__pagination .swiper-pagination-bullet-active {
  background: var(--wc-blue);
  opacity: 1;
}

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .quiniela-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
  .quiniela-panel { padding: 1.1rem 1rem 1.25rem; }
  .quiniela-panel__head { flex-direction: column; align-items: flex-start; gap: 0.6rem; }
  .quiniela-panel__cta { align-self: stretch; text-align: center; }
  .quiniela-hero { padding: 1rem 1rem 1.25rem; }
  .quiniela-hero__bar { flex-wrap: wrap; }
  .quiniela-grid { grid-template-columns: 1fr; }
  .quiniela-swiper__prev { left: -6px; }
  .quiniela-swiper__next { right: -6px; }
  .qcard .qmatch__name { font-size: 0.95rem; }
  .qresult {
    grid-template-columns: 1fr auto 1fr;
    gap: 0.6rem;
    padding: 0.65rem 0.75rem;
  }
  .qresult__date {
    grid-column: 1 / -1;
    text-align: center;
    margin-top: 0.15rem;
  }
  .qresult__name { font-size: 0.9rem; }
  .qresult__logo, .qresult__crest { width: 26px; height: 26px; }
  .qresult__crest { font-size: 0.68rem; }
  .qresult__team { gap: 0.4rem; }
  .qresult__score { font-size: 1.15rem; min-width: 64px; padding: 0.1rem 0.55rem; }
  .quiniela-hero__matchup { gap: 0.5rem; }
  .qmatch__logo, .qmatch__crest { width: 44px; height: 44px; font-size: 1.05rem; }
  .qscore__num { font-size: 1.8rem; }
  .qvs { font-size: 1.4rem; padding: 0.2rem 0.55rem; }
}

/* ---------- Calendario (/calendario/) ---------- */
.cal-wrap { max-width: 880px; margin: 0 auto; }
.cal-head { padding: 0.25rem 0 1.5rem; border-bottom: 1px solid var(--border); margin-bottom: 1.5rem; }
.cal-head__kicker {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wc-red);
}
.cal-head__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  letter-spacing: 0.02em;
  line-height: 1;
  color: var(--ink);
}
.cal-head__lead { margin: 0 0 0.85rem; color: var(--muted); max-width: 60ch; }
.cal-head__back { margin: 0; font-size: 0.95rem; }
.cal-head__back a { color: var(--wc-blue); font-weight: 600; }

.cal-empty {
  padding: 2.5rem 1.25rem;
  text-align: center;
  color: var(--muted);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
}

.cal-day { margin: 0 0 1.75rem; }
.cal-day__heading {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0 0 0.6rem;
  padding: 0.45rem 0.85rem;
  background: var(--ink);
  color: #fff;
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 6px;
}
.cal-day.is-today .cal-day__heading {
  background: linear-gradient(90deg, var(--wc-green), var(--wc-red), var(--wc-blue));
}
.cal-day__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.1rem 0.55rem;
  margin-left: auto;
  background: var(--wc-gold);
  color: var(--ink);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  border-radius: 999px;
}
.cal-day__matches {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.6rem;
}

.cal-match {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 0.85rem;
  align-items: center;
  padding: 0.85rem 1rem;
  background: #fff;
  border: 1px solid var(--border);
  border-left: 4px solid var(--border);
  border-radius: var(--radius);
}
.cal-match.is-final { border-left-color: var(--wc-red); }
.cal-match.is-upcoming { border-left-color: var(--wc-blue); }

.cal-match__meta {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.cal-match__time {
  font-family: var(--font-display);
  font-size: 1.35rem;
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.cal-match__status {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.cal-match.is-final .cal-match__status { color: var(--wc-red); font-weight: 700; }

.cal-match__teams {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 0.85rem;
}
.cal-match__center {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 90px;
}
.cal-match__center .qscore {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.85rem;
  background: var(--ink);
  color: #fff;
  border-radius: 8px;
  font-family: var(--font-display);
  font-size: 1.5rem;
  line-height: 1;
}
.cal-match__center .qscore strong { font-weight: 400; }
.cal-match__center .qscore .is-winner { color: var(--wc-gold); }
.cal-match__center .qscore__sep { color: var(--muted); }
.cal-match .qmatch__logo,
.cal-match .qmatch__crest { width: 40px; height: 40px; font-size: 0.95rem; }
.cal-match .qmatch__name { font-size: 1rem; color: var(--ink); }

.cal-match__venue {
  grid-column: 1 / -1;
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.cal-updated {
  margin: 1.5rem 0 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  text-align: right;
}

@media (max-width: 700px) {
  .cal-match {
    grid-template-columns: 1fr;
    gap: 0.6rem;
    padding: 0.75rem 0.85rem;
  }
  .cal-match__meta {
    flex-direction: row;
    align-items: baseline;
    gap: 0.6rem;
  }
  .cal-match__time { font-size: 1.15rem; }
  .cal-match__teams {
    grid-template-columns: 1fr auto 1fr;
    gap: 0.5rem;
  }
  .cal-match .qmatch__logo,
  .cal-match .qmatch__crest { width: 32px; height: 32px; font-size: 0.85rem; }
  .cal-match .qmatch__name { font-size: 0.9rem; }
  .cal-match__center { min-width: 70px; }
  .cal-match__center .qscore { font-size: 1.2rem; padding: 0.2rem 0.6rem; }
  .cal-day__heading { font-size: 1rem; padding: 0.4rem 0.7rem; }
}

/* =========================================================================
   Quiniela embed (/quiniela/) — iframe del sistema externo
   ========================================================================= */
.cancha-quiniela-embed {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin: 0 auto;
}
.cancha-quiniela-embed__head {
  text-align: center;
  padding: 0.25rem 0 0.5rem;
  border-bottom: 3px solid var(--wc-red);
}
.cancha-quiniela-embed__eyebrow {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--wc-blue);
  text-transform: uppercase;
}
.cancha-quiniela-embed__title {
  margin: 0.25rem 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.8rem);
  letter-spacing: 0.04em;
  color: var(--ink);
}
.cancha-quiniela-embed__lead {
  margin: 0 auto;
  max-width: 720px;
  color: var(--muted);
  font-size: 1rem;
}
.cancha-quiniela-embed__frame {
  position: relative;
  width: 100%;
  height: calc(100vh - 240px);
  min-height: 640px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(11, 17, 48, 0.08);
}
.cancha-quiniela-embed__frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.cancha-quiniela-embed__hint {
  margin: 0;
  text-align: center;
  color: var(--muted);
  font-size: 0.9rem;
}
.cancha-quiniela-embed__hint a {
  color: var(--wc-blue);
  font-weight: 600;
}
.cancha-quiniela-embed__hint a:hover { color: var(--wc-red); }

@media (max-width: 700px) {
  .cancha-quiniela-embed__frame {
    height: calc(100vh - 200px);
    min-height: 560px;
    border-radius: var(--radius);
  }
}
