:root{
  --bg:#070a10; --panel:#0b1018; --panel2:#0c1219; --line:rgba(255,255,255,.06); --line2:rgba(255,255,255,.12);
  --txt:#e7edf4; --mut:#8a96a6; --dim:#5d6b7d;
  --accent:#2dd4a0; --accent-dim:#1c5e44; --warn:#f0883a; --bad:#ff5a6a;
  --serif:"Newsreader",Georgia,serif; --sans:"Plus Jakarta Sans",system-ui,"PingFang HK","Microsoft JhengHei",sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
  --soft:0 24px 60px -34px rgba(0,0,0,.8);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font-family:var(--sans);-webkit-font-smoothing:antialiased;letter-spacing:-.005em;min-height:100vh;font-variant-numeric:tabular-nums}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(820px 420px at 82% -10%, rgba(45,212,160,.06), transparent 60%)}
.hidden{display:none!important}
.eyebrow{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}

/* shell */
.shell{position:relative;z-index:1;display:grid;grid-template-columns:208px minmax(0,1fr);min-height:100vh;max-width:1240px;margin:0 auto}
.side{border-right:1px solid var(--line);padding:28px 20px;display:flex;flex-direction:column}
.logo{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-.02em;margin-bottom:30px}
.logo b{color:var(--accent);font-weight:500}
.nav{display:flex;flex-direction:column;gap:3px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:var(--mut);font-size:13.5px;font-weight:500;text-decoration:none;transition:.2s}
.nav a:hover{color:var(--txt);background:rgba(255,255,255,.03)}
.nav a.on{color:var(--txt);background:rgba(255,255,255,.05)}
.nav a .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:0;transition:.2s}
.nav a.on .dot{opacity:1}
.side-foot{margin-top:auto;padding-top:24px}
.tr-lbl{font-size:10px;color:var(--dim);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.tr-spark{display:flex;align-items:flex-end;gap:3px;height:30px}
.tr-spark i{flex:1;border-radius:2px;background:var(--accent-dim)}
.tr-spark i.on{background:var(--accent)}
.tr-num{margin-top:9px;font-family:var(--mono);font-size:19px;font-weight:500}
.tr-num span{font-size:10px;font-family:var(--sans);color:var(--mut);margin-left:5px}
.guide-btn{margin-top:18px;width:100%;background:transparent;border:1px solid var(--line2);color:var(--mut);border-radius:8px;padding:8px;font-size:11.5px;font-family:var(--sans);cursor:pointer;transition:.2s}
.guide-btn:hover{color:var(--txt);border-color:var(--accent)}

.main{padding:30px 34px 64px;min-width:0}
.acct{font-size:11px;color:var(--mut);text-align:right;margin-bottom:18px}

/* tabs */
.tabs{display:flex;gap:24px;border-bottom:1px solid var(--line);margin-bottom:22px;overflow-x:auto}
.tab{padding:0 0 12px;font-size:13px;color:var(--dim);font-weight:500;white-space:nowrap;border-bottom:1.5px solid transparent;margin-bottom:-1px;cursor:pointer;transition:.2s}
.tab .t-time{font-family:var(--mono);font-size:11px;display:block;margin-top:2px;opacity:.7}
.tab:hover{color:var(--mut)}
.tab.on{color:var(--txt);border-bottom-color:var(--accent)}

/* race header */
.rhead{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px}
.rhead h1{font-family:var(--serif);font-size:31px;font-weight:500;letter-spacing:-.025em;line-height:1.05;margin-top:3px}
.rhead .sub{font-size:12.5px;color:var(--mut);margin-top:7px}
.rhead .count{font-family:var(--mono);font-size:11px;color:var(--accent);white-space:nowrap}

/* 場況橫額 */
.banner-wrap{position:relative;margin-bottom:14px}
.banner{display:flex;align-items:center;gap:14px;border-radius:14px;padding:15px 17px;border:1px solid}
.banner.good{background:linear-gradient(105deg,#0e2a20,#0b1612);border-color:#1f6b52}
.banner.warn{background:linear-gradient(105deg,#3d1414,#150a0a);border-color:#7a2626}
.banner.skip{background:var(--panel);border-color:var(--line2)}
.banner .bic{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;flex:0 0 38px}
.banner.good .bic{background:#10412f}.banner.warn .bic{background:#7f1d1d}.banner.skip .bic{background:#1a2230;color:var(--mut)}
.banner .btx{flex:1;min-width:0}
.banner .btx b{font-size:16px;font-weight:800}
.banner.good .btx b{color:#a7f3d0}.banner.warn .btx b{color:#f6c9c9}
.banner .bsub{font-size:12px;margin-top:3px}
.banner.good .bsub{color:#8fcfb3}.banner.warn .bsub{color:#d3a3a3}
.banner .bmeter{text-align:right;flex:0 0 auto}
.banner .ms{display:flex;gap:3px;justify-content:flex-end}
.banner .ms i{width:17px;height:5px;border-radius:2px;background:rgba(255,255,255,.12)}
.banner.good .ms i.on{background:var(--accent)}.banner.warn .ms i.on{background:var(--warn)}
.banner .ml{font-family:var(--mono);font-size:10px;margin-top:5px}
.banner.good .ml{color:#8fcfb3}.banner.warn .ml{color:#d3a3a3}

/* ★ 本場投注建議 */
.picks-panel{position:relative;background:linear-gradient(180deg,#0d1620,#0a1119);border:1px solid #1d2c3a;border-radius:14px;padding:14px 15px;margin-bottom:12px}
.pp-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.pp-ttl{font-size:14px;font-weight:800;display:flex;align-items:center;gap:8px}
.pp-cnt{font-family:var(--mono);font-size:11px;font-weight:700;color:#04241a;background:var(--accent);border-radius:6px;padding:2px 8px}
.pp-play{font-size:12px;color:var(--mut)}
.pp-play b{color:var(--accent);font-weight:700}
.pp-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:9px}
.pp-card{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:10px;min-width:0}
.pp-card.bank{border-color:rgba(45,212,160,.55);background:linear-gradient(180deg,#11241c,#0c1219)}
.pp-top{display:flex;align-items:center;gap:6px}
.pp-silk{width:18px;height:18px;border-radius:5px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.4);flex:0 0 18px}
.pp-no{font-family:var(--mono);font-size:18px;font-weight:700;flex:1}
.pp-card.bank .pp-no{color:var(--accent)}
.pp-gr{font-size:10px;font-weight:700}
.pp-gr.ap{color:#7ee3bd}.pp-gr.a{color:#9fd0f5}.pp-gr.bp{color:#9fbce0}.pp-gr.b{color:#a8adba}.pp-gr.c{color:var(--dim)}
.pp-nm{font-size:13px;font-weight:600;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pp-card.bank .pp-nm{color:#eafaf2}
.pp-jt{font-size:10px;color:var(--mut);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pp-bot{display:flex;align-items:center;gap:6px;margin-top:9px;min-height:18px}
.pp-od{font-family:var(--mono);font-size:15px;font-weight:700}
.pp-tags{display:flex;gap:4px}
.ppt{font-size:9px;font-weight:700;border-radius:4px;padding:1px 5px;white-space:nowrap}
.ppt.bk{background:rgba(45,212,160,.16);color:#7ee3bd}
.ppt.fly{background:#2a2410;color:#e2bd6a}
.ppt.big{background:#2a1b12;color:#e0a07a}

/* dashboard grids */
.dash{display:grid;gap:10px;margin-bottom:10px}
.dash.a{grid-template-columns:1.35fr 1fr}
.dash.b{grid-template-columns:1fr 1fr 1fr}
.dash.c{grid-template-columns:1fr}
.stackcol{display:flex;flex-direction:column;gap:10px;min-width:0}

/* panel */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;min-width:0}
.phead{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-bottom:1px solid var(--line)}
.pttl{font-size:11px;color:var(--mut);font-weight:600}
.pbody{padding:11px 12px}
.svgc{width:100%;height:auto;display:block}
.empty{font-size:11px;color:var(--dim);padding:14px 4px;text-align:center}
.chlg{font-size:9px;color:var(--dim);margin-top:9px}
.chlg.ctr{text-align:center}

/* ⓘ tooltip */
.info{position:relative;display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;border:1px solid var(--line2);color:var(--dim);font-size:9px;font-style:normal;cursor:help;flex:0 0 15px}
.banner-wrap>.info{position:absolute;top:12px;right:12px}
.info .tip{position:absolute;bottom:145%;right:-4px;background:#05080c;border:1px solid #2a3647;border-radius:8px;padding:7px 10px;font-size:11.5px;font-weight:600;color:var(--txt);white-space:nowrap;opacity:0;pointer-events:none;transform:translateY(4px);transition:.15s;z-index:25;box-shadow:0 12px 30px -12px #000}
.info:hover .tip,.info:focus .tip{opacity:1;transform:translateY(0)}
.info .tip::after{content:"";position:absolute;top:100%;right:9px;border:5px solid transparent;border-top-color:#05080c}

/* ① table */
.tbl{font-size:12px}
.tcol,.trow{display:grid;grid-template-columns:20px 20px 1fr 44px 22px 30px;gap:7px;align-items:center}
.tcol{font-size:9px;color:var(--dim);padding:2px 2px 8px;border-bottom:1px solid var(--line)}
.tcol .r{text-align:right}.tcol .c{text-align:center}
.trow{padding:7px 2px;border-bottom:1px solid rgba(255,255,255,.04)}
.trow:last-child{border-bottom:0}
.trow.pk{background:rgba(45,212,160,.06);margin:0 -12px;padding-left:14px;padding-right:14px;grid-template-columns:20px 20px 1fr 44px 22px 30px;border-radius:0}
.tno{font-family:var(--mono);color:var(--mut)}
.trow.pk .tno{color:var(--accent);font-weight:700}
.tsilk{width:18px;height:18px;border-radius:5px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.4)}
.tnm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:5px}
.trow.pk .tnm{color:#eafaf2;font-weight:600}
.tod{font-family:var(--mono);text-align:right}
.da{text-align:center;font-size:10px}
.da.in{color:var(--accent)}.da.out{color:var(--warn)}.da.fl{color:var(--dim)}
.tg{text-align:right;font-weight:700;font-size:11px}
.tg.ap{color:#7ee3bd}.tg.a{color:#9fd0f5}.tg.bp{color:#9fbce0}.tg.b{color:#a8adba}.tg.c{color:var(--dim)}
.t{font-size:9px;font-weight:700;border-radius:4px;padding:1px 5px;flex:0 0 auto}
.t.bk{background:rgba(45,212,160,.16);color:#7ee3bd}
.t.fly{background:#2a2410;color:#e2bd6a}
.t.big{background:#2a1b12;color:#e0a07a}

/* ② bar */
.bars{display:flex;align-items:flex-end;gap:5px;height:84px}
.bcol{flex:1;display:flex;align-items:flex-end;height:100%}
.bar{width:100%;border-radius:3px 3px 0 0;min-height:6px}
.bar.veryhot{background:linear-gradient(180deg,#f0883a,#7a2d18)}
.bar.hot{background:linear-gradient(180deg,#2dd4a0,#16a34a)}
.bar.normal{background:#3f4d5e}
.blabs{display:flex;gap:5px;margin-top:5px}
.blabs span{flex:1;text-align:center;font-family:var(--mono);font-size:9px;color:var(--dim)}
.blabs span.eg{color:var(--accent);font-weight:700}

/* ⑤ drift */
.dbrow{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.dno{font-family:var(--mono);font-size:10px;color:var(--mut);width:14px;flex:0 0 14px}
.dtrack{flex:1;height:7px;position:relative}
.dline{position:absolute;top:3px;height:1.5px;border-radius:1px}
.ddot{position:absolute;top:0;width:7px;height:7px;border-radius:50%;margin-left:-3px}
.ddot.o17{background:#3f4d5e}

/* ⑥ momentum */
.mrow{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mno{font-family:var(--mono);font-size:10px;color:var(--mut);width:14px;flex:0 0 14px}
.mtrack{flex:1;display:flex;border-left:1px solid var(--line2)}
.mhalf{width:50%;display:flex;height:7px}
.mhalf.l{justify-content:flex-end}
.mhalf i{display:block;height:7px;border-radius:2px}

/* ⑦ spectrum */
.spgrid{display:grid;gap:3px;align-items:center}
.spcell{height:14px;border-radius:2px}
.spcell.sphd{height:auto;font-family:var(--mono);font-size:9px;color:var(--dim);text-align:center;background:none}
.spcell.sphd.eg{color:var(--accent);font-weight:700}
.spcell.splbl{font-family:var(--mono);font-size:9px;color:var(--mut);text-align:left;background:none}
.spcell.spna{display:flex;align-items:center;justify-content:center;color:#2a3645;font-size:9px;background:#0e151e}

.rfoot{margin-top:14px;font-size:11.5px;color:var(--mut);line-height:1.6}
.rfoot .lg{color:var(--dim);font-size:10px;margin-top:5px}

/* wall */
.wall{position:fixed;inset:0;background:rgba(6,8,12,.94);display:flex;align-items:center;justify-content:center;z-index:80;padding:24px}
.wall-card{border:1px solid var(--line);border-radius:16px;padding:34px 30px;max-width:340px;text-align:center;background:var(--panel);box-shadow:var(--soft)}
.wall-card .eyebrow{margin-bottom:16px}
.wall-title{font-family:var(--serif);font-size:21px;font-weight:500;margin-bottom:8px}
.wall-msg{font-size:13px;color:var(--mut);line-height:1.65}
.wall-btn{margin-top:22px;background:var(--accent);color:#04241a;border:none;border-radius:8px;padding:11px 24px;font-size:13.5px;font-weight:600;cursor:pointer}
.wall-btn:active{transform:scale(.98)}

.loading{color:var(--mut);padding:48px 0;font-size:13px}
.foot{position:fixed;bottom:0;left:0;right:0;text-align:center;font-size:10px;color:var(--dim);padding:8px;background:rgba(7,10,16,.9);backdrop-filter:blur(8px);border-top:1px solid var(--line);z-index:5}

/* 導覽 onboarding */
.onb-dim{position:fixed;inset:0;background:rgba(4,6,10,.82);z-index:55;display:none}
.spot{position:relative;z-index:60;border-radius:13px;box-shadow:0 0 0 2px var(--accent),0 0 0 4000px rgba(4,6,10,.82);transition:box-shadow .2s}
.onb-card-wrap{position:fixed;left:0;right:0;bottom:26px;z-index:70;display:flex;justify-content:center;padding:0 20px;pointer-events:none}
.onb-card{pointer-events:auto;width:100%;max-width:430px;background:#0c1219;border:1px solid #25323f;border-radius:14px;padding:16px 18px;box-shadow:0 24px 60px -24px #000}
.onb-top{display:flex;justify-content:space-between;align-items:center}
.onb-step{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--accent)}
.onb-skip{font-size:11px;color:var(--mut);cursor:pointer}
.onb-skip:hover{color:var(--txt)}
.onb-ttl{font-size:17px;font-weight:800;margin-top:9px}
.onb-body{font-size:13px;color:#aab6c6;line-height:1.65;margin-top:6px}
.onb-bot{display:flex;justify-content:space-between;align-items:center;margin-top:15px}
.onb-dots{display:flex;gap:4px}
.onb-dots i{width:6px;height:6px;border-radius:50%;background:#2a3647;transition:.2s}
.onb-dots i.on{width:16px;border-radius:3px;background:var(--accent)}
.onb-btns{display:flex;gap:8px}
.onb-btns button{font-family:var(--sans);font-size:12.5px;color:var(--mut);background:transparent;border:1px solid #25323f;border-radius:8px;padding:7px 14px;cursor:pointer;transition:.2s}
.onb-btns button:hover{color:var(--txt)}
.onb-btns button.prim{color:#04241a;background:var(--accent);border-color:var(--accent);font-weight:700}

/* responsive */
@media(max-width:980px){.dash.a{grid-template-columns:1fr}.dash.b{grid-template-columns:1fr}}
@media(max-width:720px){.shell{grid-template-columns:1fr}.side{display:none}.main{padding:20px 14px 64px}}
