/* ============================================================================
   Mundialaco 2026 — estilos globales
   Tema oscuro deportivo. Mobile-first. Custom properties.
   ============================================================================ */

:root {
  --c-bg:        #0a0e27;
  --c-bg-2:      #11163a;
  --c-surface:   #161b42;
  --c-surface-2: #1d2350;
  --c-border:    #2a3170;
  --c-text:      #eef1ff;
  --c-muted:     #99a0d0;
  --c-primary:   #00e5a0;   /* verde césped neón */
  --c-primary-2: #00b87e;
  --c-accent:    #ff3d71;   /* rojo tarjeta */
  --c-gold:      #ffd23f;
  --c-live:      #ff3d71;

  --space-1: 4px;  --space-2: 8px;  --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
  --radius-sm: 8px; --radius-md: 14px; --radius-lg: 22px;
  --maxw: 1140px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --font: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-head: 'Archivo', 'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,229,160,.10), transparent 60%),
    radial-gradient(1000px 500px at -10% 10%, rgba(255,61,113,.08), transparent 55%),
    var(--c-bg);
  color: var(--c-text);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

.wrap { width: 92%; max-width: var(--maxw); margin-inline: auto; }
@media (min-width: 640px) { .wrap { width: 90%; } }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.12; font-weight: 800; letter-spacing: -.01em; }
h1 { text-transform: none; }
.muted { color: var(--c-muted); }
.small { font-size: .85rem; }
.center { text-align: center; }

.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--c-primary); color: #042; padding: var(--space-3); border-radius: 0 0 var(--radius-sm) 0;
}
.skip-link:focus { left: 0; }

:focus-visible { outline: 3px solid var(--c-primary); outline-offset: 2px; border-radius: 4px; }

/* ── Header / Nav ─────────────────────────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10,14,39,.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--c-border);
}
.header-inner { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-3) 0; }
.brand { display: flex; align-items: center; gap: var(--space-2); font-size: 1.25rem; font-weight: 800; }
.brand-ball { font-size: 1.4rem; }
.brand-text strong { color: var(--c-primary); }

.main-nav { display: none; margin-left: auto; gap: var(--space-2); flex-wrap: wrap; }
.main-nav a {
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  color: var(--c-muted); font-weight: 600; font-size: .95rem; transition: .2s;
}
.main-nav a:hover { color: var(--c-text); background: var(--c-surface); }
.main-nav a.is-active { color: var(--c-primary); background: var(--c-surface); }

.nav-toggle {
  margin-left: auto; background: none; border: 0; cursor: pointer;
  display: flex; flex-direction: column; gap: 5px; padding: var(--space-2);
}
.nav-toggle span { width: 26px; height: 3px; background: var(--c-text); border-radius: 3px; transition: .25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }

@media (min-width: 900px) {
  .nav-toggle { display: none; }
  .main-nav { display: flex; }
}
@media (max-width: 899px) {
  .main-nav.open {
    display: flex; flex-direction: column; position: absolute; left: 0; right: 0; top: 100%;
    background: var(--c-bg-2); border-bottom: 1px solid var(--c-border); padding: var(--space-3) 5%;
    margin: 0;
  }
}

/* Live ticker */
.live-ticker:empty { display: none; }
.live-ticker {
  background: var(--c-accent); color: #fff; font-weight: 700; font-size: .9rem;
  padding: var(--space-2) 0; text-align: center; overflow: hidden; white-space: nowrap;
}
.live-ticker .dot { display:inline-block; width:8px;height:8px;border-radius:50%;background:#fff;margin-right:6px;animation: pulse 1s infinite; }
@keyframes pulse { 50% { opacity: .3; } }

/* ── Main spacing ─────────────────────────────────────────────────────────── */
main { padding-block: var(--space-6) var(--space-8); }
section { margin-block: var(--space-7); }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-4); flex-wrap: wrap; }
.section-head h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
.section-head a.more { color: var(--c-primary); font-weight: 600; font-size: .95rem; }

