*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#080c18;--s1:#0e1326;--s2:#131830;--s3:#1a2040;
  --bd:rgba(255,255,255,.05);--bd2:rgba(255,255,255,.08);--bd3:rgba(255,255,255,.12);
  --t1:#e0e4ef;--t2:#7882a0;--t3:#444e6a;--t4:#282e42;
  --gold:#d4a843;--gd:rgba(212,168,67,.08);
  --gn:#e24c4c;--gn-d:rgba(226,76,76,.08);
  --rd:#2d9b5a;--rd-d:rgba(45,155,90,.08);
  --bl:#4a8fe7;--bl-d:rgba(74,143,231,.08);
  --cy:#5bc0de;--pu:#9b7aed;
  --r:6px;--rs:4px;
  --shadow:0 1px 4px rgba(0,0,0,.25);
  --shadow-lg:0 4px 16px rgba(0,0,0,.35);
  --font:'Noto Sans SC','PingFang SC','Microsoft YaHei','Inter',sans-serif;
  --mono:'JetBrains Mono','SF Mono',monospace;
  --ease:cubic-bezier(.4,0,.2,1);
  --fs-base:clamp(11px,1.1vw,13px);
  --fs-xs:clamp(7px,.6vw,9px);
  --fs-sm:clamp(8px,.75vw,10px);
  --fs-md:clamp(10px,.9vw,12px);
  --fs-lg:clamp(14px,1.4vw,18px);
  --fs-xl:clamp(20px,2.2vw,30px);
  --gap:clamp(4px,.5vw,7px);
  --pad:clamp(5px,.6vw,10px);
  --stk-bg:#080c18;--stk-s1:#0e1326;--stk-s2:#131830;--stk-s3:#1a2040;
  --stk-bd:rgba(255,255,255,.05);--stk-bd2:rgba(255,255,255,.08);
  --stk-t1:#e0e4ef;--stk-t2:#7882a0;--stk-t3:#444e6a;--stk-t4:#282e42;
  --stk-up:#e24c4c;--stk-dn:#2d9b5a;--stk-gold:#d4a843;--stk-blue:#4a8fe7;
}
html,body{height:100%;overflow:hidden;font-size:var(--fs-base);-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--t1);font-family:var(--font)}
canvas{display:block}

/* ===== DASHBOARD GRID ===== */
.dash{
  display:grid;
  grid-template-rows:auto auto auto auto auto 1fr auto auto auto auto;
  height:100vh;width:100%;max-width:1800px;
  margin:0 auto;
  padding:var(--gap) clamp(10px,1.4vw,24px) calc(var(--gap) + 2px);
  gap:var(--gap);
  overflow:hidden;
}

/* ===== INDICES BAR ===== */
.idx-bar{
  display:flex;align-items:center;gap:clamp(4px,.5vw,8px);
  padding:0;overflow-x:auto;
}
.idx-bar::-webkit-scrollbar{display:none}
.idx-item{
  display:flex;align-items:center;gap:clamp(6px,.8vw,14px);
  padding:clamp(4px,.4vw,7px) clamp(8px,1vw,14px);
  background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);
  flex:1;min-width:0;white-space:nowrap;transition:border-color .2s;
}
.idx-item:hover{border-color:var(--bd2)}
.idx-name{font-size:var(--fs-xs);color:var(--t3);font-weight:700;letter-spacing:.8px;text-transform:uppercase;flex-shrink:0}
.idx-price{font-size:clamp(11px,1.1vw,15px);font-weight:800;font-family:var(--mono);color:var(--t1);flex-shrink:0}
.idx-chg{font-size:var(--fs-sm);font-weight:700;font-family:var(--mono);margin-left:auto}
.idx-chg.up{color:var(--gn)}.idx-chg.dn{color:var(--rd)}
.idx-extra{font-size:7px;color:var(--t3);font-family:var(--mono);margin-left:4px}

