/* ═══ Polla Mundialera 2026 · doctrina SonKiri glass-mac (dark-first) ═══ */
:root{
  --bg-base:#1a1625;
  --bg-elevated:rgba(255,255,255,.06);
  --bg-elevated-strong:rgba(255,255,255,.10);
  --bg-elevated-floating:rgba(255,255,255,.14);
  --glass-blur:blur(20px) saturate(180%);
  --glass-blur-strong:blur(40px) saturate(200%);
  --shadow:0 8px 32px rgba(26,22,37,.4),0 1px 0 rgba(255,255,255,.10) inset;
  --shadow-strong:0 24px 64px rgba(26,22,37,.5),0 1px 0 rgba(255,255,255,.15) inset;

  --royal:#3a63d8;          /* azul royal SonKiri, aclarado para contraste sobre noche */
  --royal-soft:#2A4FBF;
  --gold:#e0a528;           /* dorado · reservado a campeón / podio / CTA */
  --gold-deep:#D4880A;
  --teal:#2ACEA8;           /* exacto (3pt) */
  --cyan:#1EA8C8;           /* acierto (2pt) */
  --coral:#E05A35;          /* fallo */

  --t1:rgba(255,255,255,.95);
  --t2:rgba(255,255,255,.74);
  --t3:rgba(255,255,255,.50);
  --t4:rgba(255,255,255,.32);
  --hair:rgba(255,255,255,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html,body{
  background:var(--bg-base);color:var(--t1);
  font-family:'Inter',system-ui,sans-serif;
  font-feature-settings:"liga" 1,"kern" 1,"tnum" 1;
  -webkit-font-smoothing:antialiased;min-height:100vh;position:relative;
}
.aurora{
  content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(circle at 18% 28%, #e8627f 0%, transparent 42%),
    radial-gradient(circle at 82% 18%, #2fb6c9 0%, transparent 38%),
    radial-gradient(circle at 65% 82%, #e8b14a 0%, transparent 46%);
  filter:blur(48px);opacity:.34;
}
.grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}
.display{font-family:'Raleway',system-ui,sans-serif;font-weight:300;letter-spacing:-.02em}
.display em{font-style:italic;font-weight:300}
.eyebrow{font-weight:500;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--t3)}
.mono{font-variant-numeric:tabular-nums}
::selection{background:var(--royal);color:#fff}

/* glass cards */
.card-glass,.card-glass-soft,.card-glass-strong{
  border:1px solid transparent;background-origin:border-box;background-clip:padding-box,border-box;
}
.card-glass{
  background:var(--bg-elevated-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  background-image:linear-gradient(var(--bg-elevated-strong),var(--bg-elevated-strong)),linear-gradient(135deg,rgba(255,255,255,.20),rgba(255,255,255,.05) 50%,rgba(255,255,255,.12));
  box-shadow:var(--shadow);
}
.card-glass-soft{
  background:var(--bg-elevated);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  background-image:linear-gradient(var(--bg-elevated),var(--bg-elevated)),linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.03) 50%,rgba(255,255,255,.08));
  box-shadow:var(--shadow);
}
.card-glass-strong{
  background:var(--bg-elevated-floating);backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);
  background-image:linear-gradient(var(--bg-elevated-floating),var(--bg-elevated-floating)),linear-gradient(135deg,rgba(255,255,255,.30),rgba(255,255,255,.08) 50%,rgba(255,255,255,.20));
  box-shadow:var(--shadow-strong);
}

/* buttons */
.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#2a1c02;border:none;
  border-radius:12px;padding:14px 18px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;
  transition:transform .15s, box-shadow .15s;
}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(224,165,40,.30)}
.btn-gold.sm{padding:9px 14px;font-size:13px;border-radius:10px}
.btn-ghost{background:var(--bg-elevated);border:1px solid var(--hair);color:var(--t2);border-radius:10px;padding:9px 14px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}
.btn-ghost:hover{color:var(--coral);border-color:var(--coral)}
.btn-ghost.sm{padding:9px 14px}