/* ── Botones ──────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--c-primary); color: #042713; font-weight: 800;
  padding: var(--space-3) var(--space-5); border-radius: 999px; border: 0; cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s; font-size: 1rem;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,229,160,.35); }
.btn:active { transform: translateY(0); }
.btn.ghost { background: transparent; color: var(--c-text); border: 1px solid var(--c-border); }
.btn.ghost:hover { border-color: var(--c-primary); box-shadow: none; }
.btn[disabled] { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }

/* ── Cards genéricas ──────────────────────────────────────────────────────── */
.card {
  background: linear-gradient(180deg, var(--c-surface), var(--c-bg-2));
  border: 1px solid var(--c-border); border-radius: var(--radius-md);
  padding: var(--space-4); box-shadow: var(--shadow);
}
.grid { display: grid; gap: var(--space-4); }
.grid.cols-2 { grid-template-columns: 1fr; }
.grid.cols-3 { grid-template-columns: 1fr; }
.grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 720px) {
  .grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
  .grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
  .grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* ── HERO ─────────────────────────────────────────────────────────────────── */
.hero {
  text-align: center; padding: var(--space-7) var(--space-4);
  background:
    radial-gradient(600px 300px at 50% 0%, rgba(0,229,160,.18), transparent 70%),
    linear-gradient(180deg, var(--c-surface), var(--c-bg-2));
  border: 1px solid var(--c-border); border-radius: var(--radius-lg);
  position: relative; overflow: hidden;
}
.hero h1 { font-size: clamp(2rem, 6vw, 3.6rem); }
.hero h1 .hl { color: var(--c-primary); }
.hero p.lead { color: var(--c-muted); font-size: clamp(1rem, 2.5vw, 1.25rem); max-width: 640px; margin: var(--space-4) auto var(--space-5); }
.hero .cta-row { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }
.hero .pill { position: absolute; opacity: .10; color: var(--c-primary); }
.hero .p1{ top: 10%; left: 8%; } .hero .p2{ bottom: 12%; right: 10%; } .hero .p3{ top: 20%; right: 18%; }

/* ── Partidos ─────────────────────────────────────────────────────────────── */
.match {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--space-3);
  background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius-md);
  padding: var(--space-4); transition: .2s;
}
.match:hover { border-color: var(--c-primary); }
.match .team { display: flex; align-items: center; gap: var(--space-2); font-weight: 700; }
.match .team.away { justify-content: flex-end; text-align: right; }
.match .flag { font-size: 1.6rem; }
.match .score { font-size: 1.5rem; font-weight: 800; min-width: 64px; text-align: center; }
.match .score small { display:block; font-size:.6rem; font-weight:700; letter-spacing:.05em; color: var(--c-muted); }
.match.live { border-color: var(--c-live); box-shadow: 0 0 0 1px var(--c-live) inset; }
.match.live .score { color: var(--c-live); }
.badge-live { display:inline-block; background: var(--c-live); color:#fff; font-size:.7rem; font-weight:800; padding:2px 8px; border-radius:999px; }
.match-meta { grid-column: 1 / -1; text-align: center; font-size: .8rem; color: var(--c-muted); }

/* ── Tabla clasificación ──────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table.standings { width: 100%; border-collapse: collapse; font-size: .92rem; }
table.standings th, table.standings td { padding: var(--space-2) var(--space-3); text-align: center; }
table.standings th { color: var(--c-muted); font-weight: 700; border-bottom: 1px solid var(--c-border); }
table.standings td:nth-child(2), table.standings th:nth-child(2) { text-align: left; }
table.standings tr td { border-bottom: 1px solid rgba(255,255,255,.05); }
table.standings .pos { width: 26px; font-weight: 800; }
table.standings tr.qualify .pos { color: var(--c-primary); }
table.standings .pts { font-weight: 800; color: var(--c-primary); }
.group-card h3 { display:flex; align-items:center; gap:var(--space-2); margin-bottom: var(--space-3); }

/* ── Noticias ─────────────────────────────────────────────────────────────── */
.news-item { display: flex; flex-direction: column; gap: var(--space-1); padding: var(--space-3) 0; border-bottom: 1px solid var(--c-border); }
.news-item:last-child { border-bottom: 0; }
.news-item .title { font-weight: 700; }
.news-item .meta { font-size: .8rem; color: var(--c-muted); }
.news-item .src { color: var(--c-primary); font-weight: 700; }

/* ── CROMOS ───────────────────────────────────────────────────────────────── */
.cromo {
  position: relative; aspect-ratio: 63/88; border-radius: 16px; overflow: hidden;
  padding: 14px; display: flex; flex-direction: column; gap: 6px;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(165deg, var(--c-surface-2), var(--c-bg-2));
  border: 1px solid var(--c-border); box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease; isolation: isolate;
}
.cromo:hover { transform: translateY(-6px); }
.cromo-foil { position:absolute; inset:0; z-index:-1;
  background: linear-gradient(115deg, transparent 42%, rgba(255,255,255,.14) 50%, transparent 58%);
  transform: translateX(-120%); }
.cromo-top { display:flex; justify-content:space-between; align-items:flex-start; }
.cromo-rating { font-family: var(--font-head); line-height:.9; }
.cromo-rating b { display:block; font-size:2rem; font-weight:900; }
.cromo-rating span { font-size:.5rem; letter-spacing:.14em; color:var(--c-muted); font-weight:700; }
.cromo-pos { font-family: var(--font-head); font-size:.7rem; font-weight:800; letter-spacing:.08em;
  color:var(--c-muted); border:1px solid var(--c-border); border-radius:6px; padding:2px 7px; }
.cromo-art { flex:1; display:grid; place-items:center; position:relative; margin:2px 0; }
.cromo-art .silhouette { width:62%; height:auto; color: rgba(255,255,255,.15); }
.cromo-art .cromo-flag { position:absolute; bottom:2px; right:4px; height:22px; width:auto;
  border-radius:3px; box-shadow:0 2px 6px rgba(0,0,0,.45); }
.cromo-info { border-top:1px solid rgba(255,255,255,.08); padding-top:8px; }
.cromo-name { font-family: var(--font-head); font-weight:800; font-size:1rem; line-height:1.05; }
.cromo-team { display:flex; align-items:center; gap:6px; font-size:.76rem; color:var(--c-muted); margin-top:3px; }
.cromo-rarity { position:absolute; top:0; left:0; z-index:2; font-size:.5rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.1em; padding:3px 8px; border-bottom-right-radius:9px;
  background: rgba(0,0,0,.5); color:#fff; }

.cromo.r-comun { border-color:#4a5280; }
.cromo.r-comun .cromo-rating b { color:#cdd3ff; }
.cromo.r-rara { border-color:#3ea7ff; box-shadow:0 0 0 1px rgba(62,167,255,.45), 0 8px 26px rgba(62,167,255,.18); }
.cromo.r-rara .cromo-rating b { color:#7cc4ff; }
.cromo.r-epica { border-color:#b06bff; box-shadow:0 0 0 1px rgba(176,107,255,.45), 0 8px 28px rgba(176,107,255,.22); }
.cromo.r-epica .cromo-rating b { color:#c89bff; }
.cromo.r-legendaria { border-color:var(--c-gold);
  background: radial-gradient(120% 80% at 50% 0%, rgba(255,210,63,.18), transparent 55%), linear-gradient(165deg,#241d08,#171326);
  box-shadow:0 0 0 1px rgba(255,210,63,.55), 0 10px 32px rgba(255,210,63,.30); }
.cromo.r-legendaria .cromo-rating b { color:var(--c-gold); }
.cromo.r-epica .cromo-foil, .cromo.r-legendaria .cromo-foil { animation: foil 3s ease-in-out infinite; }
@keyframes foil { 0%{transform:translateX(-120%);} 55%,100%{transform:translateX(120%);} }

.cromo.locked { background: linear-gradient(165deg,#12173a,#0c1030); border-style:dashed; }
.cromo.locked .cromo-art .silhouette { color: rgba(255,255,255,.05); }
.cromo.locked .cromo-name, .cromo.locked .cromo-rating, .cromo.locked .cromo-pos { opacity:.25; }
.cromo.locked::after { content:'?'; position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--font-head); font-size:3rem; font-weight:900; color: rgba(255,255,255,.12); }

/* Apertura de sobre */
.pack-stage { display: grid; gap: var(--space-4); place-items: center; min-height: 380px; }
.pack {
  width: 200px; aspect-ratio: 3/4; border-radius: var(--radius-md); cursor: pointer;
  background: linear-gradient(160deg, var(--c-primary-2), #044, var(--c-accent));
  display: grid; place-items: center; font-size: 4rem; box-shadow: var(--shadow);
  transition: transform .2s; border: 2px solid var(--c-gold);
}
.pack:hover { transform: scale(1.05) rotate(2deg); }
.reveal-row { display: flex; gap: var(--space-3); flex-wrap: wrap; justify-content: center; }
.reveal-row .cromo { width: 150px; animation: pop .4s ease backwards; }
.reveal-row .cromo:nth-child(2){ animation-delay:.1s } .reveal-row .cromo:nth-child(3){ animation-delay:.2s }
.reveal-row .cromo:nth-child(4){ animation-delay:.3s } .reveal-row .cromo:nth-child(5){ animation-delay:.4s }
@keyframes pop { from { opacity:0; transform: translateY(20px) scale(.8);} }

.album-progress { display:flex; align-items:center; gap:var(--space-3); }
.bar { flex:1; height:10px; background: var(--c-surface); border-radius:999px; overflow:hidden; }
.bar > i { display:block; height:100%; background: linear-gradient(90deg,var(--c-primary),var(--c-gold)); }

/* ── Quiniela ─────────────────────────────────────────────────────────────── */
.q-match { display:grid; grid-template-columns: 1fr auto 1fr; gap: var(--space-3); align-items:center; padding: var(--space-3) 0; border-bottom: 1px solid var(--c-border); }
.q-pred { display:flex; gap:var(--space-2); justify-content:center; }
.q-pred button { width:42px; height:42px; border-radius:var(--radius-sm); border:1px solid var(--c-border); background:var(--c-surface); color:var(--c-text); font-weight:800; cursor:pointer; transition:.15s; }
.q-pred button.sel { background: var(--c-primary); color:#042; border-color:var(--c-primary); transform: scale(1.05); }
.q-pred button:hover { border-color: var(--c-primary); }

.leaderboard { width:100%; border-collapse:collapse; }
.leaderboard td, .leaderboard th { padding: var(--space-3); border-bottom:1px solid var(--c-border); text-align:left; }
.leaderboard .rank { font-weight:800; width:40px; }
.leaderboard tr:nth-child(1) .rank { color: var(--c-gold); }
.leaderboard .pts { text-align:right; font-weight:800; color: var(--c-primary); }
.leaderboard tr.me { background: rgba(0,229,160,.12); }
.leaderboard small { font-weight:500; }

.q-userbar { display:flex; gap:var(--space-2); flex-wrap:wrap; }
.q-input { flex:1; min-width:180px; padding:var(--space-3); border-radius:var(--radius-sm);
  border:1px solid var(--c-border); background:var(--c-bg-2); color:var(--c-text); font-size:1rem; }
.q-input::placeholder { color:var(--c-muted); }

/* ── Ranking listas ───────────────────────────────────────────────────────── */
.rank-list { list-style:none; }
.rank-list li { display:flex; align-items:center; gap:var(--space-3); padding:var(--space-3) 0; border-bottom:1px solid var(--c-border); }
.rank-list .n { font-weight:900; font-size:1.1rem; color:var(--c-muted); width:28px; text-align:center; }
.rank-list .who { flex:1; font-weight:700; }
.rank-list .who small { display:block; color:var(--c-muted); font-weight:500; }
.rank-list .val { font-weight:800; color: var(--c-primary); }

/* ── Cuadro / bracket ─────────────────────────────────────────────────────── */
.bracket { display:flex; gap: var(--space-5); overflow-x:auto; padding-bottom: var(--space-4); }
.round { display:flex; flex-direction:column; justify-content:space-around; gap: var(--space-4); min-width: 200px; }
.round h4 { color: var(--c-muted); text-align:center; margin-bottom: var(--space-2); font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; }
.tie { background: var(--c-surface); border:1px solid var(--c-border); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); }
.tie .row { display:flex; justify-content:space-between; gap:var(--space-2); padding:2px 0; }
.tie .row.win { color: var(--c-primary); font-weight:800; }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.site-footer { border-top: 1px solid var(--c-border); background: var(--c-bg-2); padding-block: var(--space-6); margin-top: var(--space-8); }
.footer-inner { display:flex; flex-wrap:wrap; gap: var(--space-5); justify-content: space-between; align-items: flex-start; }
.footer-nav { display:flex; gap: var(--space-4); flex-wrap:wrap; }
.footer-nav a { color: var(--c-muted); } .footer-nav a:hover { color: var(--c-primary); }
.footer-legal a { font-size: .9rem; }
.footer-inner { width: 100%; }

/* Aviso de cookies */
.cookie-note { position: fixed; left: 50%; bottom: 16px; transform: translateX(-50%);
  width: min(680px, 92%); display: flex; gap: var(--space-3); align-items: center; justify-content: space-between;
  background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4); box-shadow: var(--shadow); z-index: 120; }
.cookie-note p { font-size: .85rem; color: var(--c-muted); margin: 0; }
.cookie-note a { color: var(--c-primary); }
.cookie-note .btn { flex-shrink: 0; }

/* ── Utilidades ───────────────────────────────────────────────────────────── */
.toast { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%) translateY(120%);
  background: var(--c-surface-2); border:1px solid var(--c-primary); color:var(--c-text);
  padding: var(--space-3) var(--space-5); border-radius: 999px; box-shadow: var(--shadow); z-index: 200; transition: transform .3s; }
.toast.show { transform: translateX(-50%) translateY(0); }

/* ── Breadcrumbs ──────────────────────────────────────────────────────────── */
.breadcrumbs { margin-bottom: var(--space-4); font-size: .85rem; }
.breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: var(--space-1); align-items: center; }
.breadcrumbs li { display: flex; align-items: center; color: var(--c-muted); }
.breadcrumbs li:not(:last-child)::after { content: "›"; margin: 0 var(--space-2); color: var(--c-border); }
.breadcrumbs a { color: var(--c-muted); }
.breadcrumbs a:hover { color: var(--c-primary); }
.breadcrumbs li[aria-current] { color: var(--c-text); font-weight: 600; }

/* ── Hero: escudo, cuenta atrás, botones grandes ──────────────────────────── */
.page-head { margin-bottom: var(--space-5); }
.btn-lg { padding: var(--space-4) var(--space-6); font-size: 1.1rem; }

.hero-badge {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  width: 100px; height: 116px; margin: 0 auto var(--space-4);
  background: linear-gradient(160deg, var(--c-primary), var(--c-primary-2));
  color: #042713; clip-path: polygon(0 0, 100% 0, 100% 70%, 50% 100%, 0 70%);
  border: 0; font-weight: 900; line-height: 1; box-shadow: 0 8px 24px rgba(0,229,160,.3);
  position: relative;
}
.hero-badge::before {
  content: ""; position: absolute; inset: 3px;
  clip-path: polygon(0 0, 100% 0, 100% 70%, 50% 100%, 0 70%);
  border: 2px solid rgba(4,39,19,.35);
}
.hb-top { font-size: .58rem; letter-spacing: .04em; }
.hb-year { font-size: 2rem; margin: 2px 0; }
.hb-sub { font-size: .52rem; letter-spacing: .1em; opacity: .85; }

.countdown { margin: var(--space-5) auto; max-width: 540px; }
.cd-label { color: var(--c-muted); font-weight: 600; margin-bottom: var(--space-3); }
.cd-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-2); }
.cd-box { background: rgba(10,14,39,.6); border: 1px solid var(--c-border); border-radius: var(--radius-md); padding: var(--space-3) var(--space-2); }
.cd-num { display: block; font-size: clamp(1.7rem, 6vw, 2.6rem); font-weight: 900; color: var(--c-primary); font-variant-numeric: tabular-nums; line-height: 1; }
.cd-u { font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; color: var(--c-muted); }
.cd-live .cd-num { color: var(--c-live); }

/* ── Tarjetas de juego (home) ─────────────────────────────────────────────── */
.games-row .game-card {
  display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2);
  padding: var(--space-6); border-radius: var(--radius-lg); border: 1px solid var(--c-border);
  position: relative; overflow: hidden; transition: transform .2s, border-color .2s;
}
.games-row .game-card:hover { transform: translateY(-4px); border-color: var(--c-primary); }
.game-card h2 { font-size: 1.5rem; }
.game-card p { color: var(--c-muted); }
.game-card .btn { margin-top: var(--space-3); }
.game-emoji { display: inline-flex; margin-bottom: var(--space-2); }
.game-cromos { background: linear-gradient(160deg, rgba(176,107,255,.20), var(--c-bg-2)); }
.game-cromos .game-emoji { color: #b06bff; }
.game-quiniela { background: linear-gradient(160deg, rgba(0,229,160,.18), var(--c-bg-2)); }
.game-quiniela .game-emoji { color: var(--c-primary); }
.game-card .btn .icon { vertical-align: -.2em; }

/* ── Cuadro: cabecera de cada cruce ───────────────────────────────────────── */
.tie-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2); }
.tie-code { font-size: .7rem; font-weight: 800; color: var(--c-primary); background: rgba(0,229,160,.12); padding: 2px 6px; border-radius: 6px; }
.tie-date { font-size: .7rem; color: var(--c-muted); }
.tie-final { border-color: var(--c-gold); box-shadow: 0 0 18px rgba(255,210,63,.25); }
.tie-final .tie-code { color: var(--c-gold); background: rgba(255,210,63,.14); }

/* ── Iconos, banderas y refinamientos corporativos ────────────────────────── */
.icon { display:inline-block; vertical-align:-.18em; }
.brand-ball { color: var(--c-primary); display:inline-flex; align-items:center; }

.flag-img { height:1.05em; width:auto; border-radius:2px; vertical-align:-.15em;
  box-shadow:0 0 0 1px rgba(255,255,255,.10); object-fit:cover; }
.flag-na { display:inline-block; height:1.05em; width:1.4em; background:var(--c-surface-2);
  border-radius:2px; box-shadow:0 0 0 1px rgba(255,255,255,.10); }
.match .flag { font-size:inherit; }
.match .flag-img { height:1.7rem; }
.rank-list .n .flag-img { height:1.3rem; }
.cromo-team .flag-img { height:1em; }

/* Título con barra de acento (sustituye a los emoji) */
.h-accent { position:relative; padding-left:16px; }
.h-accent::before { content:""; position:absolute; left:0; top:.12em; bottom:.12em; width:5px;
  border-radius:3px; background:linear-gradient(var(--c-primary), var(--c-primary-2)); }

.pos-chip { font-family:var(--font-head); font-weight:800; font-size:.72rem; letter-spacing:.05em;
  color:var(--c-muted); border:1px solid var(--c-border); padding:2px 9px; border-radius:6px; }

.empty-state { color:var(--c-muted); padding:var(--space-4) var(--space-2); text-align:center; line-height:1.6; }

/* Sobre de cromos (pack) más sobrio */
.pack { font-size:0; position:relative; }
.pack .pack-ico { color:var(--c-gold); }
.pack .pack-label { position:absolute; bottom:14px; left:0; right:0; text-align:center;
  font-family:var(--font-head); font-weight:800; letter-spacing:.12em; font-size:.8rem; color:#04150d; }

/* Legales */
.legal { max-width:820px; }
.legal h2 { font-size:1.3rem; margin-top:var(--space-6); }
.legal h3 { font-size:1.05rem; margin-top:var(--space-4); }
.legal p, .legal li { color:var(--c-text); opacity:.92; margin-top:var(--space-3); line-height:1.7; }
.legal ul { padding-left:1.3em; }
.legal .ph { background:rgba(255,210,63,.16); border:1px dashed var(--c-gold); border-radius:4px;
  padding:0 6px; font-weight:700; color:var(--c-gold); }
.legal .updated { color:var(--c-muted); font-size:.9rem; }

/* Artículos / Análisis */
.article-card { display:flex; flex-direction:column; gap:8px; padding:var(--space-5);
  border:1px solid var(--c-border); border-radius:var(--radius-md);
  background:linear-gradient(180deg,var(--c-surface),var(--c-bg-2)); transition:transform .2s, border-color .2s; }
.article-card:hover { transform:translateY(-4px); border-color:var(--c-primary); }
.article-ico { color:var(--c-primary); display:inline-flex; }
.article-tag { font-family:var(--font-head); font-size:.66rem; font-weight:800; letter-spacing:.1em;
  text-transform:uppercase; color:var(--c-primary); }
.article-card h2 { font-size:1.15rem; line-height:1.2; }
.article-card h3 { font-size:1rem; line-height:1.2; }
.article-card p { color:var(--c-muted); font-size:.92rem; }
.article-more { margin-top:auto; color:var(--c-primary); font-weight:700; font-size:.9rem;
  display:inline-flex; align-items:center; gap:4px; }

.post { max-width:760px; }
.post > .article-tag { display:inline-block; margin-bottom:8px; }
.post h1 { font-size:clamp(1.8rem,4.5vw,2.6rem); margin-bottom:6px; }
.post-meta { margin-bottom:var(--space-5); }
.post-body h2 { font-size:1.4rem; margin-top:var(--space-6); }
.post-body p, .post-body li { line-height:1.8; margin-top:var(--space-3); }
.post-body ul { padding-left:1.3em; }
.post-body a { color:var(--c-primary); text-decoration:underline; }
.post-sources { margin-top:var(--space-7); padding-top:var(--space-4); border-top:1px solid var(--c-border); }
.post-sources h2 { font-size:1.1rem; }
.post-sources ul { padding-left:1.2em; }
.post-sources a { color:var(--c-primary); }
.post-related { margin-top:var(--space-7); }
.ficha-context p { margin-top:var(--space-2); }

/* Imágenes con crédito (media) */
.media { margin:0; }
.media img { width:100%; height:auto; display:block; border-radius:var(--radius-sm); }
.media .credit { font-size:.68rem; color:var(--c-muted); margin-top:4px; }
.media .credit a { color:var(--c-muted); text-decoration:underline; }
.post-body .media { margin:var(--space-4) 0; max-width:560px; }
.post-body .media img { max-height:480px; object-fit:cover; }
.post-hero { margin:0 0 var(--space-5); }
.post-hero img { width:100%; max-height:420px; object-fit:cover; border-radius:var(--radius-md); }

/* Estadios */
.stadium-card { border:1px solid var(--c-border); border-radius:var(--radius-md); overflow:hidden;
  background:linear-gradient(180deg,var(--c-surface),var(--c-bg-2)); transition:transform .2s, border-color .2s; }
.stadium-card:hover { transform:translateY(-4px); border-color:var(--c-primary); }
.stadium-photo { aspect-ratio:16/9; }
.stadium-photo img { width:100%; height:100%; object-fit:cover; }
.stadium-photo.placeholder { display:grid; place-items:center; color:var(--c-border);
  background:repeating-linear-gradient(45deg,var(--c-surface),var(--c-surface) 12px,var(--c-bg-2) 12px,var(--c-bg-2) 24px); }
.stadium-card .media .credit { padding:0 var(--space-3); }
.stadium-body { padding:var(--space-4); }
.stadium-body h2 { font-size:1.15rem; }
.stadium-meta { margin-top:var(--space-2); font-weight:600; }
.stadium-cap { color:var(--c-muted); font-size:.9rem; margin-top:4px; display:flex; align-items:center; gap:6px; }
.stadium-note { margin-top:var(--space-3); font-size:.8rem; font-weight:700; color:var(--c-primary);
  background:rgba(0,229,160,.10); border-radius:6px; padding:6px 10px; display:inline-block; }

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