:root{--bg-primary:#0b1120;--bg-card:#131c31;--bg-card-hover:#1a2744;--bg-header:#0f1a2e;--border:#1e3456;--border-light:#2a4066;--text:#e2e8f0;--text-dim:#7e93b0;--text-muted:#4a6080;--blue:#3b82f6;--green:#22c55e;--orange:#f59e0b;--purple:#a78bfa;--red:#ef4444;--cyan:#06b6d4;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px rgba(0,0,0,.3);--font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans TC","Microsoft JhengHei",sans-serif}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:15px}
body{font-family:var(--font);background:var(--bg-primary);color:var(--text);min-height:100vh;line-height:1.5}
#app{max-width:1440px;margin:0 auto;padding:0 16px}
.topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);margin-bottom:16px}
.topbar-left{display:flex;align-items:center;gap:10px}
.logo{font-size:1.35rem;font-weight:800;letter-spacing:-.5px}
.logo span{background:linear-gradient(135deg,var(--blue),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo-badge{font-size:.65rem;background:var(--blue);color:#fff;padding:2px 7px;border-radius:20px;font-weight:600}
.topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.filter-group{display:flex;align-items:center;gap:6px}
.input-date{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;font-size:.82rem;outline:none}
.input-date:focus{border-color:var(--blue)}
.btn{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:7px 14px;cursor:pointer;font-size:.82rem;font-family:var(--font)}
.btn:hover{background:var(--bg-card-hover);border-color:var(--border-light)}
.btn-icon{font-size:1.1rem;padding:7px 10px;line-height:1}
.btn-primary{background:#1d4ed8;border-color:#2563eb;color:#fff;font-weight:600}
.btn-primary:hover{background:#2563eb;border-color:#3b82f6}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.auto-label{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-dim);cursor:pointer}
.auto-label input{accent-color:var(--blue)}
.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px}
.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 12px;text-align:center}
.kpi-card:hover{border-color:var(--border-light);transform:translateY(-2px)}
.kpi-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.kpi-val{font-size:1.5rem;font-weight:700;line-height:1.2}
.kpi-sub{font-size:.72rem;color:var(--text-muted);margin-top:2px}
.kpi-val.blue{color:var(--blue)}
.kpi-val.green{color:var(--green)}
.kpi-val.orange{color:var(--orange)}
.kpi-val.purple{color:var(--purple)}
.kpi-val.red{color:var(--red)}
.kpi-val.cyan{color:var(--cyan)}
.tabs{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.tab{background:var(--bg-card);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius);padding:8px 18px;cursor:pointer;font-size:.85rem;font-family:var(--font)}
.tab:hover{background:var(--bg-card-hover);color:var(--text)}
.tab.active{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:600}
.tab-content{display:none}
.tab-content.active{display:block}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px}
.card-header{font-size:.85rem;font-weight:600;margin-bottom:14px;color:var(--text-dim);display:flex;align-items:center;justify-content:space-between}
.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px}
.chart-grid canvas{max-height:250px;max-width:100%}
.table-wrap{overflow-x:auto;border-radius:var(--radius)}
.data-table{width:100%;border-collapse:collapse;font-size:.8rem}
.data-table thead th{background:var(--bg-primary);padding:8px 10px;text-align:right;white-space:nowrap;font-weight:600;color:var(--text-dim);position:sticky;top:0;cursor:pointer}
.data-table thead th:first-child,.data-table thead th:nth-child(2),.data-table thead th:nth-child(3){text-align:left}
.data-table thead th .dim{font-weight:400;color:var(--text-muted)}
.data-table tbody td{padding:7px 10px;border-bottom:1px solid var(--bg-primary);text-align:right;white-space:nowrap}
.data-table tbody td:first-child,.data-table tbody td:nth-child(2),.data-table tbody td:nth-child(3){text-align:left}
.data-table tbody tr:hover td{background:var(--bg-card-hover)}
.data-table tbody tr:nth-child(even) td{background:rgba(255,255,255,.02)}
.data-table tbody tr:nth-child(even):hover td{background:var(--bg-card-hover)}
td.kelly-pos{color:var(--green);font-weight:600}
td.kelly-neg{color:var(--text-muted)}
td.ev-pos{color:var(--green)}
td.ev-neg{color:var(--text-dim)}
.match-badge{background:var(--bg-primary);color:var(--text-dim);padding:2px 12px;border-radius:20px;font-size:.75rem}
.status-live:before{content:"";display:inline-block;width:7px;height:7px;background:var(--red);border-radius:50%;margin-right:5px;vertical-align:middle;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.status-half:before{content:"";display:inline-block;width:7px;height:7px;background:var(--orange);border-radius:50%;margin-right:5px;vertical-align:middle}
.status-ft{color:var(--text-muted)}
.badge-green{color:var(--green);font-weight:600}
@media(max-width:768px){.topbar{flex-direction:column;align-items:stretch}.topbar-right{justify-content:space-between}.kpi-strip{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}.tabs{overflow-x:auto;flex-wrap:nowrap}}