/* ===== LOGIN ===== */
.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{border-radius:26px;padding:42px 38px;width:min(420px,100%);position:relative}
.brand-mark.lg{width:52px;height:52px;border-radius:15px;font-size:18px;margin-bottom:22px}
.login-card h1{font-family:'Raleway';font-weight:200;letter-spacing:-.03em;font-size:clamp(34px,7vw,46px);line-height:1;margin:0 0 14px}
.login-card .sub{color:var(--t2);font-size:14px;line-height:1.6;margin:0 0 24px;max-width:32ch}
#loginForm{display:flex;flex-direction:column;gap:10px}
.btn-gold i{font-size:13px}
#passInput{
  background:rgba(0,0,0,.22);border:1px solid var(--hair);border-radius:12px;padding:15px 16px;
  color:var(--t1);font-size:15px;font-family:inherit;letter-spacing:.04em;
}
#passInput:focus{outline:none;border-color:var(--royal);box-shadow:0 0 0 3px rgba(58,99,216,.22)}
.login-error{color:var(--coral);font-size:13px;margin-top:12px}
.login-foot{margin-top:24px;color:var(--t3);font-size:12px;display:flex;align-items:center;gap:8px}
.login-foot .dot{width:6px;height:6px;border-radius:50%;background:var(--teal)}

/* ===== TOPBAR ===== */
.topbar{
  position:sticky;top:12px;z-index:30;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin:12px auto;max-width:1120px;width:calc(100% - 24px);padding:10px 14px;border-radius:16px;
}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto}
.brand-mark{
  width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;font-size:14px;
  background:linear-gradient(135deg,var(--royal),var(--royal-soft));color:#fff;letter-spacing:.02em;
  box-shadow:0 4px 14px rgba(58,99,216,.35);
}
.brand-txt strong{display:block;font-size:14px;font-weight:600}
.brand-txt small{color:var(--t3);font-size:11px}
.tabs{display:flex;gap:3px;background:rgba(0,0,0,.22);padding:4px;border-radius:12px;border:1px solid var(--hair)}
.tab{background:none;border:none;color:var(--t3);font-weight:600;font-size:13px;padding:8px 15px;border-radius:9px;cursor:pointer;font-family:inherit;transition:.15s}
.tab:hover{color:var(--t1)}
.tab.active{background:var(--royal);color:#fff;box-shadow:0 3px 12px rgba(58,99,216,.4)}
.tab i{font-size:12px;margin-right:3px}
.tab-admin.active{background:var(--gold-deep);color:#2a1c02}
.top-actions{display:flex;gap:6px;align-items:center}
.played-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(0,0,0,.2);border:1px solid var(--hair);border-radius:10px;padding:8px 12px;font-size:12px;color:var(--t2);font-variant-numeric:tabular-nums}
.played-chip i{color:var(--teal)}
.icon-btn{background:rgba(0,0,0,.18);border:1px solid var(--hair);color:var(--t3);padding:8px 13px;border-radius:10px;cursor:pointer;font-weight:600;font-size:12px;font-family:inherit;text-transform:lowercase}
.icon-btn:hover{color:var(--t1);border-color:var(--royal)}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:1fr 1fr 1fr 1.7fr;gap:12px;padding:8px 20px 4px;max-width:1120px;margin:0 auto}
.stat{border-radius:16px;padding:16px 18px}
.stat .n{font-family:'Raleway';font-weight:300;font-size:32px;letter-spacing:-.02em;line-height:1}
.stat .n small{font-size:15px;color:var(--t3)}
.stat .l{color:var(--t3);font-size:12px;font-weight:500;margin-top:6px}
/* el pozo manda · no es una tarjeta más */
.stat.pozo{
  background-image:linear-gradient(135deg,rgba(224,165,40,.16),rgba(212,136,10,.06)),linear-gradient(135deg,rgba(224,165,40,.5),rgba(255,255,255,.08) 60%);
  display:flex;flex-direction:column;justify-content:center;
}
.stat.pozo .n{color:var(--gold);font-size:clamp(34px,4.4vw,46px)}
.stat.pozo .l{color:rgba(224,165,40,.8)}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}.stat.pozo{grid-column:1/-1}}

