:root{color:#e6edf3;font-synthesis:none;text-rendering:optimizelegibility;background:#08111f;font-family:Inter,Noto Sans SC,PingFang SC,Microsoft YaHei,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 18% 8%,#22c55e26,#0000 28%),radial-gradient(circle at 82% 0,#0ea5e921,#0000 30%),linear-gradient(135deg,#07101c 0%,#0b1220 44%,#111827 100%);min-width:320px;min-height:100vh;margin:0;overflow:hidden}button,input,select{font:inherit}button{color:inherit}.app-shell{flex-direction:column;width:min(1440px,100% - 40px);min-height:100vh;max-height:100vh;margin:0 auto;padding:18px 0;display:flex}.auth-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:#09101de6;border:1px solid #94a3b833;border-radius:8px;width:min(440px,100%);padding:22px;box-shadow:0 18px 50px #00000052,inset 0 1px #ffffff0a}.auth-brand{align-items:flex-start;gap:12px;display:flex}.auth-brand svg{color:#7dd3fc;margin-top:4px}.auth-brand h1{color:#f8fafc;margin:0;font-size:28px;line-height:1.1}.auth-copy{color:#a7b5c8;margin:14px 0;font-size:13px;line-height:1.55}.auth-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px;display:grid}.auth-tabs button,.auth-submit,.user-chip button{color:#dbeafe;cursor:pointer;background:#0ea5e91f;border:1px solid #7dd3fc57;border-radius:8px;min-height:40px;padding:8px 10px;font-weight:850}.auth-tabs button.active,.auth-submit{color:#bbf7d0;background:#22c55e29;border-color:#22c55e6b}.auth-submit:disabled{cursor:wait;opacity:.64}.auth-form{gap:10px;display:grid}.auth-form label{gap:5px;display:grid}.auth-form span{color:#93a4ba;font-size:12px;font-weight:800}.auth-form input{color:#f8fafc;background:#0206179e;border:1px solid #94a3b833;border-radius:8px;outline:none;min-height:42px;padding:0 11px}.auth-message,.verification-link,.user-chip{color:#bfdbfe;background:#0ea5e91a;border:1px solid #7dd3fc42;border-radius:8px;align-items:center;gap:8px;margin-top:12px;padding:10px;font-size:13px;display:flex}.verification-link{text-decoration:none}.user-chip{min-width:0;margin-top:0;padding:6px 8px}.user-chip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.user-chip button{min-height:32px;padding:5px 8px}.topbar,.section-heading,.match-meta,.match-footer,.probability-labels,.detail-footer,.factor-row,.score-row,.filter-row,.section-title-row,.match-submeta,.data-info,.card-insight{justify-content:space-between;align-items:center;gap:12px;display:flex}.topbar{flex:none;margin-bottom:12px}.topbar h1,.section-heading h2{letter-spacing:0;margin:0}.topbar h1{color:#f8fafc;font-size:32px;line-height:1.08}.section-heading h2{color:#f8fafc;font-size:20px}.eyebrow{color:#8ba4c4;letter-spacing:.08em;text-transform:uppercase;margin:0 0 5px;font-size:12px;font-weight:800}.topbar-status,.date-pill,.model-pill,.notice{color:#cbd5e1;background:#0f172ac7;border:1px solid #94a3b838;border-radius:8px;align-items:center;gap:8px;padding:8px 11px;font-size:13px;display:inline-flex;box-shadow:inset 0 1px #ffffff0a}.topbar-status{color:#bbf7d0;border-color:#22c55e57}.notice{color:#fde68a;background:#78350f38;border-color:#fbbf2461;flex:none;justify-content:flex-start;width:100%;margin-bottom:12px}.layout-grid{flex:auto;grid-template-columns:minmax(360px,.72fr) minmax(680px,1.28fr);align-items:stretch;gap:14px;min-height:0;display:grid}.match-list-section,.detail-panel{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#09101ddb;border:1px solid #94a3b82e;border-radius:8px;flex-direction:column;height:100%;min-height:0;display:flex;box-shadow:0 18px 50px #00000052,inset 0 1px #ffffff0a}.match-list-section{padding:14px;overflow:hidden}.filter-panel{background:#0f172a94;border:1px solid #94a3b824;border-radius:8px;flex:none;gap:10px;margin-top:12px;padding:10px;display:grid}.search-field{color:#94a3b8;background:#0206178f;border:1px solid #94a3b82e;border-radius:8px;align-items:center;gap:8px;min-height:42px;padding:0 11px;display:flex}.search-field input{color:#e5edf6;background:0 0;border:0;outline:none;width:100%;min-width:0}.search-field input::placeholder{color:#64748b}.filter-row{align-items:stretch}.filter-row label{flex:1;gap:5px;min-width:0;display:grid}.filter-row label span{color:#93a4ba;font-size:12px;font-weight:800}.filter-row select{color:#e5edf6;background:#0f172a;border:1px solid #94a3b82e;border-radius:8px;min-width:0;height:40px;padding:0 10px}.clear-filters,.text-button,.inline-action,.drawer-button,.icon-button{color:#7dd3fc;cursor:pointer;background:#0ea5e91f;border:1px solid #38bdf857;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:40px;padding:8px 10px;font-size:13px;font-weight:800;display:inline-flex}.inline-action,.compact-button{min-height:32px;padding:6px 9px}.icon-button{width:38px;min-height:38px;padding:0}.match-list{gap:12px;margin-top:12px;display:grid}.match-list-section .match-list{flex:auto;min-height:0;max-height:none;padding-right:4px;overflow-y:auto}.match-day-group{gap:10px;display:grid}.day-heading{color:#93a4ba;justify-content:space-between;align-items:center;font-size:12px;font-weight:900;display:flex}.day-heading strong{color:#cbd5e1;background:#0f172aeb;border:1px solid #94a3b833;border-radius:999px;padding:3px 8px}.match-card{width:100%;color:inherit;cursor:pointer;text-align:left;background:linear-gradient(#0f172aeb,#0f172aad),#0f172ae0;border:1px solid #94a3b829;border-radius:8px;padding:14px;transition:border-color .16s,background .16s,transform .16s}.match-card:hover,.match-card.selected{background:linear-gradient(#11202cfa,#0c1928c7),#0f172aeb;border-color:#22c55e94}.match-card:hover{transform:translateY(-1px)}.match-meta,.match-footer{color:#93a4ba;min-width:0;font-size:12px}.match-footer span{align-items:center;gap:6px;min-width:0;display:inline-flex}.match-footer span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.status{color:#bae6fd;white-space:nowrap;background:#0ea5e91f;border:1px solid #7dd3fc47;border-radius:999px;padding:3px 8px}.status.live{color:#bbf7d0;background:#22c55e24;border-color:#22c55e6b}.status.finished{color:#cbd5e1;background:#64748b1f;border-color:#94a3b83d}.teams-row,.match-hero{grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;display:grid}.teams-row{margin:14px 0}.team-summary,.team-block{gap:4px;min-width:0;display:grid}.team-summary.right,.team-block.right{text-align:right}.team-code,.team-block span{color:#8ba4c4;font-size:12px;font-weight:900}.team-name,.team-block strong{overflow-wrap:anywhere;color:#f8fafc;min-width:0;font-size:16px;font-weight:900}.versus{color:#dbeafe;white-space:nowrap;background:#02061780;border:1px solid #94a3b829;border-radius:8px;place-items:center;min-width:44px;min-height:34px;font-size:13px;font-weight:900;display:inline-grid}.probability-block{gap:8px;display:grid}.probability-bar{background:#020617b8;border:1px solid #94a3b81f;border-radius:999px;width:100%;height:13px;display:flex;overflow:hidden}.probability-bar .home{background:linear-gradient(90deg,#38bdf8,#2563eb)}.probability-bar .draw{background:linear-gradient(90deg,#94a3b8,#64748b)}.probability-bar .away{background:linear-gradient(90deg,#22c55e,#059669)}.probability-labels{color:#a7b5c8;min-width:0;font-size:12px}.probability-labels span{white-space:nowrap}.probability-labels .strong{color:#f8fafc;font-weight:900}.card-insight{color:#93a4ba;border-top:1px solid #94a3b81f;margin-top:10px;padding-top:10px;font-size:12px}.card-insight strong{color:#f8fafc;overflow-wrap:anywhere}.detail-section{height:100%;min-height:0;position:sticky;top:18px}.detail-panel{padding:14px;overflow-y:auto}.match-hero{background:linear-gradient(135deg,#0ea5e91f,#22c55e14),#0f172ab8;border:1px solid #94a3b824;border-radius:8px;flex:none;padding:14px}.score-block{text-align:center;gap:4px;min-width:130px;display:grid}.score-block strong{color:#f8fafc;font-size:30px;line-height:1}.score-block span{color:#9fb0c6;font-size:12px}.match-submeta{color:#93a4ba;flex:none;padding-top:10px;font-size:12px}.match-submeta span:first-child{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.panel-section{border-bottom:1px solid #94a3b81f;flex:none;padding:12px 0}.panel-section:last-of-type{border-bottom:0}.section-heading.compact{margin-bottom:12px}.metric-grid,.live-snapshot-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.metric{background:#0f172a9e;border:1px solid #94a3b824;border-radius:8px;gap:4px;padding:9px;display:grid}.metric span{color:#93a4ba;font-size:12px}.metric strong{color:#f8fafc;overflow-wrap:anywhere;font-size:18px}.live-delta{color:#93a4ba;flex-wrap:wrap;gap:8px;margin-top:10px;font-size:12px;display:flex}.live-delta span,.live-delta strong{background:#0f172a9e;border:1px solid #94a3b824;border-radius:999px;padding:5px 8px}.live-delta strong{color:#f8fafc}.agent-panel{gap:10px;display:grid}.agent-heading{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.agent-heading h3{margin-bottom:0}.agent-heading>span{color:#bfdbfe;white-space:nowrap;background:#0ea5e91f;border:1px solid #7dd3fc47;border-radius:999px;padding:5px 8px;font-size:12px;font-weight:800}.agent-summary{color:#f8fafc;margin:0;font-size:14px;font-weight:750;line-height:1.45}.agent-points{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.agent-points span{color:#bfdbfe;background:#0f172a9e;border:1px solid #94a3b824;border-radius:8px;min-width:0;padding:8px;font-size:12px;line-height:1.35}.agent-notes{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.detail-grid,.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.panel-section h3{color:#f8fafc;margin:0 0 10px;font-size:16px}.section-title-row{margin-bottom:10px}.section-title-row h3{margin:0}.section-title-row span{color:#93a4ba;font-size:12px}.score-list,.factor-list{gap:8px;display:grid}.compact-list{gap:7px}.score-row,.factor-row{background:#0f172a9e;border:1px solid #94a3b824;border-radius:8px;min-width:0;padding:9px;font-size:14px}.score-row{grid-template-columns:auto 1fr auto;display:grid}.score-row .rank{color:#8ba4c4;font-size:12px;font-weight:900}.score-row strong{color:#f8fafc}.factor-row{display:block}.compact-factor{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.factor-main{gap:10px;min-width:0;display:grid}.factor-summary{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.factor-summary>div:first-child{gap:4px;min-width:0;display:grid}.factor-row p{color:#93a4ba;margin:0;font-size:12px;line-height:1.45}.factor-row span:first-child{color:#f8fafc;font-weight:800}.factor-row strong{color:#f8fafc}.factor-row.home{border-left:3px solid #38bdf8}.factor-row.away{border-left:3px solid #22c55e}.factor-row.draw,.factor-row.neutral{border-left:3px solid #94a3b8}.factor-impact{color:#93a4ba;white-space:nowrap;align-content:center;justify-items:end;gap:4px;font-size:12px;display:grid}.factor-impact span{color:#93a4ba;font-weight:800}.factor-detail-grid{border-top:1px solid #94a3b81f;gap:6px;padding-top:10px;display:grid}.factor-detail-row{color:#9fb0c6;grid-template-columns:68px minmax(0,1fr);align-items:start;gap:8px;font-size:12px;line-height:1.45;display:grid}.factor-detail-row span{color:#7dd3fc;font-weight:800}.factor-detail-row strong{color:#dbeafe;overflow-wrap:anywhere;font-size:12px;font-weight:650}.factor-fallback{border-top:1px solid #94a3b81f;padding-top:10px}.matrix-layout{grid-template-columns:minmax(0,1fr) 190px;align-items:start;gap:12px;display:grid}.matrix-scroll{padding-bottom:4px;overflow-x:auto}.score-matrix{gap:6px;width:max-content;display:grid}.matrix-axis{color:#93a4ba;text-align:center;align-self:center;font-size:12px;font-weight:800}.matrix-cell{color:#f8fafc;cursor:pointer;border:1px solid #38bdf82e;border-radius:8px;align-content:center;justify-items:center;min-height:54px;padding:5px 4px;font-size:12px;display:grid;position:relative}.matrix-cell span{color:#dbeafe}.matrix-cell.low{color:#93a4ba;opacity:.66}.matrix-cell.top-score{border-color:#22c55e99;box-shadow:inset 0 0 0 1px #22c55e33}.matrix-cell.selected{border-color:#f8fafc;box-shadow:0 0 0 2px #f8fafc24}.top-marker{color:#bbf7d0;font-size:9px;font-weight:900;position:absolute;top:3px;right:5px}.matrix-summary,.data-info{background:#0f172a9e;border:1px solid #94a3b824;border-radius:8px}.matrix-summary{color:#93a4ba;gap:7px;padding:12px;font-size:12px;display:grid}.matrix-summary strong{color:#f8fafc;font-size:26px}.matrix-summary p{margin:0;line-height:1.45}.matrix-summary b{color:#7dd3fc;font-size:16px}.data-info-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.data-info{color:#93a4ba;justify-content:flex-start;align-items:flex-start;min-width:0;padding:11px}.data-info div{gap:4px;min-width:0;display:grid}.data-info strong{color:#f8fafc;overflow-wrap:anywhere;font-size:13px}.action-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.drawer-button{color:#dbeafe;background:#0f172ab8;border-color:#94a3b82e;width:100%;min-height:44px}.drawer-button:hover,.inline-action:hover,.text-button:hover,.icon-button:hover{background:#0ea5e92e;border-color:#7dd3fc85}.drawer-layer{z-index:30;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0206179e;justify-content:flex-end;display:flex;position:fixed;inset:0}.analysis-drawer{background:linear-gradient(#09101dfa,#0a1220f5),#09101d;border-left:1px solid #94a3b838;flex-direction:column;width:min(720px,100vw - 28px);height:100%;display:flex;box-shadow:-24px 0 70px #0000006b}.drawer-header{border-bottom:1px solid #94a3b824;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px;display:flex}.drawer-header h2{color:#f8fafc;margin:0;font-size:22px}.drawer-body{flex:auto;min-height:0;padding:16px 18px 22px;overflow-y:auto}.drawer-section-stack{gap:14px;display:grid}.drawer-factor-list{gap:10px}.drawer-note{color:#bfdbfe;background:#0ea5e91a;border:1px solid #7dd3fc38;border-radius:8px;align-items:flex-start;gap:9px;padding:11px;font-size:13px;line-height:1.5;display:flex}.drawer-info-grid,.model-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.stale-banner{color:#fde68a;background:#78350f38;border:1px solid #fbbf2461;border-radius:8px;align-items:center;gap:8px;margin-top:14px;padding:10px 12px;font-size:13px;display:flex}.detail-footer{color:#93a4ba;padding-top:14px;font-size:12px}.status-message{color:#93a4ba;background:#0f172a9e;border:1px solid #94a3b824;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding:14px;display:flex}.status-message strong{color:#f8fafc;margin-bottom:3px;display:block}.status-message p{margin:0;font-size:13px;line-height:1.4}.status-message.error{color:#fecaca;background:#7f1d1d38;border-color:#f871714d}.status-message.error strong{color:#fee2e2}.skeleton-list{margin-top:14px}.skeleton-card,.detail-skeleton div{background:linear-gradient(90deg,#0f172a80,#1e293be6,#0f172a80) 0 0/220% 100%;border-color:#94a3b824;min-height:132px;animation:1.3s linear infinite shimmer}.detail-skeleton{gap:10px;padding-top:16px;display:grid}.detail-skeleton div{border-radius:8px;min-height:72px}@keyframes shimmer{0%{background-position:220% 0}to{background-position:-220% 0}}@media (width<=900px){body{overflow:auto}.app-shell{width:min(100% - 24px,720px);min-height:100vh;max-height:none;padding:16px 0 28px}.layout-grid,.detail-grid,.agent-points,.agent-notes,.summary-grid{grid-template-columns:1fr}.detail-section{order:1;height:auto;scroll-margin-top:12px;position:static}.match-list-section{order:2;height:auto;overflow:visible}.detail-panel{height:auto;overflow:visible}.match-list-section .match-list{max-height:70vh;padding-right:4px;overflow-y:auto}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.matrix-layout,.data-info-grid,.drawer-info-grid,.model-feature-grid,.live-snapshot-grid{grid-template-columns:1fr}.analysis-drawer{width:min(680px,100vw - 18px)}}@media (width<=560px){.topbar,.section-heading,.detail-footer,.filter-row,.status-message{flex-direction:column;align-items:flex-start}.topbar h1{font-size:26px}.topbar-status,.user-chip,.date-pill,.notice{width:100%}.layout-grid{gap:12px}.match-list-section,.detail-panel{padding:12px}.filter-row label,.clear-filters,.text-button,.inline-action{width:100%}.match-meta,.match-footer,.card-insight,.section-title-row,.match-submeta{flex-direction:column;align-items:flex-start;gap:6px}.teams-row{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:8px}.match-hero{text-align:left;grid-template-columns:1fr}.team-block.right,.score-block{text-align:left}.probability-labels{flex-direction:column;align-items:flex-start;gap:4px}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.score-row,.factor-row,.data-info{flex-direction:column;align-items:flex-start}.compact-factor{display:flex}.factor-impact{justify-items:start}.score-matrix{gap:5px}.action-strip{grid-template-columns:1fr}.drawer-layer{align-items:flex-end}.analysis-drawer{border-top:1px solid #94a3b838;border-left:0;border-radius:12px 12px 0 0;width:100%;height:min(92vh,760px)}.drawer-header,.drawer-body{padding-left:14px;padding-right:14px}}
