:root{
  --bg:#071c17; --bg2:#09261f; --panel:#102d26; --panel2:#f5f4ed; --ink:#071c17;
  --text:#edf3e9; --muted:#a5b9ae; --green:#32d17d; --green-dark:#0d9452;
  --gold:#f0c95b; --red:#e85252; --border:rgba(255,255,255,.09); --shadow:0 18px 50px rgba(0,0,0,.18);
}
*{box-sizing:border-box}
body{margin:0;background:#f2f1e9;color:var(--ink);font-family:Inter,Arial,sans-serif}
button,input,select{font:inherit}
button{cursor:pointer;border:0}
.shell{min-height:100vh;display:flex}
.sidebar{width:274px;min-height:100vh;background:var(--bg);color:var(--text);padding:28px 18px 18px;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:15px;padding:4px 10px 42px}
.ball{font-size:35px;filter:drop-shadow(0 4px 10px rgba(48,209,125,.32))}
.eyebrow{font-size:11px;letter-spacing:.19em;font-weight:800;color:var(--green);display:block;margin-bottom:5px}
.brand h1{font-family:"Bebas Neue",Impact,sans-serif;letter-spacing:.045em;font-size:35px;line-height:.91;margin:0;color:#fff}
.nav{display:flex;flex-direction:column;gap:10px}
.nav-item{height:55px;display:flex;align-items:center;gap:17px;padding:0 18px;border-radius:13px;background:transparent;color:#b7c8be;font-weight:600;text-align:left;transition:.16s}
.nav-item span{font-size:20px;width:23px}
.nav-item:hover,.nav-item.active{background:var(--green);color:#062217}
.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding:19px 10px 5px;display:flex;align-items:center;gap:12px}
.sidebar-footer small{display:block;color:#8ca79c;font-size:11px;margin-bottom:3px}
.avatar{height:42px;width:42px;display:grid;place-items:center;border-radius:50%;background:#153c32;color:var(--green);font-weight:800}
.close-menu{display:none}
.main{margin-left:274px;flex:1;min-height:100vh}
.topbar{height:88px;background:white;border-bottom:1px solid #e7e4dc;padding:0 38px;display:flex;align-items:center;justify-content:space-between;gap:20px;position:sticky;top:0;z-index:10}
.topbar h2{margin:0;font-size:23px}
.green{color:var(--green-dark)}
.top-actions{display:flex;align-items:center;gap:18px}
.ghost{background:transparent;color:#69736d;font-size:14px}
.pill{padding:12px 18px;border-radius:25px;background:#e8faf1;color:#04834c;font-weight:700}
.hamburger{display:none;font-size:26px;background:transparent}
.view{display:none;padding:31px 40px 48px}
.view.active{display:block}
.hero{background:linear-gradient(120deg,#0a2720,#163e32);min-height:235px;border-radius:19px;color:white;padding:38px 39px;display:flex;justify-content:space-between;align-items:center;overflow:hidden;position:relative}
.hero:after{content:"⚽";position:absolute;right:200px;bottom:-70px;font-size:210px;opacity:.05;transform:rotate(-12deg)}
.hero h3{font-family:"Bebas Neue",Impact,sans-serif;font-size:54px;line-height:.96;letter-spacing:.04em;margin:8px 0 13px}
.hero p{margin:0;color:#bbd0c5;max-width:470px;font-size:14px}
.countdown{background:rgba(255,255,255,.075);border:1px solid var(--border);border-radius:15px;padding:22px 25px;width:340px;position:relative;z-index:1}
.countdown-title{text-align:center;color:#9db5aa;font-size:12px;font-weight:700;letter-spacing:.12em;margin-bottom:17px}
.clock{display:flex;justify-content:center;gap:14px}
.clock div{text-align:center}
.clock b{background:rgba(3,16,13,.35);font-size:28px;display:grid;place-items:center;height:55px;min-width:57px;border-radius:8px}
.clock small{font-size:10px;color:#9db5aa;display:block;margin-top:8px;letter-spacing:.11em}
.colon{font-size:24px;margin-top:13px;color:#a7bdb2}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:21px;margin-top:25px}
.card{background:white;border:1px solid #e7e3da;border-radius:16px;padding:25px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.card h3{font-size:18px;margin:0 0 20px}
.next-match{display:flex;align-items:center;justify-content:space-between;gap:12px}
.team{display:flex;flex-direction:column;align-items:center;gap:7px;font-weight:700;font-size:13px;width:130px;text-align:center}
.flag{font-size:38px}
.vs{text-align:center}
.vs b{font-family:"Bebas Neue";font-size:29px;display:block}
.vs small{color:#6b756f;font-size:11px}
.match-meta{text-align:center;color:#66716a;font-size:13px;margin-top:24px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:17px}
.stat{background:#f8f7f2;border-radius:12px;padding:22px 18px}
.stat b{font-size:29px;display:block;margin-bottom:4px}
.stat small{color:#68736d;font-size:12px}
.stat.green-stat b{color:#079453}
.progress-wrap{margin-top:24px}
.progress-head{display:flex;justify-content:space-between;font-size:13px;margin-bottom:10px;color:#59645f}
.progress{height:8px;border-radius:8px;background:#e3e3dc;overflow:hidden}
.progress span{display:block;height:100%;background:var(--green);border-radius:inherit}
.table-banner{min-height:190px;border-radius:18px;padding:29px 31px;margin-bottom:25px;color:white;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.table-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(7,28,23,.96),rgba(7,28,23,.72) 56%,rgba(7,28,23,.36));z-index:0}
.table-banner:after{content:"";position:absolute;right:-38px;top:-72px;width:250px;height:250px;border:28px solid rgba(255,255,255,.08);border-radius:50%;z-index:0}
.table-banner--predictions{background:linear-gradient(135deg,#07362a,#0f6b47 48%,#d73434)}
.table-banner--schedule{background:linear-gradient(135deg,#061c2f,#1461a8 48%,#f0c95b)}
.banner-copy,.banner-scoreboard,.banner-fixture{position:relative;z-index:1}
.banner-copy h3{font-family:"Bebas Neue",Impact,sans-serif;font-size:47px;line-height:.96;letter-spacing:.04em;margin:6px 0 10px}
.banner-copy p{margin:0;color:#d5e5dc;max-width:520px;font-size:14px;line-height:1.5}
.banner-scoreboard{display:grid;grid-template-columns:repeat(3,95px);gap:9px}
.banner-scoreboard div{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:15px 11px;text-align:center;backdrop-filter:blur(6px)}
.banner-scoreboard b{display:block;font-size:25px;color:#fff;margin-bottom:3px}
.banner-scoreboard span{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#c9d9d0;font-weight:800}
.banner-fixture{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:17px;justify-self:start;background:rgba(3,16,13,.3);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:9px 16px;font-weight:800}
.banner-fixture strong{font-family:"Bebas Neue";font-size:25px;color:var(--gold);letter-spacing:.06em}
.section-heading{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:22px}
.section-heading h3{margin:0;font-size:27px}
.section-heading p{margin:6px 0 0;color:#6a756e;font-size:14px}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.chip{background:white;border:1px solid #ddd9d1;padding:10px 16px;border-radius:25px;color:#52615b;font-size:13px}
.chip.active{background:var(--bg);color:white;border-color:var(--bg)}
.matches{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:15px}
.match-card{background:white;border-radius:15px;border:1px solid #e5e0d6;padding:17px 17px 14px}
.match-card header{display:flex;justify-content:space-between;color:#69746c;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:15px}
.locked{color:var(--red)!important}
.fixture-team{display:flex;align-items:center;justify-content:space-between;margin:10px 0;font-weight:600}
.fixture-team input{width:48px;height:39px;border:1px solid #ddd7cb;border-radius:9px;text-align:center;font-weight:700;font-size:17px}
.fixture-team select{max-width:190px;height:39px;border:1px solid #ddd7cb;border-radius:9px;background:#fff;padding:0 10px;font-weight:700;color:#26362f}
.fixture-team input:focus,input:focus,.fixture-team select:focus,select:focus{outline:2px solid var(--green);border-color:transparent}
.fixture-meta{font-size:12px;color:#68736d;border-top:1px solid #eeeae2;padding-top:12px;margin-top:13px;display:flex;justify-content:space-between}
.empty{padding:45px;text-align:center;color:#65726b;background:white;border-radius:15px;border:1px dashed #dad4c8}
.table-card{background:white;border-radius:16px;border:1px solid #e5e0d6;overflow:hidden}
.ranking-table{width:100%;border-collapse:collapse}
.ranking-table th{text-align:left;background:#faf9f5;color:#79827d;text-transform:uppercase;letter-spacing:.08em;font-size:11px;padding:18px}
.ranking-table td{padding:17px 18px;border-top:1px solid #eee9df;font-size:14px}
.calendar-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:20px}
.calendar-summary div{background:white;border:1px solid #e5e0d6;border-radius:13px;padding:18px 17px}
.calendar-summary b{display:block;font-size:22px;margin-bottom:4px}
.calendar-summary span{color:#68736d;font-size:12px}
.calendar-card{overflow:auto}
.calendar-table{width:100%;border-collapse:collapse;min-width:780px}
.calendar-table th{text-align:left;background:#faf9f5;color:#79827d;text-transform:uppercase;letter-spacing:.08em;font-size:11px;padding:16px}
.calendar-table td{padding:15px 16px;border-top:1px solid #eee9df;font-size:14px;vertical-align:middle}
.calendar-match{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;font-weight:700}
.calendar-match b{font-family:"Bebas Neue";font-size:18px;color:#69736d;letter-spacing:.04em}
.place{font-weight:800;font-size:16px}
.medal{font-size:19px;margin-right:8px}
.points{font-weight:800;color:#079453;font-size:18px}
.rule-layout{display:grid;grid-template-columns:1fr 350px;gap:21px}
.scoring{display:grid;gap:11px}
.score-row{display:flex;justify-content:space-between;align-items:center;background:#f8f7f2;padding:16px 18px;border-radius:10px}
.score-tag{background:#dff7ea;color:#06854a;padding:7px 10px;border-radius:20px;font-weight:800}
.notice{background:#fff7dc;border:1px solid #f1d67d;border-radius:14px;padding:17px;margin-top:18px;color:#6e5b20;font-size:13px;line-height:1.55}
.admin-login{max-width:420px;margin:55px auto;background:#fff;border-radius:17px;padding:32px;border:1px solid #e5dfd3;text-align:center}
.admin-login input,.modal input{width:100%;height:49px;border:1px solid #d8d2c6;border-radius:10px;padding:0 14px;margin:15px 0}
.primary{background:var(--green);color:#062217;font-weight:800;padding:13px 19px;border-radius:10px}
.primary:disabled{opacity:.52;cursor:not-allowed}
.full{width:100%}
.submit-pred{margin-top:14px}
.admin-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.admin-match .fixture-team input{background:#f8f7f2}
.special-card{margin-bottom:20px}
.user-approval-list{display:grid;gap:10px;margin-top:14px}
.user-approval-row{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#f8f7f2;border:1px solid #eee9df;border-radius:10px;padding:12px 14px}
.user-approval-row strong{display:block}
.user-approval-row span{display:block;color:#68736d;font-size:12px;margin-top:3px}
.compact-empty{padding:18px}
.toggle{display:flex;gap:7px;align-items:center;color:#61706a;font-size:12px;margin-top:12px}
.toggle input{accent-color:var(--green);height:17px;width:17px}
.modal-backdrop{position:fixed;inset:0;background:rgba(3,15,12,.72);z-index:60;display:grid;place-items:center;padding:18px}
.modal{width:min(395px,100%);background:white;border-radius:20px;padding:32px;text-align:center;box-shadow:var(--shadow);position:relative}
.modal-close{position:absolute;right:14px;top:12px;width:34px;height:34px;border-radius:50%;background:#f3f1eb;color:#5d675f;font-size:22px;line-height:1}
.modal-close:hover{background:#e7e3da;color:#071c17}
.modal-ball{font-size:46px;margin-bottom:9px}
.modal h2{margin:0 0 9px}
.modal p{color:#67736d;line-height:1.45;font-size:14px}
.modal label{font-size:12px;font-weight:700;display:block;text-align:left;margin-top:22px}
.mini{font-size:11px!important;margin:18px 0 0!important}
.auth-toggle{margin-top:10px}
.hidden{display:none!important}
.toast{position:fixed;bottom:25px;right:25px;background:var(--bg);color:white;padding:14px 18px;border-radius:11px;z-index:100;box-shadow:var(--shadow);font-size:14px}
.special-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:25px}
.special-form label{font-size:12px;color:#68736d;font-weight:600}
.special-form input{width:100%;height:43px;padding:0 12px;margin-top:7px;border-radius:9px;border:1px solid #ded8cc}
/* ── Compartir ── */
.share-btn{background:#e8faf1;color:#04834c;border:1px solid #b7e9cf;font-weight:700;padding:11px 17px;border-radius:10px;font-size:13px;cursor:pointer;transition:.15s}
.share-btn:hover{background:#d1f5e4}
.admin-tools{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.admin-bar .admin-tools{margin-bottom:0;justify-content:flex-end}

/* ── Errores / importar ── */
.auth-error{background:#fee2e2;color:#b91c1c;border-radius:9px;padding:10px 14px;font-size:13px;margin:10px 0;text-align:left}
.modal label{display:block;text-align:left;font-size:12px;font-weight:700;margin-top:16px}
.modal label input{margin-top:6px}

/* ── Ranking ── */
.me-tag{background:var(--green);color:#062217;font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;margin-left:6px;vertical-align:middle}
.my-row td{background:#f0fdf6}
.earned-pts{color:#079453;font-weight:800}

/* ── Sidebar footer ── */
.sidebar-user{flex:1;min-width:0;overflow:hidden}
.sidebar-user strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ghost-sm{background:rgba(255,255,255,.08);color:#8ca79c;border-radius:8px;padding:6px 9px;font-size:15px;flex-shrink:0;transition:.15s}
.ghost-sm:hover{background:rgba(255,255,255,.18);color:white}

@media(max-width:1020px){
 .sidebar{transform:translateX(-100%);transition:transform .22s}.sidebar.open{transform:none}
 .close-menu{display:block;position:absolute;right:16px;top:13px;background:transparent;color:white;font-size:27px}
 .main{margin-left:0}.hamburger{display:block}.topbar{justify-content:flex-start}.top-actions{margin-left:auto}
 .view{padding:25px 20px}.hero{display:block}.countdown{margin-top:25px;width:100%}.grid,.rule-layout{grid-template-columns:1fr}
 .table-banner{grid-template-columns:1fr}.banner-scoreboard{grid-template-columns:repeat(3,1fr)}.calendar-summary{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:650px){
 .topbar{height:80px;padding:0 16px;gap:13px}.topbar h2{font-size:19px}.top-actions{gap:8px}.ghost:not(.auth-toggle){font-size:12px}.pill{padding:10px 12px;font-size:13px}
 .auth-toggle{display:block}
 .hero{padding:28px 22px;min-height:0}.hero h3{font-size:44px}.clock b{font-size:24px;min-width:48px}
 .stats{gap:8px}.stat{padding:15px 10px}.stat b{font-size:24px}.matches{grid-template-columns:1fr}
 .section-heading{align-items:flex-start;flex-direction:column}.special-form{grid-template-columns:1fr}
 .table-banner{padding:24px 20px;border-radius:15px}.banner-copy h3{font-size:39px}.banner-scoreboard{gap:7px}.banner-scoreboard div{padding:12px 7px}.banner-scoreboard b{font-size:20px}.banner-scoreboard span{font-size:9px}
 .banner-fixture{width:100%;justify-content:space-between}.calendar-summary{grid-template-columns:1fr}.calendar-summary div{padding:15px}
}