/* ===== HEADER ===== */
.hdr{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:1px 0;gap:clamp(6px,1vw,16px)}
.brand{display:flex;align-items:center;gap:clamp(6px,.8vw,12px)}
.brand-i{width:clamp(24px,2vw,30px);height:clamp(24px,2vw,30px);background:linear-gradient(135deg,#c0392b,#e67e22);border-radius:var(--r);display:grid;place-items:center;font-size:clamp(11px,1.1vw,15px)}
.brand h1{font-size:clamp(9px,.9vw,12px);font-weight:800;letter-spacing:3px;background:linear-gradient(90deg,var(--gold),#e8c06a);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.brand .sub{font-size:var(--fs-xs);color:var(--t3);letter-spacing:.8px}
.hdr-r{display:flex;align-items:center;gap:clamp(3px,.3vw,6px);flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:3px;padding:2px clamp(4px,.5vw,9px);border-radius:var(--rs);font-size:var(--fs-xs);font-weight:600;letter-spacing:.3px;white-space:nowrap}
.pill-live{background:var(--gn-d);color:var(--gn);border:1px solid rgba(226,76,76,.15)}
.pill-sim{background:var(--gd);color:var(--gold);border:1px solid rgba(212,168,67,.15)}
.pill-day{background:var(--bl-d);color:var(--bl);border:1px solid rgba(74,143,231,.15)}
.pill-time{color:var(--t3);font-family:var(--mono);font-size:var(--fs-xs)}
.dot{width:4px;height:4px;border-radius:50%;background:var(--gn);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== HERO ===== */
.hero{
  display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;align-items:center;
  padding:clamp(10px,1.2vw,18px) clamp(12px,1.5vw,24px);
  background:linear-gradient(135deg,var(--s1),var(--s2));
  border:1px solid var(--bd);border-radius:var(--r);
  position:relative;overflow:hidden;
}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.3}
.hv{padding:0 clamp(8px,1.2vw,20px)}.hv:first-child{padding-left:0}.hv:last-child{padding-right:0}.hc{text-align:center}.hr{text-align:right}
.hero .lb{font-size:var(--fs-xs);color:var(--t3);text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-bottom:4px}
.hero .big{font-size:var(--fs-xl);font-weight:900;line-height:1;font-family:var(--mono);letter-spacing:-1px}
.big.go{color:var(--gold)}.big.gn{color:var(--gn)}.big.rd{color:var(--rd)}
.hero .sub{font-size:var(--fs-sm);color:var(--t2);margin-top:4px}
.hero .sub .up{color:var(--gn);font-weight:600}.hero .sub .dn{color:var(--rd);font-weight:600}
.hdiv{width:1px;height:clamp(28px,3.5vw,48px);background:linear-gradient(180deg,transparent,var(--bd2),transparent)}
.hreg{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:4px}
.reg-tag{font-size:var(--fs-md);font-weight:800;padding:2px 10px;border-radius:var(--rs)}
.reg-conf{font-size:var(--fs-md);font-weight:700;color:var(--gold);font-family:var(--mono)}

/* ===== KPI ===== */
.kpi{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--gap)}
.kc{
  background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);
  padding:var(--pad) clamp(6px,.8vw,12px);transition:border-color .2s;min-width:0;
  position:relative;overflow:hidden;
}
.kc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--t4);border-radius:var(--r) var(--r) 0 0}
.kc:hover{border-color:var(--bd2)}
.kc:nth-child(1)::before{background:var(--gn)}
.kc:nth-child(2)::before{background:var(--bl)}
.kc:nth-child(3)::before{background:var(--gold)}
.kc:nth-child(4)::before{background:var(--pu)}
.kc:nth-child(5)::before{background:var(--rd)}
.kc:nth-child(6)::before{background:var(--t3)}
.kl{font-size:var(--fs-xs);color:var(--t3);text-transform:uppercase;letter-spacing:1.2px;font-weight:600;display:flex;align-items:center;gap:3px;white-space:nowrap}
.kl i{font-style:normal;font-size:clamp(8px,.7vw,11px)}
.kv{font-size:var(--fs-lg);font-weight:800;font-family:var(--mono);letter-spacing:-.5px;line-height:1;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kv.g{color:var(--gn)}.kv.r{color:var(--rd)}.kv.w{color:var(--t1)}.kv.go{color:var(--gold)}.kv.b{color:var(--bl)}
.kd{font-size:var(--fs-xs);color:var(--t3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kd .tg{display:inline-block;padding:1px 4px;border-radius:2px;font-size:var(--fs-xs);font-weight:700;margin-left:3px}
.tg-g{background:var(--gn-d);color:var(--gn)}.tg-r{background:var(--rd-d);color:var(--rd)}

/* ===== ALERTS ===== */
.alerts{display:flex;gap:var(--gap);min-height:0;flex-wrap:wrap}
.alerts:empty{display:none}
.alert{display:flex;align-items:center;gap:6px;padding:5px clamp(8px,.8vw,14px);border-radius:var(--rs);font-size:var(--fs-sm);border:1px solid;flex:1;min-width:200px}
.alert-danger{background:rgba(226,76,76,.05);border-color:rgba(226,76,76,.15);color:var(--gn)}
.alert-warn{background:rgba(212,168,67,.05);border-color:rgba(212,168,67,.15);color:var(--gold)}
.alert .a-icon{font-size:var(--fs-md);flex-shrink:0}.alert .a-text{font-weight:600;font-size:var(--fs-xs)}.alert .a-detail{color:var(--t3);margin-left:4px;font-weight:400;font-size:var(--fs-xs)}

/* ===== MAIN GRID ===== */
.main{display:grid;grid-template-columns:1fr clamp(280px,25vw,400px);gap:var(--gap);min-height:0;overflow:hidden}

/* LEFT COLUMN */
.left{display:grid;grid-template-rows:1fr 1fr;gap:var(--gap);min-height:0;overflow:hidden}
.card{
  background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;min-height:0;
}
.ch{
  padding:clamp(4px,.4vw,8px) clamp(6px,.7vw,12px);
  font-size:var(--fs-xs);font-weight:700;color:var(--t2);
  text-transform:uppercase;letter-spacing:1.5px;
  display:flex;align-items:center;gap:4px;flex-shrink:0;
  border-bottom:1px solid var(--bd);
  background:linear-gradient(180deg,var(--s2),var(--s1));
}
.ch .ic{font-size:var(--fs-sm)}
.cb{padding:clamp(4px,.4vw,8px) clamp(6px,.7vw,12px) clamp(4px,.5vw,10px);flex:1;min-height:0;overflow:hidden}

/* CHART */
.chart-card .cb{padding:3px clamp(4px,.6vw,10px) 2px}
.chart-main{flex:1;min-height:0}
.chart-main canvas{width:100%!important;height:100%!important}
.chart-dd{height:clamp(28px,3vw,48px);padding:0 clamp(4px,.6vw,10px) 3px;flex-shrink:0}
.chart-dd canvas{width:100%!important;height:100%!important}
.ctabs{display:flex;gap:2px;margin-left:auto}
.ct{padding:2px clamp(4px,.5vw,9px);border-radius:var(--rs);font-size:var(--fs-xs);font-weight:600;background:transparent;color:var(--t3);border:none;cursor:pointer;transition:all .15s;letter-spacing:.3px;white-space:nowrap}
.ct.on{background:var(--gd);color:var(--gold)}
.ct:hover:not(.on){color:var(--t2)}

/* HOLDINGS TABLE */
.hold-card{min-height:0}
.hold-card .ch{justify-content:flex-start}
.rt-toggle{
  margin-left:auto;padding:2px 8px;border-radius:var(--rs);
  font-size:var(--fs-xs);font-weight:600;background:transparent;
  color:var(--t3);border:1px solid var(--bd);cursor:pointer;transition:all .2s;
  white-space:nowrap;display:flex;align-items:center;gap:3px;
}
.rt-toggle:hover{color:var(--cy);border-color:var(--cy)}
.rt-toggle.on{background:var(--cy);color:#000;border-color:var(--cy)}
.rt-toggle .rt-dot{width:4px;height:4px;border-radius:50%;background:var(--cy);display:none}
.rt-toggle.on .rt-dot{display:block;animation:pulse 1.5s infinite}
.rt-badge{font-size:7px;color:var(--t3);font-family:var(--mono);margin-left:6px;font-weight:400;letter-spacing:0}
.rt-loading{display:flex;align-items:center;justify-content:center;padding:16px;gap:6px;color:var(--t3);font-size:var(--fs-sm)}
.rt-loading .ld-ring-sm{width:14px;height:14px;border:2px solid var(--s3);border-top-color:var(--cy);border-radius:50%;animation:spin .6s linear infinite}
.rt-hl{font-size:8px;color:var(--t3);font-family:var(--mono)}
.rt-vol{font-size:8px;color:var(--t2);font-family:var(--mono)}
.rt-amp{font-size:8px;font-family:var(--mono)}
.hold-scroll{overflow-y:auto;overflow-x:auto}
.hold-scroll::-webkit-scrollbar{width:3px;height:4px}
.hold-scroll::-webkit-scrollbar-thumb{background:var(--s3);border-radius:2px}
table.w{width:100%;border-collapse:collapse;min-width:500px}
table.w th{
  font-size:var(--fs-xs);color:var(--t3);font-weight:700;
  text-transform:uppercase;letter-spacing:1.2px;text-align:left;
  padding:clamp(4px,.4vw,7px) clamp(3px,.4vw,8px);
  border-bottom:1px solid var(--bd2);white-space:nowrap;
  position:sticky;top:0;background:var(--s2);z-index:1;
}
table.w th.r{text-align:right}
table.w td{padding:clamp(4px,.4vw,7px) clamp(3px,.4vw,8px);border-bottom:1px solid rgba(255,255,255,.02);font-size:var(--fs-sm);vertical-align:middle;white-space:nowrap}
table.w td.r{text-align:right;font-family:var(--mono);font-size:var(--fs-sm)}
table.w tbody tr{transition:background .1s}
table.w tbody tr:nth-child(even){background:rgba(255,255,255,.015)}
table.w tbody tr:hover{background:rgba(212,168,67,.04)}
.stk{display:flex;align-items:center;gap:4px}
.stk-dot{width:4px;height:4px;border-radius:50%;background:var(--bl);flex-shrink:0}
.stk-dot.gem{background:var(--pu)}
.stk-name{font-weight:600;font-size:var(--fs-sm)}.stk-link{cursor:pointer;color:var(--t1);text-decoration:none;transition:color .15s}.stk-link:hover{color:var(--gold);text-decoration:underline}.stk-code{font-size:var(--fs-xs);color:var(--t3);font-family:var(--mono);margin-left:1px}
.bt{font-size:clamp(5px,.4vw,7px);padding:1px 3px;border-radius:2px;font-weight:700;margin-left:2px;letter-spacing:.3px}
.bt-g{background:rgba(155,122,237,.12);color:var(--pu)}.bt-m{background:var(--bl-d);color:var(--bl)}
.wb{display:inline-flex;align-items:center;gap:3px}.wb-bar{width:clamp(18px,2.5vw,32px);height:2px;background:var(--s3);border-radius:2px;overflow:hidden}
.wb-fill{height:100%;border-radius:2px;background:var(--bl);transition:width .6s var(--ease)}
.hd{width:5px;height:5px;border-radius:50%;display:inline-block}
.hd-h{background:var(--gn)}.hd-m{background:var(--gold)}.hd-l{background:var(--rd)}
.p-up{color:var(--gn)}.p-dn{color:var(--rd)}
.empty{text-align:center;padding:clamp(8px,1vw,16px);color:var(--t3);font-size:var(--fs-sm)}

/* RIGHT COLUMN */
.right{display:grid;grid-template-rows:1fr 1fr;gap:var(--gap);min-height:0;overflow:hidden}
.r-top,.r-bot{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);min-height:0;overflow:hidden}

/* STRATEGY SCORE */
.score-body{display:flex;gap:clamp(4px,.6vw,10px);align-items:center}
.score-ring{position:relative;width:clamp(40px,4vw,64px);height:clamp(40px,4vw,64px);flex-shrink:0}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.score-ring .trk{fill:none;stroke:var(--s3);stroke-width:5}
.score-ring .val{fill:none;stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset 1s var(--ease)}
.score-num{position:absolute;inset:0;display:grid;place-items:center;font-size:clamp(12px,1.3vw,18px);font-weight:900;font-family:var(--mono)}
.score-grade{font-size:var(--fs-xs);font-weight:700;margin-top:2px;text-align:center}
.score-breakdown{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.sb-row{display:flex;align-items:center;gap:3px;font-size:var(--fs-xs)}
.sb-label{width:clamp(28px,3vw,44px);color:var(--t3);flex-shrink:0;text-align:right;font-size:var(--fs-xs)}
.sb-bar-bg{flex:1;height:3px;background:var(--s3);border-radius:2px;overflow:hidden}
.sb-bar-fill{height:100%;border-radius:2px;transition:width .6s var(--ease)}
.sb-val{width:clamp(14px,1.5vw,20px);font-family:var(--mono);font-weight:700;font-size:var(--fs-xs);text-align:right}

/* SIGNALS */
.sig-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3px,.3vw,6px);margin-bottom:clamp(3px,.4vw,8px)}
.sig-item{padding:clamp(3px,.4vw,7px) clamp(4px,.5vw,8px);background:var(--s2);border-radius:var(--rs);border:1px solid var(--bd)}
.sig-label{font-size:var(--fs-xs);color:var(--t3);text-transform:uppercase;letter-spacing:.8px;font-weight:600}
.sig-val{font-size:clamp(9px,.9vw,13px);font-weight:800;margin-top:1px}

/* SECTORS */
.sectors{border-top:1px solid var(--bd);padding-top:clamp(2px,.3vw,6px)}
.sector-row{display:flex;align-items:center;justify-content:space-between;padding:1px 0;font-size:var(--fs-xs)}
.sector-name{font-weight:500;display:flex;align-items:center;gap:3px}
.sector-chg{font-weight:700;font-family:var(--mono);font-size:var(--fs-xs)}

/* PNL DISTRIBUTION */
.pnl-dist{display:flex;align-items:flex-end;gap:clamp(2px,.3vw,5px);height:clamp(35px,5vw,70px);padding-top:3px}
.pnl-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.pnl-bar{width:100%;border-radius:2px 2px 0 0;transition:height .6s var(--ease);min-height:1px}
.pnl-bar-label{font-size:var(--fs-xs);color:var(--t3);white-space:nowrap}
.pnl-bar-count{font-size:var(--fs-xs);font-weight:700;font-family:var(--mono)}
.pnl-stats{display:flex;gap:clamp(4px,.6vw,10px);margin-top:clamp(3px,.4vw,8px);padding-top:clamp(2px,.3vw,6px);border-top:1px solid var(--bd)}
.pnl-stat{text-align:center;flex:1}
.pnl-stat .ps-val{font-size:clamp(9px,.9vw,13px);font-weight:800;font-family:var(--mono)}
.pnl-stat .ps-label{font-size:var(--fs-xs);color:var(--t3);margin-top:1px}

/* EXTRA (streaks, donut, etc) */
.extra-body{display:flex;flex-direction:column;gap:clamp(2px,.3vw,6px);overflow-y:auto}
.extra-body::-webkit-scrollbar{width:2px}
.extra-body::-webkit-scrollbar-thumb{background:var(--s3);border-radius:2px}
.streak-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2px,.3vw,6px)}
.streak-box{padding:clamp(3px,.4vw,7px);background:var(--s2);border-radius:var(--rs);border:1px solid var(--bd);text-align:center}
.streak-num{font-size:clamp(11px,1.2vw,17px);font-weight:900;font-family:var(--mono);line-height:1}
.streak-label{font-size:var(--fs-xs);color:var(--t3);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.streak-current{padding:clamp(2px,.3vw,5px);border-radius:var(--rs);text-align:center;font-size:var(--fs-xs);font-weight:700}
.streak-current.win{background:var(--gn-d);color:var(--gn)}.streak-current.loss{background:var(--rd-d);color:var(--rd)}
.donut-wrap{display:flex;align-items:center;gap:clamp(4px,.6vw,10px)}
.donut-svg{width:clamp(30px,3vw,48px);height:clamp(30px,3vw,48px);flex-shrink:0}
.donut-legend{display:flex;flex-direction:column;gap:2px}
.donut-item{display:flex;align-items:center;gap:3px;font-size:var(--fs-xs)}
.donut-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}