/* ===== VIEWS ===== */
.view{max-width:1120px;margin:0 auto;padding:14px 20px 70px}
.view h2{font-size:clamp(26px,4vw,34px);margin:4px 0 0}
.view-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:14px 0 18px}
/* frase editorial con dato concreto · calidez, no relleno */
.promise{font-family:'Raleway';font-style:italic;font-weight:300;color:var(--t2);font-size:clamp(15px,2vw,18px);margin:6px 0 0;max-width:50ch}
.promise b{font-style:normal;font-weight:400;color:var(--gold)}
.search-wrap{display:flex;align-items:center;gap:9px;background:rgba(0,0,0,.22);border:1px solid var(--hair);border-radius:11px;padding:0 13px}
.search-wrap i{color:var(--t4);font-size:13px}
.search-wrap input{background:none;border:none;outline:none;color:var(--t1);font-family:inherit;font-size:14px;padding:11px 0;width:200px;max-width:42vw}
.search-wrap:focus-within{border-color:var(--royal);box-shadow:0 0 0 3px rgba(58,99,216,.2)}
.select{background:rgba(0,0,0,.22);border:1px solid var(--hair);color:var(--t1);padding:10px 14px;border-radius:11px;font-size:14px;font-family:inherit;cursor:pointer}

/* ===== RANKING ===== */
/* movimiento (racha) */
.mov{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}
.mov.up{color:var(--teal)} .mov.down{color:var(--coral)} .mov.same{color:var(--t4)}
.mov i{font-size:9px}

