:root{
  --bg:#f3f3f3;
  --paper:#ffffff;
  --paper-soft:#fafafa;
  --ink:#1e1e1e;
  --muted:#666b73;
  --line:#d7dbe0;
  --line-strong:#c4c8ce;
  --accent:#c71f25;
  --accent-dark:#9f171c;
  --accent-soft:#f7ecec;
  --success:#1f7a4d;
  --success-soft:#eaf6ef;
  --error:#9a1f28;
  --error-soft:#fbeaec;
  --warning:#8a6508;
  --warning-soft:#fff6dc;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(0,0,0,.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--ink);background:var(--bg);min-height:100vh;line-height:1.45}
a{color:inherit}

/* topbar */
.topbar{position:sticky;top:0;z-index:80;background:var(--accent);color:#fff;border-bottom:1px solid rgba(0,0,0,.08)}
.topbar__inner{max-width:1360px;margin:0 auto;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;font-weight:800}
.brand__ball{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);font-size:22px}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__title{font-size:19px;letter-spacing:-.02em}
.brand__sub{font-size:11px;opacity:.9;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.navlinks{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.navlinks a{color:#fff;text-decoration:none;font-weight:700;font-size:14px;padding:10px 12px;border-radius:999px;transition:.15s ease}
.navlinks a:hover{background:rgba(255,255,255,.12)}
.navlinks .pill{background:#fff;color:var(--accent)}
.navlinks .pill:hover{background:#fff;opacity:.92}

.container{max-width:1360px;margin:0 auto;padding:24px 18px 54px}

/* common cards */
.card,.hero-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card{padding:22px}
.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.hero-card{padding:28px;position:relative;overflow:hidden}
.hero-card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:var(--accent)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;background:var(--accent-soft);color:var(--accent);padding:8px 11px;border-radius:999px}
.hero h1{font-size:clamp(32px,4vw,52px);line-height:1.02;margin:16px 0 14px;letter-spacing:-.04em;color:#171717}
.hero p{color:var(--muted);font-size:16px;line-height:1.68;margin:0 0 14px}
.hero .lead{font-size:17px;color:#4e5661}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;padding:11px 15px;font-size:14px;font-weight:800;cursor:pointer;text-decoration:none;background:var(--accent);color:#fff;box-shadow:0 8px 18px rgba(199,31,37,.14);transition:.15s ease}
.btn:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn.secondary{background:#fff;color:var(--accent);border:1px solid var(--line);box-shadow:none}
.btn.secondary:hover{background:var(--paper-soft)}
.btn.danger{background:var(--accent-dark)}
.btn:disabled{background:#cfd4da;color:#fff;box-shadow:none;cursor:not-allowed;transform:none}

.mini-stats{display:grid;gap:14px}
.stat{padding:20px}
.stat__label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.stat__number{font-size:34px;line-height:1;font-weight:900;margin-top:6px;color:var(--accent)}
.stat .muted{margin-top:8px}

.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.card h2,.card h3{margin:0 0 10px;color:#202225;letter-spacing:-.02em}
.muted{color:var(--muted);line-height:1.62}
.subtle{color:#505661}
.alert{padding:13px 14px;border-radius:12px;margin-bottom:16px;font-weight:700;border:1px solid transparent}
.alert.ok{background:var(--success-soft);border-color:#cbe7d6;color:var(--success)}
.alert.err{background:var(--error-soft);border-color:#efc8ce;color:var(--error)}

/* forms */
.form-card{max-width:560px;margin:26px auto}
.field{margin:14px 0}
.field label{display:block;font-size:13px;font-weight:800;margin-bottom:7px;color:#2a2f38}
.field input,.field select,.compact-form input,.compact-form select{width:100%;padding:12px 13px;border-radius:12px;border:1px solid var(--line);background:#fff;font:inherit;outline:none}
.field input:focus,.field select:focus,.compact-form input:focus,.compact-form select:focus{border-color:#bfc5cc;box-shadow:0 0 0 3px rgba(199,31,37,.08)}
.note-box{background:#f8f8f8;border:1px solid var(--line);border-radius:12px;padding:14px 15px;color:#4f5660;font-size:14px;line-height:1.6}

/* sections */
.section-title{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:26px 0 12px}
.section-title h2{margin:0;color:#202225;font-size:26px;letter-spacing:-.02em}
.date-title{font-size:17px;font-weight:900;color:#202225;padding:0 0 8px;margin:28px 0 12px;border-bottom:1px solid var(--line-strong)}

/* home legacy blocks */
.legacy-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.legacy-quote{font-size:15px;line-height:1.8;color:#484f59}
.timeline-list{display:grid;gap:12px;margin-top:10px}
.timeline-item{padding:14px 14px 14px 16px;border-left:4px solid var(--accent);background:#fcfcfc;border-radius:0 12px 12px 0;border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.timeline-item strong{display:block;font-size:14px;margin-bottom:4px}
.feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.feature-card{border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff}
.feature-card h3{font-size:16px;margin-bottom:8px}
.feature-card p{font-size:14px;color:var(--muted);margin:0;line-height:1.55}

/* dashboard match layout */
.matches{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
.match{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:10px;box-shadow:none}
.match__top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.phase{font-size:10px;font-weight:800;color:#5c616a;text-transform:uppercase;letter-spacing:.04em}
.group{font-size:11px;color:#6a7079;margin-top:2px}
.time{font-size:12px;color:#1f1f1f;font-weight:900;white-space:nowrap}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:800;border:1px solid transparent;margin-bottom:7px}
.badge.pendiente{background:#fff;border-color:#e0e3e7;color:#5f6670}
.badge.finalizado{background:#f3f4f6;border-color:#dcdfe4;color:#3d434b}
.badge.en_juego{background:var(--success-soft);border-color:#cde7d6;color:var(--success)}
.badge.anulado{background:var(--error-soft);border-color:#efc8ce;color:var(--error)}
.badge.verde{background:var(--success-soft);border-color:#cde7d6;color:var(--success)}
.badge.amarillo{background:var(--warning-soft);border-color:#efdfaa;color:var(--warning)}
.badge.rojo{background:var(--error-soft);border-color:#efc8ce;color:var(--error)}
.match .btn{width:100%;margin-top:8px}

.teams{display:grid;gap:6px;margin:8px 0}
.team{display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:7px;background:#fff;cursor:pointer;transition:.15s}
.team:hover{border-color:#bfc5cc;background:#fafafa}
.team input{margin:0}
.flag{font-size:20px;line-height:1}
.team b{display:block;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:800}
.team small{display:block;font-size:10px;color:var(--muted);font-weight:800;margin-top:2px}
.credit-note{font-size:10px;color:var(--muted);font-weight:800}
.predicted{background:#f7f8f9;border:1px solid var(--line);color:#2d343b;padding:9px;border-radius:9px;font-size:11px;line-height:1.45;font-weight:700}

/* tables */
.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse;min-width:760px}
.table th,.table td{padding:11px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;vertical-align:top}
.table th{background:#f7f7f7;color:#202225;font-weight:900;position:sticky;top:0}
.rank{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#f3f3f3;border:1px solid var(--line);font-weight:900;color:#444}
.empty{padding:26px;border:1px dashed var(--line-strong);border-radius:14px;background:#fff;text-align:center;color:var(--muted)}

/* admin */
.admin-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.compact-form{display:grid;gap:8px}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 18px}
.tabs a{padding:10px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);text-decoration:none;font-weight:800;font-size:13px;color:#363b43}
.tabs a.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* footer */
.footer{max-width:1360px;margin:0 auto;padding:24px 18px 34px;color:var(--muted);font-size:12px;text-align:center}
.footer strong{color:#343840}

@media(max-width:1260px){.matches{grid-template-columns:repeat(5,1fr)}.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1100px){.hero{grid-template-columns:1fr}.legacy-grid{grid-template-columns:1fr}.matches{grid-template-columns:repeat(4,1fr)}.admin-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.grid{grid-template-columns:1fr}.matches{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.topbar__inner{flex-direction:column;align-items:flex-start}.navlinks{width:100%}.container{padding:18px 12px 42px}.hero-card,.card{padding:18px}.feature-grid{grid-template-columns:1fr}.matches{grid-template-columns:repeat(2,1fr)}.admin-grid{grid-template-columns:1fr}}
@media(max-width:520px){.matches{grid-template-columns:1fr}.actions{flex-direction:column}.btn{width:100%}.hero h1{font-size:30px}.section-title h2{font-size:22px}}






.flag-img {
    width: 30px;
    height: 20px;
    object-fit: cover;
    border-radius: 2px;
    border: 1px solid #d7dbe0;
    display: block;
    background: #fff;
}

.flag-text {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 20px;
    padding: 0 4px;
    border-radius: 3px;
    border: 1px solid #d7dbe0;
    background: #f4f4f4;
    color: #333;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.03em;
}

.flag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    min-width: 34px;
}