@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@500;600;700;800;900&display=swap";:root{--bg-app:#030303;--bg-card:#0a0a0c;--bg-sidebar:#060608;--bg-elevated:#111114;--border:#ffffff12;--border-hover:#ffffff24;--accent:#0070f3;--accent-soft:#0070f31f;--text:#f5f5f5;--text-muted:#e2e8f0;--text-dim:#cbd5e1;--success:#00e69d;--success-soft:#00e69d1a;--danger:#f36;--danger-soft:#ff33661a;--warning:#fa0;--warning-soft:#ffaa001a;--sidebar-w:240px;--radius:16px;--radius-sm:10px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-app);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,sans-serif}h1,h2,h3,.brand-name,.kpi-value,.team-name,.pred-winner,.modal-title{font-family:Outfit,sans-serif}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed}.sidebar-header{padding:2rem 1.25rem}.brand-name{letter-spacing:-.04em;background:linear-gradient(135deg,#0070f3,#a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:900;display:flex}.nav-container{flex:1;padding:0 .75rem;overflow-y:auto}.nav-section{margin-bottom:1.5rem}.nav-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem;padding:0 .75rem;font-size:.6rem;font-weight:800}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;align-items:center;gap:.75rem;margin-bottom:2px;padding:.7rem .75rem;font-size:.85rem;font-weight:600;transition:all .15s;display:flex}.nav-item:hover{color:var(--text);background:#ffffff0a}.nav-item.active{color:var(--text);border:1px solid var(--border);background:#ffffff12}.main-viewport{margin-left:var(--sidebar-w);flex-direction:column;flex:1;display:flex}.top-bar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50;background:#030303d9;justify-content:space-between;align-items:center;height:64px;padding:0 2.5rem;display:flex;position:sticky;top:0}.page-title{letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700}.top-bar-status{color:var(--success);align-items:center;gap:.5rem;font-size:.75rem;font-weight:700;display:flex}.status-dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.content-body{width:100%;max-width:1440px;margin:0 auto;padding:2.5rem}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:3rem;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;transition:border-color .2s}.kpi-card:hover{border-color:var(--border-hover)}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.7rem;font-weight:700}.kpi-value{letter-spacing:-.04em;font-size:2.25rem;font-weight:800}.kpi-total{color:var(--text-muted);font-size:1rem;font-weight:500}.kpi-sub{color:var(--text-dim);margin-top:.5rem;font-size:.75rem;font-weight:500}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-title{letter-spacing:-.02em;font-family:Outfit,sans-serif;font-size:1.35rem;font-weight:800}.loading-state,.empty-state{text-align:center;color:var(--text-muted);padding:5rem 2rem}.empty-icon{margin-bottom:1rem;font-size:3rem;display:block}.empty-state h3{color:var(--text);margin-bottom:.5rem;font-size:1.2rem}.empty-state p{max-width:400px;margin:0 auto;font-size:.9rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.match-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem;display:grid}.match-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;transition:all .25s;display:flex}.match-card:hover{border-color:var(--border-hover);transform:translateY(-3px)}.match-card-top{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.league-info{color:var(--text);align-items:center;gap:.6rem;font-size:.78rem;font-weight:700;display:flex}.flag-icon{object-fit:cover;border-radius:3px;width:22px;height:15px}.flag-icon-sm{object-fit:cover;border-radius:2px;width:18px;height:12px}.match-time{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:100px;padding:.35rem .65rem;font-size:.72rem;font-weight:700}.match-card-body{padding:1.5rem}.teams-display{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.team{text-align:center;flex:1}.team-name{letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.05rem;font-weight:800;display:block}.team-label{color:var(--text-dim);letter-spacing:.08em;font-size:.6rem;font-weight:800}.vs-badge{color:var(--text-dim);background:var(--bg-elevated);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-family:Outfit,sans-serif;font-size:.65rem;font-weight:900;display:flex}.prediction-section{border-top:1px solid var(--border);background:#ffffff04;padding:1.25rem}.prediction-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.pred-label{letter-spacing:.1em;color:var(--text-dim);font-size:.6rem;font-weight:800}.confidence-badge{color:var(--accent);background:var(--accent-soft);border:1px solid #0070f340;border-radius:100px;padding:.2rem .5rem;font-size:.65rem;font-weight:800}.pred-winner{margin-bottom:.4rem;font-size:1.15rem;font-weight:800}.pred-rationale{color:var(--text-muted);font-size:.8rem;font-style:italic;line-height:1.5}.match-card-actions{border-top:1px solid var(--border);gap:.75rem;padding:1rem 1.25rem;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);color:var(--text);text-align:center;background:0 0;flex:1;padding:.6rem .75rem;font-size:.78rem;font-weight:700;text-decoration:none;transition:all .15s}.btn:hover{border-color:var(--border-hover);background:#ffffff0f}.btn-primary{background:var(--text);color:var(--bg-app);border-color:var(--text)}.btn-primary:hover{background:#ffffffe0}.btn-ghost{background:0 0}.btn-sm{flex:none;padding:.4rem .7rem;font-size:.7rem}.history-feed{flex-direction:column;gap:2rem;display:flex}.history-day{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.history-day-header{border-bottom:1px solid var(--border);background:#ffffff04;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.history-day-title{font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.hit-rate-badge{border-radius:100px;padding:.3rem .7rem;font-size:.7rem;font-weight:800}.hit-rate-badge.good{background:var(--success-soft);color:var(--success);border:1px solid #00e69d33}.hit-rate-badge.mid{background:var(--warning-soft);color:var(--warning);border:1px solid #fa03}.hit-rate-badge.bad{background:var(--danger-soft);color:var(--danger);border:1px solid #f363}.history-matches{flex-direction:column;display:flex}.history-row{border-bottom:1px solid var(--border);grid-template-columns:160px 1fr 180px 140px 100px 80px;align-items:center;gap:1rem;padding:1rem 1.5rem;font-size:.85rem;transition:background .1s;display:grid}.history-row:last-child{border-bottom:none}.history-row:hover{background:#ffffff05}.history-row-league{align-items:center;gap:.5rem;display:flex}.history-league-name{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:600;overflow:hidden}.history-row-match{align-items:center;gap:.5rem;display:flex}.history-team{font-size:.85rem;font-weight:700}.history-score{color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);text-align:center;border-radius:6px;min-width:40px;padding:.2rem .5rem;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:900}.history-row-prediction,.history-row-result{align-items:center;gap:.4rem;display:flex}.history-pred-label,.history-actual-label{color:var(--text-dim);text-transform:uppercase;font-size:.65rem;font-weight:700}.history-pred-value{color:var(--accent);font-weight:700}.history-actual-value{font-weight:700}.history-confidence{color:var(--text-dim);font-size:.65rem}.status-badge{text-align:center;white-space:nowrap;border-radius:100px;padding:.25rem .55rem;font-size:.68rem;font-weight:800}.status-badge.correct{background:var(--success-soft);color:var(--success)}.status-badge.incorrect{background:var(--danger-soft);color:var(--danger)}.status-badge.postponed{background:var(--warning-soft);color:var(--warning)}.history-row-status{text-align:center}.kpi-inline{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.kpi-inline-label{color:var(--text-muted);font-weight:600}.kpi-inline-value{font-weight:800}.kpi-inline-sep{color:var(--text-dim)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000e0;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;width:95%;max-width:740px;max-height:85vh;padding:3rem;animation:.35s cubic-bezier(.16,1,.3,1) slideUp;position:relative;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-close{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close:hover{background:#ffffff1a;transform:rotate(90deg)}.modal-header{text-align:center;margin-bottom:2.5rem}.modal-league{color:var(--text-muted);justify-content:center;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.8rem;font-weight:700;display:flex}.modal-title{letter-spacing:-.04em;margin-bottom:.75rem;font-size:1.75rem;font-weight:900}.modal-meta{color:var(--text-muted);justify-content:center;gap:1.5rem;margin-bottom:1rem;font-size:.85rem;font-weight:600;display:flex}.modal-score{color:var(--text);font-weight:800}.modal-prediction{justify-content:center;align-items:center;gap:.75rem;font-size:1rem;font-weight:600;display:flex}.modal-prediction strong{font-weight:900}.modal-body{color:#bbb;white-space:pre-wrap;font-size:1rem;line-height:1.8}@media (width<=1024px){.sidebar{width:72px}.brand-name span,.nav-label,.nav-item span:last-child{display:none}.main-viewport{margin-left:72px}.content-body{padding:1.5rem}.history-row{grid-template-columns:1fr;gap:.5rem;padding:1rem}}@media (width<=768px){.match-grid,.kpi-grid{grid-template-columns:1fr}.top-bar{padding:0 1rem}.modal-content{border-radius:20px;padding:1.5rem}.history-row{font-size:.8rem}}.leaderboard-section{margin-bottom:2.5rem}.section-subtitle{color:var(--text-dim);margin-top:.25rem;font-size:.8rem}.leaderboard-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.leaderboard-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:1rem;display:flex}.leaderboard-item .league-info{align-items:center;gap:.75rem;display:flex}.league-name-text{white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:.85rem;font-weight:600;overflow:hidden}.league-stats-row{flex-direction:column;align-items:flex-end;display:flex}.league-rate{color:var(--success);font-family:Outfit,sans-serif;font-size:1rem;font-weight:800}.league-count{color:var(--text-dim);font-size:.65rem;font-weight:600}