/* ===== PODIO ===== */
.podium{display:grid;grid-template-columns:1fr 1.18fr 1fr;gap:14px;align-items:end;margin-bottom:20px}
.pod{position:relative;border-radius:22px;padding:22px 16px 18px;text-align:center;background:var(--bg-elevated);border:1px solid var(--hair);box-shadow:var(--shadow)}
.pod .mov{position:absolute;top:14px;right:14px;font-size:12px}
.pod-av{border-radius:50%;margin:0 auto;display:grid;place-items:center;font-family:'Raleway';font-weight:400;color:#fff;border:2px solid rgba(255,255,255,.25)}
.pod-place{margin-top:6px;font-size:11px;font-weight:700}
.pod-name{font-family:'Raleway';font-weight:400;font-size:18px;margin-top:5px}
.pod-ini{font-size:10.5px;color:var(--t4);letter-spacing:.05em}
.pod-tot{font-family:'Raleway';font-weight:300;font-size:34px;margin-top:8px;line-height:1}
.pod-tot small{font-size:13px;color:var(--t4)}
.pod-chips{display:flex;justify-content:center;gap:6px;margin-top:10px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;border-radius:7px;padding:3px 8px}
.chip.ex{background:rgba(42,206,168,.16);color:var(--teal)}
.chip.ac{background:rgba(30,168,200,.16);color:var(--cyan)}
.pod-sub{margin-top:11px;font-size:11.5px;color:var(--t3)}
.pod-sub b{color:var(--t1);font-weight:700}
.pod-spacer{height:40px}
/* 1ro */
.pod.first{padding:26px 18px 20px;border-radius:24px;border-color:rgba(224,165,40,.4);
  background:linear-gradient(160deg,rgba(224,165,40,.18),rgba(212,136,10,.05)),var(--bg-elevated-floating);
  animation:glowPulse 6s ease-in-out infinite}
.pod.first .crown{color:#e8b53a;font-size:22px;filter:drop-shadow(0 4px 10px rgba(224,165,40,.5))}
.pod.first .pod-av{width:74px;height:74px;font-size:23px;color:#2a1c02;margin-top:8px;background:linear-gradient(135deg,#f1c558,#D4880A);border:2.5px solid rgba(255,255,255,.5);box-shadow:0 10px 28px rgba(224,165,40,.45)}
.pod.first .pod-place{color:#e8b53a;text-transform:uppercase;letter-spacing:.06em;margin-top:8px}
.pod.first .pod-name{font-size:23px}
.pod.first .pod-tot{font-size:48px;color:#e8b53a}
.pod.first .pod-tot small{color:rgba(224,165,40,.6);font-size:15px}
/* 2do / 3ro */
.pod.second .pod-av,.pod.third .pod-av{width:60px;height:60px;font-size:18px}
.pod.second .pod-av{background:linear-gradient(135deg,rgba(207,214,230,.5),rgba(150,160,180,.3));border-color:rgba(207,214,230,.6)}
.pod.third .pod-av{background:linear-gradient(135deg,rgba(221,154,120,.5),rgba(170,110,80,.3));border-color:rgba(224,140,90,.55)}
.pod.second .pod-place{color:#cfd6e6} .pod.second .pod-tot{color:#e7ecf7}
.pod.third .pod-place{color:#dd9a78} .pod.third .pod-tot{color:#f0d3c6}
.pod.ghost{opacity:.5;animation:none;border-style:dashed}
.pod.ghost .pod-av{background:rgba(255,255,255,.06)!important;color:var(--t4);border-color:var(--hair)!important;box-shadow:none!important}
.pod.ghost .pod-name,.pod.ghost .pod-tot{color:var(--t4)!important}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 1px rgba(224,165,40,.4),0 18px 50px rgba(224,165,40,.18)}50%{box-shadow:0 0 0 1px rgba(224,165,40,.6),0 22px 64px rgba(224,165,40,.30)}}
@media(max-width:640px){.podium{grid-template-columns:1fr;gap:10px}.pod.first{order:-1}.pod-spacer{display:none}}

/* ===== TABLA RANKING ===== */
.ranking-wrap{border-radius:20px;overflow:hidden}
.rank-row{position:relative;display:grid;grid-template-columns:64px 1fr 76px 76px 90px;align-items:center;padding:14px 20px;border-top:1px solid var(--hair);gap:10px}
.rank-row:first-child{border-top:none}
.rank-row.head{background:rgba(0,0,0,.2);color:var(--t4);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em}
.rank-row.head span:nth-child(3),.rank-row.head span:nth-child(4){text-align:center}
.rank-row.head span:last-child{text-align:right}
.rank-pos{display:flex;align-items:center;gap:6px}
.rank-pos .pos{font-family:'Raleway';font-weight:300;font-size:21px;min-width:22px;text-align:center;color:var(--t2)}
.rank-row.top1 .pos{color:var(--gold)} .rank-row.top2 .pos,.rank-row.top3 .pos{color:var(--t1)}
.rank-who{display:flex;align-items:center;gap:11px;min-width:0}
.rank-av{width:36px;height:36px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;font-family:'Raleway';font-size:14px;background:rgba(58,99,216,.28);border:1px solid rgba(255,255,255,.16)}
.rank-name{font-weight:600;font-size:14.5px}
.rank-meta{font-size:11px;color:var(--t4);margin-top:1px}
.rank-num{text-align:center}
.rank-num span{display:inline-block;min-width:30px;font-weight:700;font-size:13.5px;border-radius:8px;padding:4px 0}
.rank-num.ex span{color:var(--teal);background:rgba(42,206,168,.14)}
.rank-num.ac span{color:var(--cyan);background:rgba(30,168,200,.14)}
.rank-tot{text-align:right;font-family:'Raleway';font-weight:400;font-size:25px;color:var(--royal);font-variant-numeric:tabular-nums}
.rank-bar{position:absolute;left:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--royal),transparent)}
.empty-rank{padding:30px;text-align:center;color:var(--t3);font-size:14px}

/* ===== PREMIOS ===== */
.premios{margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:13px}
.premio{border-radius:18px;padding:18px 20px;background:var(--bg-elevated);border:1px solid var(--hair)}
.premio.p1{background:linear-gradient(135deg,rgba(224,165,40,.14),rgba(212,136,10,.04));border-color:rgba(224,165,40,.28)}
.premio .lab{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;display:flex;align-items:center;gap:8px}
.premio .lab i{color:#cfd6e6}.premio.p1 .lab i{color:var(--gold)}
.premio .v{font-family:'Raleway';font-weight:300;font-size:32px;letter-spacing:-.02em;margin-top:8px;line-height:1;color:#e7ecf7}
.premio.p1 .v{color:var(--gold)}
.premio .now{font-size:12px;color:var(--t3);margin-top:6px}
.premio .now b{color:var(--t1);font-weight:600}
@media(max-width:560px){.premios{grid-template-columns:1fr}}

/* ===== PARTIDOS ===== */
.filtros{display:flex;flex-wrap:wrap;gap:6px}
.fbtn{background:rgba(0,0,0,.2);border:1px solid var(--hair);color:var(--t3);padding:7px 13px;border-radius:9px;cursor:pointer;font-weight:600;font-size:12px;font-family:inherit}
.fbtn:hover{color:var(--t1)}
.fbtn.active{background:var(--royal);color:#fff;border-color:transparent}
.partidos-list{overflow-x:auto}
/* tabla compacta de partidos */
.ptbl{min-width:880px;border:1px solid var(--hair);border-radius:14px;overflow:hidden}
.ptr{display:grid;grid-template-columns:46px 92px 56px 1fr 118px 1fr 64px 200px;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--hair);font-size:13px}
.ptr.head .cl{display:block;text-align:right}
.ptr.head .cv{display:block;text-align:left}
.ptr.head .cm{white-space:nowrap}
.ptr:last-child{border-bottom:none}
.ptr:nth-child(even){background:rgba(255,255,255,.02)}
.ptr.head{background:rgba(0,0,0,.22);color:var(--t3);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.ptr .pg{display:inline-block;text-align:center;background:rgba(58,99,216,.16);color:#9bb3ff;font-weight:600;border-radius:6px;padding:2px 0}
.ptr .pd{color:var(--t2);font-weight:600;font-size:11px;letter-spacing:.02em}
.ptr .ph{color:var(--t2);font-variant-numeric:tabular-nums}
.ptr .cl{display:flex;align-items:center;justify-content:flex-end;gap:8px;text-align:right;font-weight:500}
.ptr .cv{display:flex;align-items:center;gap:8px;font-weight:500}
.ptr .cl.win,.ptr .cv.win{font-weight:700;color:var(--t1)}
.ptr .cm{text-align:center;font-family:'Raleway';font-weight:400;font-size:18px;font-variant-numeric:tabular-nums}
.ptr .cm i{color:var(--t4);font-style:normal;margin:0 2px}
.ptr .cm.vs{font-family:'Inter';font-size:11px;color:var(--t4);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.flag-img{width:24px;height:18px;object-fit:cover;border-radius:3px;box-shadow:0 0 0 1px rgba(255,255,255,.12);flex:0 0 auto}
.flag-ph{display:inline-block;width:24px;height:18px;border-radius:3px;background:rgba(255,255,255,.1);flex:0 0 auto}
.cd{display:flex;flex-wrap:wrap;gap:4px}
.tv{font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;white-space:nowrap}
.tv-p{background:rgba(58,99,216,.18);color:#9bb3ff}
.tv-a{background:rgba(42,206,168,.16);color:var(--teal)}
.tv-s{background:rgba(224,165,40,.16);color:var(--gold)}
.tv-none{font-size:11px;color:var(--t4)}
.partidos-list-old{display:flex;flex-direction:column;gap:8px}
.pgroup-label{font-family:'Raleway';font-weight:400;font-size:15px;color:var(--t3);margin:16px 0 6px;letter-spacing:.04em}
.pgroup-label::before{content:'grupo ';color:var(--t4)}
.match{border-radius:14px;padding:13px 18px;display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;background:var(--bg-elevated);border:1px solid var(--hair)}
.match .meta{font-size:11px;color:var(--t3);font-weight:500;line-height:1.5}
.match .meta .g{display:inline-block;background:rgba(58,99,216,.18);border-radius:6px;padding:1px 8px;color:#9bb3ff;font-weight:600;margin-bottom:4px}
.match .teams{display:flex;flex-direction:column;gap:7px}
.match .team{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:500;font-size:14px}
.match .team.win{font-weight:700}
.match .score{font-family:'Raleway';font-weight:400;font-size:18px;min-width:22px;text-align:center;font-variant-numeric:tabular-nums}
.match .badge{font-size:10px;font-weight:600;padding:4px 11px;border-radius:999px;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}
.b-pend{background:rgba(255,255,255,.08);color:var(--t3)}
.b-final{background:rgba(42,206,168,.16);color:var(--teal)}
.flag{font-size:16px;opacity:.9}
/* código de país · tag deliberado, no bandera rota */
.tcode{display:inline-block;min-width:30px;text-align:center;padding:2px 6px;margin-right:8px;border-radius:6px;
  font-size:10px;font-weight:600;letter-spacing:.06em;background:rgba(58,99,216,.16);color:#9bb3ff;
  font-variant-numeric:tabular-nums;vertical-align:middle}
.team.win .tcode{background:rgba(224,165,40,.18);color:var(--gold)}
.cart-row .tcode,.adm-teams .tcode{min-width:26px;margin-right:5px}

/* ===== LLAVES ===== */
.llaves-note{border-radius:16px;padding:18px 20px;margin:14px 0 22px}
.llaves-note strong{font-weight:600}
.llaves-note p{color:var(--t3);font-size:13px;margin-top:5px;line-height:1.5}
.bracket{display:flex;gap:26px;overflow-x:auto;padding:6px 2px 18px}
.round{display:flex;flex-direction:column;justify-content:space-around;gap:14px;min-width:190px}
.round-title{font-family:'Raleway';font-weight:400;color:var(--t3);font-size:13px;text-align:center;letter-spacing:.06em;margin-bottom:2px}
.tie{border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:8px;background:var(--bg-elevated);border:1px solid var(--hair)}
.tie .slot{display:flex;justify-content:space-between;color:var(--t4);font-size:13px;border-bottom:1px dashed var(--hair);padding-bottom:6px}
.tie .slot:last-child{border-bottom:none;padding-bottom:0}
.tie .slot::before{content:'por definir'}

/* ===== ADMIN ===== */
.admin-sub{display:flex;gap:4px;background:rgba(0,0,0,.2);padding:4px;border-radius:12px;border:1px solid var(--hair);width:fit-content;margin:16px 0 18px}
.subtab{background:none;border:none;color:var(--t3);font-weight:600;font-size:13px;padding:8px 16px;border-radius:9px;cursor:pointer;font-family:inherit}
.subtab.active{background:var(--gold-deep);color:#2a1c02}
.admin-note{color:var(--t3);font-size:13px;line-height:1.6;margin-bottom:16px;max-width:760px}
.admin-note code{background:rgba(0,0,0,.3);padding:2px 7px;border-radius:6px;color:var(--gold);font-family:ui-monospace,monospace}
.admin-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.admin-status{color:var(--teal);font-size:13px;font-weight:500}
.ord{display:inline-flex;align-items:center;gap:5px;color:var(--t3);font-size:12px}
.ordbtn{background:rgba(0,0,0,.2);border:1px solid var(--hair);color:var(--t3);padding:6px 11px;border-radius:8px;cursor:pointer;font-weight:600;font-size:12px;font-family:inherit}
.ordbtn:hover{color:var(--t1)}
.ordbtn.active{background:var(--gold-deep);color:#2a1c02;border-color:transparent}
.admin-list{display:flex;flex-direction:column;gap:6px}
.dropzone{border:1.5px dashed var(--hair);border-radius:16px;padding:26px;text-align:center;background:rgba(255,255,255,.02);transition:.15s}
.dropzone.over{border-color:var(--gold);background:rgba(224,165,40,.08)}
.dz-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.dz-ic{font-size:30px;color:var(--gold);line-height:1}
.dz-inner>div{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.dz-hint{color:var(--t3);font-size:12px;line-height:1.6;margin-top:2px}
.dz-hint code{background:rgba(0,0,0,.3);padding:1px 6px;border-radius:5px;color:var(--gold);font-family:ui-monospace,monospace;font-size:11px}
.alt-paste{margin-top:18px;border-top:1px solid var(--hair);padding-top:14px}
.alt-paste summary{color:var(--t3);font-size:13px;cursor:pointer;font-weight:600}
.alt-paste summary:hover{color:var(--t1)}
.cartilla-input{width:100%;background:rgba(0,0,0,.28);border:1px solid var(--hair);border-radius:12px;padding:14px;color:var(--t1);font-family:ui-monospace,'JetBrains Mono',monospace;font-size:13px;line-height:1.6;resize:vertical;margin-bottom:14px}
.cartilla-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,165,40,.16)}
.cart-row .flag-img,.adm-teams .flag-img{width:20px;height:15px;vertical-align:middle;margin:0 5px}
.adm-row{border-radius:12px;padding:10px 16px;display:grid;grid-template-columns:64px 1fr auto;gap:14px;align-items:center;background:var(--bg-elevated);border:1px solid var(--hair)}
.adm-row .g{color:#9bb3ff;font-weight:600;font-size:12px}
.adm-row .g small{display:block;color:var(--t4);font-weight:400;margin-top:2px}
.adm-teams{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;font-weight:500;font-size:14px}
.adm-teams .vl{text-align:right}
.adm-teams .vs{color:var(--t4);font-size:11px}
.adm-inputs{display:flex;align-items:center;gap:6px}
.adm-inputs input{width:46px;height:42px;text-align:center;font-size:18px;font-weight:600;background:rgba(0,0,0,.28);border:1px solid var(--hair);border-radius:10px;color:var(--t1);font-family:inherit;font-variant-numeric:tabular-nums}
.adm-inputs input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,165,40,.18)}
.adm-inputs input.filled{border-color:var(--gold);color:var(--gold)}
.adm-inputs .dash{color:var(--t4)}

/* cartilla detalle (admin) */
.cart-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-bottom:18px}
.cart-table{border-radius:14px;overflow:hidden;border:1px solid var(--hair)}
.cart-row{display:grid;grid-template-columns:44px 1fr 70px 70px 54px;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--hair);font-size:13px;background:var(--bg-elevated)}
.cart-row:last-child{border-bottom:none}
.cart-row.head{background:rgba(0,0,0,.2);color:var(--t3);font-size:11px;font-weight:600;text-transform:uppercase}
.cart-row .g{color:#9bb3ff;font-weight:600;text-align:center}
.cart-row .mi,.cart-row .real{text-align:center;font-weight:600;font-variant-numeric:tabular-nums}
.cart-row .real{color:var(--t3)}
.cart-row .p{text-align:center;font-weight:700;border-radius:8px;padding:3px 0;font-variant-numeric:tabular-nums}
.p3{background:rgba(42,206,168,.18);color:var(--teal)}
.p2{background:rgba(30,168,200,.18);color:var(--cyan)}
.p0{background:rgba(224,90,53,.16);color:var(--coral)}
.pp{color:var(--t4)}

/* modal admin */
.modal-overlay{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:24px;background:rgba(10,8,16,.6)}
.modal{border-radius:22px;padding:30px 30px 26px;width:min(400px,100%)}
.modal h3{font-size:28px;margin:8px 0 6px}
.modal p{color:var(--t3);font-size:13px;margin-bottom:18px}
.modal input{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--hair);border-radius:11px;padding:13px 15px;color:var(--t1);font-family:inherit;font-size:14px}
.modal input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,165,40,.18)}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}

.foot{display:flex;gap:10px;justify-content:center;align-items:center;color:var(--t3);font-size:12px;padding:24px;border-top:1px solid var(--hair);max-width:1120px;margin:0 auto;flex-wrap:wrap}
.foot .sep{color:var(--t4)} .foot .muted{color:var(--t4)}

@media(max-width:640px){
  .brand-txt small{display:none}
  .tab{padding:8px 11px;font-size:12px}
  .stat .n{font-size:26px}
  .rank-row{grid-template-columns:40px 1fr 60px 70px;font-size:13px}
  .rank-row .num.res{display:none}
  .rank-row.head .num.res{display:none}
  .match{grid-template-columns:72px 1fr auto}
  .cart-row{grid-template-columns:30px 1fr 54px 54px 44px;font-size:12px}
  .search-wrap input{width:100%}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
