:root{
    --blue:#004f9f; --blue-2:#0a72d6; --blue-d:#013366; --navy:#061f3f;
    --orange:#ef7816; --orange-2:#ff9d42; --orange-d:#cc5f0a;
    --gray:#878787; --bg:#eef2f8; --ink:#14223d; --muted:#65728a; --line:#e6ecf4; --card:#fff; --danger:#d83a3a;
    --grad-brand:linear-gradient(135deg,#004f9f,#0a72d6);
    --grad-accent:linear-gradient(135deg,#ef7816,#ff9d42);
    --grad-mix:linear-gradient(120deg,#004f9f,#0a72d6 45%,#ef7816);
    --shadow:0 8px 26px -10px rgba(8,35,75,.18);
    --shadow-lg:0 26px 50px -18px rgba(8,35,75,.30);
    --r:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100vw}
body::before{content:"";position:fixed;inset:0;z-index:-1;background:
    radial-gradient(38% 44% at 100% 0%,rgba(239,120,22,.07),transparent 70%),
    radial-gradient(46% 50% at 0% 100%,rgba(0,79,159,.08),transparent 70%)}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-d)}
.wrap{max-width:1060px;margin:0 auto;padding:0 20px}
h1{margin:.1em 0;font-weight:800;letter-spacing:-.025em}
h2{font-weight:800;letter-spacing:-.02em;margin-top:1.7em;font-size:1.5rem}
h3{font-weight:700;margin:.2em 0}
.muted{color:var(--muted)}
.small{font-size:.85rem}
code{background:rgba(0,79,159,.08);color:var(--blue-d);padding:1px 6px;border-radius:5px;font-size:.88em}
.gradtext{background:var(--grad-mix);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Topbar (glass) ---------- */
.topbar{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line)}
@supports (backdrop-filter:blur(1px)){.topbar{background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(170%)}}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 20px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand .logo{height:42px;width:auto;display:block;transition:transform .3s}
.brand:hover .logo{transform:scale(1.05) rotate(-2deg)}
.brand-text{font-weight:800;font-size:1.04rem;color:var(--blue);letter-spacing:-.02em;border-left:2px solid var(--line);padding-left:12px;line-height:1.1}
.brand-text b{color:var(--orange)}
.topbar nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.topbar nav a{position:relative;color:var(--ink);font-weight:600;font-size:.92rem;padding:9px 13px;border-radius:10px;transition:.18s}
.topbar nav a:not(.btn-accent):not(.btn-ghost)::after{content:"";position:absolute;left:13px;right:13px;bottom:5px;height:2px;border-radius:2px;background:var(--grad-mix);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.topbar nav a:not(.btn-accent):not(.btn-ghost):hover::after{transform:scaleX(1)}
.topbar nav a.admin-link{color:var(--orange)}
.who{color:var(--muted);font-size:.86rem;padding-left:8px}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--blue);cursor:pointer;padding:4px 8px}