/* ===== BOTTOM STRIP ===== */
.bot-strip{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);max-height:clamp(55px,7vw,90px);overflow:hidden}
.tcal-card .cb{overflow:hidden}
.tcal{display:grid;grid-template-columns:repeat(30,1fr);gap:1px}
.tcal-cell{width:100%;aspect-ratio:1;border-radius:1px;position:relative}
.tcal-tip{display:none;position:absolute;bottom:calc(100%+2px);left:50%;transform:translateX(-50%);background:rgba(12,14,20,.96);color:var(--t1);font-size:var(--fs-xs);padding:2px 6px;border-radius:var(--rs);white-space:nowrap;z-index:10;border:1px solid var(--bd2)}
.tcal-cell:hover .tcal-tip{display:block}
.wf-row{display:flex;align-items:center;gap:3px;padding:1px 0;font-size:var(--fs-xs)}
.wf-name{width:clamp(28px,3vw,48px);font-weight:600;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wf-bar-area{flex:1;height:clamp(5px,.7vw,10px);position:relative;background:var(--s2);border-radius:2px;overflow:hidden}
.wf-bar{position:absolute;height:100%;border-radius:2px;transition:width .6s var(--ease);top:0}
.wf-bar.pos{background:var(--gn);left:50%}.wf-bar.neg{background:var(--rd);right:50%}
.wf-val{width:clamp(28px,3vw,48px);font-size:var(--fs-xs);font-weight:700;font-family:var(--mono);text-align:right;flex-shrink:0}
.ticker{font-size:var(--fs-xs);color:var(--t2);line-height:1.5;overflow-y:auto;max-height:clamp(35px,4.5vw,60px)}
.ticker::-webkit-scrollbar{width:2px}
.ticker::-webkit-scrollbar-thumb{background:var(--s3);border-radius:2px}

/* ===== NEWS TICKER BAR ===== */
.ticker-bar{
  --tk-fs:clamp(10px,1vw,14px);--tk-time:clamp(8px,.7vw,10px);
  display:flex;align-items:center;
  height:clamp(28px,3vw,40px);
  background:var(--s1);border:1px solid var(--bd);border-radius:var(--rs);
  overflow:hidden;position:relative;padding:0;
}
.ticker-label{
  flex-shrink:0;display:flex;align-items:center;gap:clamp(3px,.4vw,6px);
  padding:0 clamp(8px,1vw,16px);
  font-size:var(--tk-fs);font-weight:700;color:var(--gold);
  text-transform:uppercase;letter-spacing:1px;
  background:var(--s2);height:100%;
  border-right:1px solid var(--bd);white-space:nowrap;z-index:2;
}
.ticker-live-dot{width:clamp(4px,.5vw,7px);height:clamp(4px,.5vw,7px);border-radius:50%;background:var(--gn);animation:pulse 1.2s infinite}
.ticker-track{
  flex:1;overflow:hidden;position:relative;height:100%;
  display:flex;align-items:center;
  mask-image:linear-gradient(90deg,transparent 0%,#000 3%,#000 97%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 3%,#000 97%,transparent 100%);
}
.ticker-scroll{display:flex;align-items:center;gap:0;white-space:nowrap;animation:scrollLeft var(--ticker-dur,60s) linear infinite;padding-left:100%}
.ticker-scroll:hover{animation-play-state:paused}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:clamp(3px,.4vw,6px);padding:0 clamp(10px,1.8vw,28px);font-size:var(--tk-fs);color:var(--t2);white-space:nowrap;flex-shrink:0;border-right:1px solid var(--bd)}
.ticker-item:last-child{border-right:none}
.ticker-item .ti-time{color:var(--t3);font-family:var(--mono);font-size:var(--tk-time);margin-right:clamp(2px,.3vw,5px)}
.ticker-item .ti-dot{width:clamp(4px,.4vw,6px);height:clamp(4px,.4vw,6px);border-radius:50%;background:var(--gold);flex-shrink:0}
.ticker-item.ti-hot .ti-dot{background:var(--gn)}
.ticker-item.ti-alert .ti-dot{background:var(--gold);animation:pulse 1s infinite}
.ticker-item.ti-hot .ti-text{color:var(--gn);font-weight:600}
.ticker-item.ti-alert .ti-text{color:var(--gold);font-weight:600}

/* ===== SECTOR HEATMAP ===== */
.heatmap-wrap{
  display:flex;align-items:center;gap:clamp(4px,.6vw,10px);
  min-height:clamp(30px,3.2vw,42px);
}
.heatmap-label{
  flex-shrink:0;display:flex;align-items:center;gap:3px;
  font-size:var(--fs-xs);font-weight:700;color:var(--t2);
  text-transform:uppercase;letter-spacing:1px;
  padding:0 clamp(4px,.5vw,8px);white-space:nowrap;
}
.heatmap-label .ic{font-size:var(--fs-sm)}
.heatmap{flex:1;display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
.heatmap::-webkit-scrollbar{display:none}
.hm-cell{
  flex:1;min-width:clamp(38px,4.2vw,65px);
  padding:clamp(3px,.4vw,5px) clamp(3px,.4vw,6px);
  border-radius:var(--rs);text-align:center;
  display:flex;flex-direction:column;justify-content:center;
  transition:transform .15s;cursor:default;position:relative;
}
.hm-cell:hover{transform:scale(1.06);z-index:2}
.hm-name{font-size:clamp(6px,.5vw,8px);font-weight:700;color:rgba(255,255,255,.9);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}
.hm-chg{font-size:clamp(7px,.6vw,9px);font-weight:800;font-family:var(--mono);color:rgba(255,255,255,1);line-height:1.2;margin-top:1px}
.hm-flow{font-size:5px;color:rgba(255,255,255,.55);font-family:var(--mono)}

/* ===== K-LINE MODAL ===== */
.kline-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.kline-overlay.show{display:flex}
.kline-modal{width:clamp(600px,80vw,1200px);height:clamp(400px,70vh,700px);background:var(--s1);border:1px solid var(--bd2);border-radius:10px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.kline-header{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--bd);flex-shrink:0}
.kline-title{display:flex;align-items:baseline;gap:8px;flex:1}
.kline-name{font-size:15px;font-weight:800;color:var(--t1)}
.kline-code{font-size:11px;color:var(--t3);font-family:var(--mono)}
.kline-tabs{display:flex;gap:2px}
.kt{padding:4px 12px;border-radius:var(--rs);font-size:11px;font-weight:600;background:transparent;color:var(--t3);border:none;cursor:pointer;transition:all .15s}
.kt.on{background:var(--gd);color:var(--gold)}
.kt:hover:not(.on){color:var(--t2)}
.kline-close{width:28px;height:28px;border-radius:var(--rs);border:1px solid var(--bd);background:transparent;color:var(--t3);font-size:14px;cursor:pointer;display:grid;place-items:center;transition:all .15s}
.kline-close:hover{background:var(--gn-d);color:var(--gn);border-color:rgba(226,76,76,.3)}
.kline-chart{flex:1;min-height:0;position:relative}

/* ===== FOOTER ===== */
.foot{display:flex;justify-content:space-between;align-items:center;padding:2px 0;border-top:1px solid var(--bd)}
.fn{font-size:var(--fs-sm);font-weight:700;color:var(--gold)}.fs{font-size:var(--fs-xs);color:var(--t3)}
.ft{font-size:var(--fs-xs);color:var(--t3);font-family:var(--mono)}

/* ===== REFRESH BAR ===== */
.rbar{position:fixed;bottom:0;left:0;right:0;height:2px;z-index:100}
.rfill{height:100%;background:linear-gradient(90deg,var(--gold),var(--bl));width:0;transition:width 1s linear}

/* ===== LOADING ===== */
.ld{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:10px}
.ld-ring{width:28px;height:28px;border:2px solid var(--s3);border-top-color:var(--gold);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ld-t{font-size:var(--fs-md);color:var(--t3)}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.a{animation:fadeUp .3s var(--ease) both}
.a1{animation-delay:.03s}.a2{animation-delay:.06s}.a3{animation-delay:.09s}.a4{animation-delay:.12s}

/* ===== SEARCH ===== */
.hdr-mid{display:flex;justify-content:center;align-items:center}
.search-wrap{position:relative;width:100%;max-width:420px}
.search-box{display:flex;align-items:center;gap:6px;background:var(--s2);border:1px solid var(--bd);border-radius:var(--r);padding:4px 10px;transition:border-color .15s,box-shadow .15s}
.search-box:focus-within{border-color:rgba(212,168,67,.35);box-shadow:0 0 0 2px rgba(212,168,67,.08)}
.search-icon{color:var(--t3);flex-shrink:0}
.search-input{background:none;border:none;outline:none;color:var(--t1);font-size:clamp(9px,.85vw,12px);font-family:var(--font);width:100%;letter-spacing:.3px}
.search-input::placeholder{color:var(--t4)}
.search-kbd{font-family:var(--mono);font-size:8px;color:var(--t3);background:var(--s3);border:1px solid var(--bd);border-radius:3px;padding:1px 5px;line-height:1.4;flex-shrink:0}
.search-box:focus-within .search-kbd{display:none}
.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--s1);border:1px solid var(--bd2);border-radius:var(--r);box-shadow:0 8px 40px rgba(0,0,0,.5);z-index:500;display:none;overflow:hidden;max-height:360px;overflow-y:auto}
.search-dropdown.open{display:block}
.sr-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid rgba(255,255,255,.03)}
.sr-item:last-child{border-bottom:none}
.sr-item:hover,.sr-item.active{background:rgba(212,168,67,.06)}
.sr-code{font-family:var(--mono);font-size:clamp(10px,.85vw,12px);font-weight:700;color:var(--gold);min-width:60px}
.sr-name{font-size:clamp(10px,.85vw,12px);color:var(--t1);font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-mkt{font-size:8px;font-weight:700;color:var(--t2);background:var(--s3);border:1px solid var(--bd);border-radius:3px;padding:2px 6px;letter-spacing:.5px}
.sr-type{font-size:7px;color:var(--t4)}
.sr-empty{padding:20px;text-align:center;color:var(--t3);font-size:11px}
.sr-hint{padding:8px 14px;font-size:9px;color:var(--t4);border-top:1px solid var(--bd);display:flex;justify-content:space-between}
.sr-hint kbd{font-family:var(--mono);background:var(--s3);border:1px solid var(--bd);border-radius:3px;padding:1px 5px;font-size:8px;color:var(--t3)}

/* ===== STOCK DETAIL PAGE ===== */
.stk-overlay{position:fixed;inset:0;z-index:800;background:var(--stk-bg);opacity:0;pointer-events:none;transition:opacity .22s ease}
.stk-overlay.open{opacity:1;pointer-events:all}
.stk-page{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden;font-family:var(--font)}
.stk-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px clamp(16px,2.5vw,28px);border-bottom:1px solid var(--stk-bd);background:var(--stk-s1);gap:20px}
.stk-hdr-left{display:flex;align-items:center;gap:clamp(10px,1.2vw,18px)}
.stk-back{background:none;border:1px solid var(--stk-bd2);border-radius:4px;color:var(--stk-t2);cursor:pointer;padding:5px 10px;display:flex;align-items:center;gap:4px;font-size:11px;transition:all .15s}
.stk-back:hover{background:var(--stk-s3);color:var(--stk-t1);border-color:rgba(255,255,255,.12)}
.stk-hdr-name{font-size:clamp(16px,1.8vw,24px);font-weight:800;color:var(--stk-t1);letter-spacing:1px}
.stk-hdr-code{font-family:var(--mono);font-size:clamp(11px,1vw,14px);font-weight:600;color:var(--stk-gold)}
.stk-hdr-mkt{font-size:9px;font-weight:700;color:var(--stk-t3);background:var(--stk-s3);border:1px solid var(--stk-bd);border-radius:3px;padding:2px 7px;letter-spacing:.8px}
.stk-hdr-right{display:flex;align-items:center;gap:20px}
.stk-price-block{display:flex;align-items:baseline;gap:clamp(8px,1vw,16px)}
.stk-price{font-family:var(--mono);font-size:clamp(24px,3vw,38px);font-weight:900;letter-spacing:-.5px}
.stk-chg{font-family:var(--mono);font-size:clamp(13px,1.3vw,18px);font-weight:700}
.stk-price.up,.stk-chg.up{color:var(--stk-up)}
.stk-price.dn,.stk-chg.dn{color:var(--stk-dn)}
.stk-body{display:grid;grid-template-columns:1fr clamp(240px,20vw,300px);min-height:0;overflow:hidden}
.stk-chart-area{display:grid;grid-template-rows:auto 1fr;min-height:0;border-right:1px solid var(--stk-bd)}
.stk-chart-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;border-bottom:1px solid var(--stk-bd);background:var(--stk-s1)}
.stk-period-tabs{display:flex;gap:2px}
.sp{background:none;border:1px solid transparent;border-radius:3px;color:var(--stk-t3);font-size:11px;font-weight:600;padding:4px 14px;cursor:pointer;transition:all .15s;letter-spacing:.3px}
.sp:hover{color:var(--stk-t2);background:var(--stk-s3)}
.sp.on{color:var(--stk-gold);background:rgba(212,168,67,.08);border-color:rgba(212,168,67,.2)}
.stk-chart-info{font-family:var(--mono);font-size:11px;color:var(--stk-t3);display:flex;gap:14px}
.stk-chart-container{min-height:0;position:relative;background:var(--stk-bg)}
.stk-sidebar{display:grid;grid-template-rows:1fr;gap:0;overflow-y:auto;background:var(--stk-s1)}
.stk-sec{padding:12px 16px;border-bottom:1px solid var(--stk-bd)}
.stk-sec-title{font-size:10px;font-weight:700;color:var(--stk-gold);letter-spacing:1.5px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--stk-bd)}
.stk-metrics{display:grid;grid-template-columns:1fr;gap:0}
.stk-metric{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.02)}
.stk-metric:last-child{border-bottom:none}
.stk-metric-label{font-size:clamp(9px,.75vw,11px);color:var(--stk-t3);font-weight:500}
.stk-metric-val{font-family:var(--mono);font-size:clamp(10px,.8vw,12px);font-weight:700;color:var(--stk-t1);letter-spacing:.3px}
.stk-metric-val.stk-up{color:var(--stk-up)}
.stk-metric-val.stk-dn{color:var(--stk-dn)}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){
  .main{grid-template-columns:1fr clamp(240px,22vw,320px)}
  .hero .big{font-size:clamp(16px,2vw,24px)}
  .hero .sub{font-size:var(--fs-xs)}
  .bot-strip{grid-template-columns:1fr 1fr}
  .kpi{grid-template-columns:repeat(3,1fr)}
  .kc:nth-child(n+4)::before{background:var(--t3)}
}
@media(max-width:900px){
  html,body{overflow-y:auto;overflow-x:hidden}
  .dash{height:auto;min-height:100vh;grid-template-rows:auto auto auto auto auto auto auto auto auto auto;overflow:visible}
  .main{grid-template-columns:1fr}
  .left{grid-template-rows:auto auto}
  .right{grid-template-rows:auto auto}
  .r-top,.r-bot{grid-template-columns:1fr 1fr}
  .hero{grid-template-columns:1fr;gap:clamp(6px,1vw,14px);padding:clamp(8px,1vw,14px)}
  .hv{padding:0!important;text-align:center!important}
  .hr{text-align:center!important}
  .hdiv{width:60%;height:1px;margin:0 auto}
  .kpi{grid-template-columns:repeat(3,1fr)}
  .bot-strip{grid-template-columns:1fr 1fr;max-height:none}
  .hold-scroll{overflow-x:auto}
  table.w{min-width:480px}
}
@media(max-width:600px){
  .dash{padding:4px 8px 6px;gap:4px}
  .hdr{grid-template-columns:1fr;gap:4px}
  .hdr-mid{order:-1}
  .hdr-r{justify-self:start}
  .search-wrap{max-width:100%}
  .stk-body{grid-template-columns:1fr}
  .stk-sidebar{display:none}
  .stk-chart-area{border-right:none}
  .hero{padding:8px 10px;gap:6px}
  .hero .big{font-size:clamp(16px,6vw,24px)}
  .kpi{grid-template-columns:repeat(2,1fr);gap:4px}
  .kc{padding:6px 8px}
  .kv{font-size:clamp(14px,4vw,18px)}
  .r-top,.r-bot{grid-template-columns:1fr}
  .bot-strip{grid-template-columns:1fr;max-height:none}
  .bot-strip .card{max-height:100px}
  .chart-dd{height:24px}
  table.w{min-width:420px}
  table.w th,table.w td{padding:3px 4px;font-size:var(--fs-xs)}
  .pill-time{display:none}
  .chart-dd{display:none}
  .stk-code{display:none}
}
