:root{color:#172033;background:#f6f8fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}a{color:inherit}.app-shell{color:#172033;background:#f6f8fb;grid-template-columns:240px minmax(0,1fr);min-height:100vh;display:grid}.nav-rail{color:#f8fafc;background:#132238;flex-direction:column;gap:18px;padding:20px 14px;display:flex}.brand-mark{object-fit:cover;background:#fff;border:1px solid #ffffff47;border-radius:8px;width:44px;height:44px}.brand-mark.large{width:58px;height:58px;margin:0 auto}.nav-rail nav{gap:6px;display:grid}.nav-rail button,.logout{min-height:42px;color:inherit;cursor:pointer;font:inherit;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:0 12px;display:flex}.nav-rail button.active,.nav-rail button:hover,.logout:hover{background:#ffffff1f}.logout{margin-top:auto}.workspace{padding:28px;overflow-x:hidden}.topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;display:flex}.topbar h1,.login-panel h1,.panel h2,.profile-card h2{margin:0}.eyebrow{color:#64748b;text-transform:uppercase;margin:0 0 6px;font-size:.82rem}.signed-in{color:#475569;align-items:center;gap:8px;min-width:0;display:flex}.signed-in span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.badge{color:#075985;background:#e0f2fe;border-radius:999px;padding:4px 9px;font-size:.78rem}.match-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.match-status{border-radius:999px;padding:4px 9px;font-size:.78rem;font-weight:800}.match-status.live{color:#047857;background:#dcfce7}.match-status.final{color:#475569;background:#f1f5f9}.match-status.attention{color:#c2410c;background:#fff7ed}.notice,.panel,.profile-card,.details-list,.metric,.picture-panel,.password-panel,.login-panel{background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 1px 2px #0f172a0d}.notice{color:#075985;margin-bottom:16px;padding:12px 14px}.current-layout{grid-template-columns:minmax(320px,.9fr) minmax(420px,1.4fr);align-items:start;gap:18px;display:grid}.standings-column{gap:14px;min-width:0;display:grid}.panel{padding:18px}table{border-collapse:collapse;width:100%;font-size:.92rem}th,td{text-align:left;border-bottom:1px solid #e2e8f0;padding:10px 8px}th{color:#64748b;font-weight:700}.rank-change{align-items:center;gap:3px;min-width:42px;font-weight:800;display:inline-flex}.rank-change.up{color:#047857}.rank-change.down{color:#be123c}.rank-change.same{color:#64748b}.movement-panel{overflow:hidden}.movement-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.movement-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.movement-actions button{color:#172033;cursor:pointer;min-height:30px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:0 9px;font-size:.78rem;font-weight:800}.movement-actions button:hover{color:#065f56;border-color:#18a999}.player-toggles{flex-wrap:wrap;gap:6px;margin:10px 0;display:flex}.player-toggles label{border:1px solid #dbe3ef;border-left:3px solid var(--player-color);color:#172033;cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:5px;min-height:28px;padding:0 8px;font-size:.76rem;font-weight:700;display:inline-flex}.player-toggles input{accent-color:var(--player-color)}.movement-chart{width:100%;min-height:220px;display:block}.movement-chart line{stroke:#e2e8f0;stroke-width:.75px}.movement-chart .axis{stroke:#94a3b8;stroke-width:1px}.movement-chart text{fill:#64748b;font-size:8px;font-weight:700}.movement-chart .game-day-label{text-anchor:middle}.player-series polyline{fill:none;stroke:var(--series-color);stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.player-series circle{r:1.5px;fill:#fff;stroke:var(--series-color);stroke-width:.8px}.match-list,.stack,.prediction-grid,.profile-grid{gap:14px;display:grid}.match-row{border:1px solid #e2e8f0;border-radius:8px;padding:14px}.match-main{justify-content:space-between;gap:14px;display:flex}.match-main h3{flex-wrap:wrap;align-items:center;gap:6px;margin:8px 0 4px;display:flex}.match-main p{color:#64748b;margin:0}.score-box{color:#fff;background:#132238;border-radius:8px;place-items:center;min-width:82px;height:48px;font-weight:800;display:grid}.score-box.live{background:#047857}.score-box.final{background:#0f172a}.prediction-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-top:12px}.lock-timer{color:#075985;align-items:center;gap:7px;margin-top:12px;font-size:.88rem;font-weight:700;display:flex}.lock-timer.closed{color:#9f1239}.prediction-editor{background:#fff;border:1px solid #dbe3ef;border-radius:8px;grid-template-columns:repeat(2,minmax(110px,1fr)) minmax(130px,.9fr) auto;align-items:end;gap:10px;margin-top:12px;padding:12px;display:grid}.prediction-editor label{color:#475569;gap:5px;font-size:.82rem;font-weight:700;display:grid}.prediction-editor .team-label{max-width:100%}.prediction-editor input,.prediction-editor select{color:#172033;min-height:38px;font:inherit;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:0 10px}.prediction-editor input:disabled,.prediction-editor select:disabled{color:#64748b;background:#f1f5f9}.prediction-editor button{color:#07141f;cursor:pointer;min-height:38px;font:inherit;background:#18a999;border:0;border-radius:8px;padding:0 14px;font-weight:800}.prediction-editor button:disabled{color:#64748b;cursor:not-allowed;background:#cbd5e1}.prediction-error{color:#9f1239;grid-column:1/-1;font-size:.86rem}.prediction-pill{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;min-height:40px;padding:8px 10px;display:flex}.prediction-pill .player-label{min-width:0}.prediction-pill em{color:#047857;font-size:.8rem;font-style:normal}.profile-grid{grid-template-columns:minmax(280px,380px) minmax(320px,1fr)}.profile-card{align-items:center;gap:16px;padding:20px;display:flex}.profile-card img{flex:none}.profile-card p,.details-list dd{color:#64748b;margin:4px 0 0}.details-list{gap:14px;margin:0;padding:18px;display:grid}.details-list dt{font-weight:700}.picture-panel,.password-panel{gap:12px;padding:18px;display:grid}.picture-panel h2,.password-panel h2{margin:0}.picture-panel label:not(.file-picker-button),.password-panel label{gap:6px;font-weight:700;display:grid}.picture-panel input:not([type=file]),.password-panel input{min-height:40px;font:inherit;border:1px solid #cbd5e1;border-radius:8px;padding:0 10px}.picture-panel button,.password-panel button{color:#fff;cursor:pointer;font:inherit;background:#132238;border:0;border-radius:8px;justify-self:start;padding:10px 14px;font-weight:800}.picture-panel button{align-items:center;gap:7px;display:inline-flex}.picture-panel button:disabled,.password-panel button:disabled{color:#64748b;cursor:not-allowed;background:#cbd5e1}.file-picker-row{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;display:grid}.file-picker-button{color:#fff;cursor:pointer;background:#132238;border:1px solid #132238;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-weight:800;display:inline-flex}.file-picker-button:hover{background:#223550}.file-picker-button input{opacity:0;pointer-events:none;block-size:1px;inline-size:1px;position:absolute}.file-status{color:#64748b;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;align-items:center;gap:8px;min-width:0;min-height:40px;padding:0 12px;display:flex}.file-status.ready{color:#065f56;background:#e7f8f5;border-color:#18a999;font-weight:800}.file-status span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.player-label{vertical-align:middle;align-items:center;gap:8px;min-width:0;max-width:100%;display:inline-flex}.player-label span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.team-label{vertical-align:middle;align-items:center;gap:7px;min-width:0;max-width:100%;display:inline-flex}.team-label span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flag-icon{object-fit:cover;background:#fff;border:1px solid #cbd5e1;border-radius:3px;flex:none;width:22px;height:16px}.versus{color:#64748b;font-size:.82em;font-weight:700}.compact-match-line{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.avatar{color:#172033;object-fit:cover;text-transform:uppercase;background:#e8eef5;border:1px solid #cbd5e1;border-radius:8px;flex:none;place-items:center;font-weight:800;display:inline-grid}.avatar.small{width:30px;height:30px;font-size:.72rem}.avatar.large{width:72px;height:72px;font-size:1.35rem}.player-buttons,.previous-grid{flex-wrap:wrap;gap:10px;display:flex}.player-buttons button,.previous-grid button,.login-panel button{color:#fff;cursor:pointer;background:#132238;border:0;border-radius:8px;padding:10px 14px}.player-buttons button.selected{color:#07141f;background:#18a999}.player-buttons button{align-items:center;max-width:100%;display:inline-flex}.metric{gap:8px;padding:18px;display:grid}.metric svg{color:#18a999}.metric strong{font-size:1.4rem}.empty-state{text-align:center;place-content:center;min-height:260px;display:grid}.login-page{background:#f6f8fb;place-items:center;min-height:100vh;display:grid}.login-panel{gap:16px;width:min(420px,100vw - 32px);padding:28px;display:grid}.login-panel h1{text-align:center}.login-panel label{gap:6px;font-weight:700;display:grid}.login-panel input{min-height:40px;font:inherit;border:1px solid #cbd5e1;border-radius:8px;padding:0 10px}.form-message{color:#64748b;margin:0}@media (width<=920px){.app-shell,.current-layout,.profile-grid,.password-panel{grid-template-columns:1fr}.nav-rail{z-index:2;flex-direction:row;align-items:center;position:sticky;top:0;overflow-x:auto}.nav-rail nav{display:flex}.logout{margin-top:0;margin-left:auto}.workspace{padding:18px}.topbar,.match-main{flex-direction:column}.prediction-editor,.file-picker-row{grid-template-columns:1fr}}