/* ---------- Buttons ---------- */
.btn,.btn-accent,.btn-ghost{position:relative;display:inline-block;border:0;border-radius:12px;font-weight:700;cursor:pointer;font-size:.93rem;padding:11px 20px;transition:transform .16s,box-shadow .16s,background .16s;line-height:1.2;text-align:center;overflow:hidden}
.btn{background:var(--grad-brand);color:#fff;box-shadow:0 12px 24px -10px rgba(0,79,159,.65)}
.btn:hover{color:#fff;transform:translateY(-2px);box-shadow:0 18px 34px -10px rgba(0,79,159,.7)}
.btn-accent{background:var(--grad-accent);color:#fff;box-shadow:0 12px 26px -10px rgba(239,120,22,.6)}
.btn-accent:hover{color:#fff;transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(239,120,22,.7)}
.btn::after,.btn-accent::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg);transition:left .5s}
.btn:hover::after,.btn-accent:hover::after{left:120%}
.btn-ghost{background:#fff;border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn-ghost.danger{color:var(--danger);border-color:#f0cccc}
.btn-ghost.danger:hover{border-color:var(--danger);background:#fdf0f0;color:var(--danger)}
.btn.block,.btn-accent.block{width:100%;margin-top:8px}
.btn.big,.btn-accent.big,.btn-ghost.big{padding:15px 30px;font-size:1.04rem;border-radius:14px}
.btn.small,.btn-ghost.small,.btn-accent.small{padding:6px 13px;font-size:.82rem;border-radius:9px}
.topbar nav .btn-accent{padding:9px 17px}

/* ---------- Layout blocks ---------- */
main{padding:24px 0 56px;min-height:60vh}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;margin:16px 0;box-shadow:var(--shadow)}
.card.narrow{max-width:440px;margin:42px auto;animation:fadeUp .6s both}
.card h1{margin-bottom:.1em}
footer{padding:30px 0;text-align:center;color:var(--muted);border-top:1px solid var(--line);background:var(--card);font-size:.88rem}
footer b{color:var(--blue)}

.flash{background:linear-gradient(135deg,rgba(0,79,159,.07),rgba(10,114,214,.04));border:1px solid #bfd9f5;border-left:4px solid var(--blue);color:var(--blue-d);padding:13px 16px;border-radius:12px;margin:14px 0;font-weight:500;animation:fadeUp .5s both}
.error{background:#fdeaea;border:1px solid #f3c4c4;border-left:4px solid var(--danger);color:#a12626;padding:10px 14px;border-radius:11px;margin:9px 0}

/* ---------- Forms ---------- */
.form label{display:block;margin:13px 0;font-weight:600;font-size:.88rem}
.form input{display:block;width:100%;margin-top:6px;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font-size:1rem;font-family:inherit;background:#fbfcfe;transition:.16s}
.form input:focus{outline:0;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(0,79,159,.12)}
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-form input{padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;background:#fbfcfe}
.inline-form input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,79,159,.12)}

/* ---------- Hero: mascota + texto tipo banner ---------- */
.hero-top{display:grid;grid-template-columns:190px 1fr;gap:26px;align-items:center;text-align:left;margin-bottom:26px}
.hero-mascot{display:flex;justify-content:center}
.mascot-img{width:100%;max-width:190px;height:auto;filter:drop-shadow(0 14px 26px rgba(0,0,0,.4));animation:floatY 6s ease-in-out infinite}
.hero-copy{animation:fadeUp .6s .05s both;min-width:0}
.hero .hero-title{font-size:clamp(1.6rem,3.4vw,2.6rem);font-weight:800;line-height:1.06;letter-spacing:-.01em;text-transform:uppercase;margin:12px 0 0}
.hero .hero-title .hl{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-steps{list-style:none;counter-reset:step;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:9px}
.hero-steps li{counter-increment:step;position:relative;padding-left:38px;font-size:.96rem;color:rgba(255,255,255,.88);line-height:1.3;text-align:left}
.hero-steps li::before{content:counter(step);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:8px;background:var(--grad-accent);color:#fff;font-weight:800;font-size:.88rem;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 12px -4px rgba(239,120,22,.6)}
.hero-steps li b{color:#fff;font-weight:700}
.hero-note{font-size:.76rem;color:rgba(255,255,255,.5);margin:20px 0 0;font-style:italic}
@media(max-width:740px){
    .hero-top{grid-template-columns:1fr;gap:4px;text-align:center;margin-bottom:20px}
    .hero-mascot{order:-1}
    .mascot-img{max-width:140px}
    .hero .hero-title{margin-top:8px}
    .hero-steps{max-width:360px;margin-left:auto;margin-right:auto}
}
@media(max-width:580px){
    .mascot-img{max-width:120px}
    .hero .hero-title{font-size:1.45rem}
    .hero-steps{margin-top:16px;gap:8px}
    .hero-steps li{font-size:.9rem;padding-left:34px}
    .hero-steps li::before{width:24px;height:24px;font-size:.82rem}
    .hero-badge{margin-bottom:0}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;border-radius:30px;padding:62px 28px 52px;color:#fff;background:var(--navy);text-align:center;margin-top:12px;box-shadow:0 34px 70px -28px rgba(6,31,63,.7)}
.hero::before{content:"";position:absolute;inset:-30%;background:
    radial-gradient(34% 44% at 16% 12%,rgba(10,114,214,.9),transparent 60%),
    radial-gradient(30% 40% at 86% 4%,rgba(239,120,22,.6),transparent 55%),
    radial-gradient(44% 56% at 72% 108%,rgba(0,79,159,.95),transparent 60%);
    animation:heroFloat 14s ease-in-out infinite alternate}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:26px 26px;mask-image:linear-gradient(180deg,#000,transparent 80%)}
.hero-inner{position:relative;z-index:2}
.hero .orb{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:1}
.hero .orb-1{width:120px;height:120px;background:var(--grad-accent);top:18%;left:8%;animation:floatY 7s ease-in-out infinite}
.hero .orb-2{width:80px;height:80px;background:var(--grad-brand);bottom:16%;right:10%;animation:floatY 9s ease-in-out infinite reverse}
.hero-badge{display:inline-flex;gap:9px;align-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:8px 16px;border-radius:30px;font-size:.8rem;font-weight:600;margin-bottom:22px;animation:fadeUp .6s both}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#34e08a;animation:pulse 2s infinite}
.hero h1{font-size:clamp(2.2rem,5.4vw,3.7rem);line-height:1.05;letter-spacing:-.035em;animation:fadeUp .6s .05s both}
.hero h1 .hl{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:clamp(1rem,2vw,1.18rem);color:rgba(255,255,255,.82);max-width:620px;margin:18px auto 0;animation:fadeUp .6s .1s both}
.hero-cta{display:flex;gap:14px;justify-content:center;margin:30px 0 6px;flex-wrap:wrap;animation:fadeUp .6s .2s both}
.hero .btn-ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4);color:#fff}
.hero .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}

/* countdown */
.countdown-wrap{margin:30px auto 4px;animation:fadeUp .6s .15s both}
.cd-label{font-size:.82rem;letter-spacing:.02em;color:rgba(255,255,255,.85);margin-bottom:12px;font-weight:600}
.countdown{display:flex;gap:10px;justify-content:center}
.cd-box{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:15px;padding:12px 10px;min-width:70px}
@supports (backdrop-filter:blur(1px)){.cd-box{backdrop-filter:blur(8px)}}
.cd-box b{display:block;font-size:1.7rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
.cd-box span{font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;opacity:.75;margin-top:5px;display:block}

/* hero stats */
.stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:34px 0 4px}
.hero .stats{animation:fadeUp .6s .28s both}
.hero .stats>div{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);color:#fff}
@supports (backdrop-filter:blur(1px)){.hero .stats>div{backdrop-filter:blur(8px)}}
.stats>div{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 28px;text-align:center;min-width:130px;box-shadow:var(--shadow)}
.stats strong{display:block;font-size:1.9rem;font-weight:800;line-height:1}
.hero .stats strong{color:#fff}
main:not(.hero) .stats strong,.card .stats strong{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.stats span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:7px;display:block}
.hero .stats span{color:rgba(255,255,255,.75)}

/* ---------- How it works ---------- */
.how{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:22px}
.how .card{margin:0;text-align:center;transition:transform .2s,box-shadow .2s}
.how .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.how-ico{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.7rem;margin:0 auto 12px;background:linear-gradient(135deg,rgba(0,79,159,.12),rgba(239,120,22,.14));border:1px solid var(--line)}
.how h3{color:var(--blue)}

/* ---------- Page head ---------- */
.page-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:6px}
.score-pill{background:var(--grad-brand);color:#fff;padding:11px 22px;border-radius:30px;font-weight:600;box-shadow:0 12px 26px -10px rgba(0,79,159,.6)}
.score-pill strong{color:#fff;font-size:1.35rem;margin-left:6px;font-variant-numeric:tabular-nums}

/* ---------- Next match banner (logged-in) ---------- */
.next-match{position:relative;overflow:hidden;border-radius:22px;padding:22px 26px;margin:16px 0 22px;color:#fff;background:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;box-shadow:var(--shadow-lg)}
.next-match::before{content:"";position:absolute;inset:-40%;background:radial-gradient(40% 60% at 12% 10%,rgba(10,114,214,.9),transparent 60%),radial-gradient(40% 60% at 92% 90%,rgba(239,120,22,.55),transparent 60%);animation:heroFloat 14s ease-in-out infinite alternate}
.next-match>*{position:relative;z-index:2}
.nm-info .tagline{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.7);font-weight:700}
.nm-info .teams{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.nm-info .when{font-size:.85rem;color:rgba(255,255,255,.75);margin-top:2px}
.next-match .countdown .cd-box{min-width:60px;padding:9px 8px}
.next-match .countdown .cd-box b{font-size:1.4rem}

/* ---------- Referidos ---------- */
.card.referral{background:linear-gradient(135deg,#fff,rgba(239,120,22,.06));border-color:#f4d4b6}
.referral .ref-head h3{color:var(--orange-d);font-size:1.15rem}
.ref-link{display:flex;gap:10px;margin:14px 0;flex-wrap:wrap}
.ref-link input{flex:1;min-width:220px;padding:11px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.92rem;background:#fbfcfe;color:var(--ink)}
.ref-link input:focus{outline:0;border-color:var(--orange);box-shadow:0 0 0 4px rgba(239,120,22,.14)}
.ref-stats{display:flex;gap:22px;flex-wrap:wrap;font-size:.9rem;color:var(--muted)}
.ref-stats strong{color:var(--ink);font-size:1.1rem}
.ref-stats span:last-child strong{color:var(--orange-d)}

/* ---------- Reglas de puntuación ---------- */
.rules-title{margin-top:1.8em}
.rules{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.rule-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow);border-left:5px solid var(--line);transition:transform .18s,box-shadow .18s}
.rule-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.rule-card.rule-best{border-left-color:var(--orange)}
.rule-card.rule-good{border-left-color:var(--blue)}
.rule-card.rule-zero{border-left-color:var(--gray)}
.rule-pts{flex-shrink:0;width:62px;height:62px;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.7rem;font-weight:800;line-height:1;color:#fff}
.rule-best .rule-pts{background:var(--grad-accent)}
.rule-good .rule-pts{background:var(--grad-brand)}
.rule-zero .rule-pts{background:linear-gradient(135deg,#9aa3b2,#c2cad6)}
.rule-pts span{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;margin-top:3px;font-weight:700;opacity:.9}
.rule-body h4{margin:0 0 3px;font-size:1rem;font-weight:700}
.rule-body p{margin:0;font-size:.85rem;color:var(--muted);line-height:1.4}
.rule-body p b{color:var(--ink)}

/* Versión colapsable en el dashboard */
.rules-toggle{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);margin:14px 0;overflow:hidden}
.rules-toggle summary{cursor:pointer;padding:15px 18px;font-weight:700;list-style:none;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rules-toggle summary::-webkit-details-marker{display:none}
.rules-toggle summary::after{content:"▾";margin-left:auto;color:var(--muted);transition:transform .2s}
.rules-toggle[open] summary::after{transform:rotate(180deg)}
.rules-toggle summary span{font-weight:600;font-size:.82rem;color:var(--muted)}
.rules-toggle .rules{padding:0 16px 16px;margin-top:4px}
@media(max-width:760px){
    .rules{grid-template-columns:1fr}
}

/* ---------- Matches ---------- */
.matches{display:flex;flex-direction:column;gap:14px;margin-top:16px}
.match-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 20px;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s}
.match-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad-mix);opacity:0;transition:.2s}
.match-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#d3e2f5}
.match-card:hover::before{opacity:1}
.match-card.done::before{opacity:1;background:var(--grad-brand)}
.match-meta{display:flex;justify-content:space-between;font-size:.74rem;color:var(--muted);margin-bottom:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.match-row{display:grid;grid-template-columns:1fr auto 1fr auto;align-items:center;gap:14px}
.team{display:flex;align-items:center;gap:11px;font-weight:700;font-size:1.04rem}
.team.away{justify-content:flex-end;text-align:right;flex-direction:row-reverse}
.crest{width:30px;height:30px;object-fit:contain;background:#fff;border-radius:8px;padding:1px;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.inputs{display:flex;align-items:center;gap:8px}
.inputs input{width:52px;height:48px;padding:6px;text-align:center;border:1.5px solid var(--line);border-radius:12px;font-size:1.25rem;font-weight:800;font-family:inherit;background:#fbfcfe;transition:.15s}
.inputs input:focus{outline:0;border-color:var(--orange);background:#fff;box-shadow:0 0 0 4px rgba(239,120,22,.16)}
.inputs input:disabled{background:#eef1f6;color:var(--gray)}
.vs{font-weight:800;color:#fff;background:var(--gray);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem}
.lock{font-size:.8rem;color:var(--muted);font-weight:700}
.result-bar{margin-top:13px;padding-top:11px;border-top:1px dashed var(--line);font-size:.92rem;color:var(--muted)}
.result-bar strong{color:var(--ink)}
.pts{font-weight:800;margin-left:8px;padding:3px 11px;border-radius:20px;font-size:.84rem}
.pts.win{background:var(--grad-brand);color:#fff}
.pts.zero{background:#eef1f6;color:var(--gray)}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:14px;box-shadow:var(--shadow)}
.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
.table th{background:var(--grad-brand);color:#fff;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.table tr:last-child td{border-bottom:0}
.table tbody tr{transition:background .15s}
.table tbody tr:hover{background:rgba(0,79,159,.05)}
.table .num,.table td.num{text-align:right;font-variant-numeric:tabular-nums}
.table tr.me{background:rgba(239,120,22,.09)}
.table tr.me:hover{background:rgba(239,120,22,.13)}
.tag{background:var(--grad-accent);color:#fff;font-size:.66rem;padding:3px 9px;border-radius:10px;font-weight:700;vertical-align:middle}

/* ---------- Podium ---------- */
.podium{display:grid;grid-template-columns:1fr 1.18fr 1fr;gap:14px;align-items:end;margin:22px 0 8px}
.podium-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px 16px 20px;text-align:center;box-shadow:var(--shadow);transition:transform .2s}
.podium-card:hover{transform:translateY(-4px)}
.podium-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px}
.podium-card.p1{padding-top:34px;border-color:#ffe0a6;box-shadow:0 26px 46px -18px rgba(239,120,22,.45)}
.podium-card.p1::before{background:var(--grad-accent)}
.podium-card.p2::before{background:var(--grad-brand)}
.podium-card.p3::before{background:linear-gradient(135deg,#9aa3b2,#c2cad6)}
.podium-card .medal{font-size:2rem;line-height:1}
.pavatar{width:60px;height:60px;border-radius:18px;margin:10px auto 8px;background:linear-gradient(135deg,var(--blue),var(--orange));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.5rem;box-shadow:var(--shadow)}
.podium-card .pname{font-weight:800;letter-spacing:-.01em}
.podium-card .pmeta{font-size:.74rem;color:var(--muted);margin-top:2px}
.podium-card .ppts{font-size:1.9rem;font-weight:800;margin-top:8px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;font-variant-numeric:tabular-nums}
.podium-card .ppts small{font-size:.7rem;color:var(--muted);-webkit-text-fill-color:var(--muted);font-weight:700}

/* ---------- People grid ---------- */
.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px;margin-top:16px}
.person-card{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 17px;color:var(--ink);box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s}
.person-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#cfe0f5;color:var(--ink)}
.avatar{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--orange));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.25rem;flex-shrink:0;box-shadow:0 8px 18px -8px rgba(0,79,159,.5)}
.person-info{flex:1;display:flex;flex-direction:column;min-width:0}
.person-info strong{font-size:1.03rem}
.person-pts{font-weight:800;color:var(--blue);text-align:right;font-size:1.25rem;font-variant-numeric:tabular-nums}
.person-pts span{display:block;font-size:.66rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}

/* ---------- Admin ---------- */
.admin-stats>div{min-width:115px}
.result-form{display:flex;align-items:center;gap:6px}
.result-form input{width:48px;height:40px;text-align:center;border:1.5px solid var(--line);border-radius:10px;font-weight:800;font-family:inherit;background:#fbfcfe}
.result-form input:focus{outline:0;border-color:var(--orange);box-shadow:0 0 0 4px rgba(239,120,22,.16)}
.row-actions{display:flex;gap:7px}
.row-actions form{display:inline}
.admin-table td{vertical-align:middle}
.admin-table th{font-size:.72rem}

/* ---------- Animations ---------- */
@keyframes heroFloat{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(0,-18px,0) scale(1.05)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,224,138,.55)}70%{box-shadow:0 0 0 11px rgba(52,224,138,0)}100%{box-shadow:0 0 0 0 rgba(52,224,138,0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.rise{animation:fadeUp .55s both}

/* ---------- Tablas con scroll horizontal en móvil ---------- */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;border-radius:var(--r)}
.table-scroll .table{margin-top:0}
@media(max-width:720px){
    .table-scroll .table{min-width:560px}
}

/* ---------- Responsive ---------- */
@media(max-width:980px){
    .wrap{padding:0 16px}
    .hero h1{font-size:clamp(2rem,5vw,3rem)}
    .next-match{padding:18px 20px}
    .nm-info .teams{font-size:1.25rem}
}
@media(max-width:780px){
    .nav-toggle{display:block}
    .topbar nav{display:none;position:absolute;top:100%;right:0;left:0;flex-direction:column;align-items:stretch;background:#fff;border-bottom:1px solid var(--line);padding:10px 16px 16px;gap:3px;box-shadow:var(--shadow-lg)}
    .topbar nav.open{display:flex}
    .topbar nav a,.topbar nav .btn-accent,.topbar nav .btn-ghost{width:100%;text-align:left}
    .topbar nav a::after{display:none}
    .who{padding:7px 13px}
}
@media(max-width:580px){
    main{padding:16px 0 36px}
    .wrap{padding:0 16px}

    /* Topbar: mantenemos texto de marca para identidad PSI, más compacto */
    .topbar .wrap{padding:8px 14px}
    .brand{gap:9px}
    .brand .logo{height:34px}
    .brand-text{display:inline-block;font-size:.78rem;border-left-width:1px;padding-left:9px;line-height:1.05}
    .brand-text b{display:block}
    .nav-toggle{font-size:1.4rem;padding:4px 6px}

    /* Hero */
    .hero{padding:42px 18px 36px;border-radius:22px}
    .hero h1{font-size:1.75rem;letter-spacing:-.015em;line-height:1.1}
    .hero p{font-size:.95rem;margin-top:12px}
    .hero-cta{flex-direction:column;align-items:stretch;margin:22px 0 6px}
    .hero-cta .btn,.hero-cta .btn-accent,.hero-cta .btn-ghost{width:100%}
    .hero-badge{font-size:.72rem;padding:6px 13px}
    .stats{gap:10px;margin:22px 0 4px}
    .stats>div{min-width:0;padding:12px 14px;flex:1 1 calc(50% - 5px)}
    .stats strong{font-size:1.4rem}
    .stats span{font-size:.66rem}

    /* Page head: título, descripción y pill en una pieza ordenada */
    .page-head{gap:6px;margin-bottom:8px;align-items:flex-start}
    .page-head>div:first-child{flex:1 1 auto;min-width:0}
    .page-head h1{font-size:1.35rem;letter-spacing:-.01em;margin:0}
    .page-head p.muted{font-size:.85rem;margin-top:4px}
    .score-pill{padding:7px 14px;font-size:.78rem;align-self:flex-start;white-space:nowrap}
    .score-pill strong{font-size:1.05rem;margin-left:3px}
    h2{font-size:1.15rem;margin-top:1.4em}

    /* Cards generales */
    .card{padding:15px 16px;border-radius:14px;margin:12px 0}

    /* Match cards */
    .match-card{padding:12px 13px}
    .match-meta{font-size:.68rem;margin-bottom:8px}
    .match-row{grid-template-columns:1fr auto 1fr;gap:8px}
    .match-row .action{grid-column:1 / -1;text-align:center;margin-top:8px}
    .match-row .action .btn,.match-row .action .btn-accent{width:100%}
    .team{font-size:.88rem;gap:6px;overflow-wrap:anywhere}
    .crest{width:22px;height:22px}
    .inputs{gap:6px}
    .inputs input{width:44px;height:42px;font-size:1.05rem}
    .vs{width:22px;height:22px;font-size:.66rem}

    /* Próximo partido (banner) — apilado y compacto */
    .next-match{padding:16px 18px;border-radius:18px;gap:14px;flex-direction:column;align-items:stretch}
    .nm-info .tagline{font-size:.66rem;letter-spacing:.12em}
    .nm-info .teams{font-size:1.1rem;line-height:1.2;margin-top:3px}
    .nm-info .when{font-size:.76rem;margin-top:2px}
    .next-match .countdown{gap:6px;width:100%;justify-content:space-between}
    .next-match .cd-box{flex:1 1 0;min-width:0;padding:9px 4px;border-radius:11px}
    .next-match .cd-box b{font-size:1.25rem}
    .next-match .cd-box span{font-size:.55rem;margin-top:3px;letter-spacing:.08em}

    /* Countdown del hero (cuando se ve completo) */
    .countdown{gap:7px}
    .cd-box{min-width:0;flex:1 1 0;padding:9px 6px;border-radius:12px}
    .cd-box b{font-size:1.3rem}
    .cd-box span{font-size:.55rem}

    /* Podio */
    .podium{grid-template-columns:1fr;align-items:stretch;gap:10px}
    .podium-card{padding:18px 14px 16px}
    .podium-card.p1{padding-top:22px;transform:none}

    /* Tarjeta de invitación */
    .ref-link{flex-direction:column}
    .ref-link input,.ref-link .btn{width:100%}
    .ref-stats{gap:14px;font-size:.85rem}
    .referral .ref-head h3{font-size:1.02rem;line-height:1.3}

    /* Forms */
    .form input,.inline-form input,.ref-link input{font-size:16px} /* evita zoom auto en iOS */
    .inline-form{flex-direction:column;align-items:stretch}
    .inline-form input,.inline-form .btn{width:100%}
    .result-form input{width:42px;height:38px}
    .btn.small,.btn-ghost.small,.btn-accent.small{padding:8px 13px;font-size:.84rem}
    .row-actions{flex-direction:column;gap:5px}
    .row-actions form{display:block;width:100%}
    .row-actions .btn-ghost{width:100%}

    /* Personas */
    .people-grid{grid-template-columns:1fr}
    .person-card{padding:13px 14px}
}
@media(max-width:380px){
    .topbar .brand-text{display:none}
    .hero h1{font-size:1.55rem}
    .page-head h1{font-size:1.2rem}
    .next-match .cd-box b{font-size:1.1rem}
    .nm-info .teams{font-size:1rem}
    .stats>div{flex:1 1 100%}
}
@media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
}
