:root {
  --bg:      #07090f;
  --bg2:     #0d1120;
  --bg3:     #131829;
  --border:  #1e2640;
  --border2: #2a3356;
  --cyan:    #00d4ff;
  --cyan2:   #0099cc;
  --green:   #00e676;
  --red:     #ff1a4b;
  --yellow:  #ffd700;
  --orange:  #ff8c00;
  --purple:  #b388ff;
  --dim:     #8892b8;
  --text:    #eef2ff;
  --text2:   #c5d1e8;
  --white:   #eef2ff;
  --row-stripe: rgba(30,38,64,.35);
  --row-border: rgba(30,38,64,.4);
  --shadow:     rgba(0,0,0,.65);
  --card:       #0d1120;
  --card-h:     #111827;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{font-size:21px;}
body{
  background:var(--bg); color:var(--text);
  font-family:'Chakra Petch',sans-serif; min-height:100vh; overflow-x:hidden;
}
body::before{
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%,rgba(0,212,255,.04) 0%,transparent 70%),
    repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(30,38,64,.3) 39px,rgba(30,38,64,.3) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(30,38,64,.15) 39px,rgba(30,38,64,.15) 40px);
}
/* ── TOPBAR ─────────────────────────────────────────────── */
#topbar{
  position:sticky;top:0;z-index:100;
  background:rgba(7,9,15,.96); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;padding:8px 20px;flex-wrap:wrap;
}
.logo{display:flex;flex-direction:column;gap:1px;line-height:1;margin-right:4px;}
.logo-mark{font-size:1.1rem;font-weight:700;letter-spacing:.18em;color:var(--cyan);font-family:'Chakra Petch',sans-serif;text-transform:uppercase;white-space:nowrap;}
.logo-sub{font-size:.58rem;color:var(--text2);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.pill{
  display:flex;align-items:center;gap:6px;
  background:var(--bg3);border:1px solid var(--border);border-radius:20px;
  padding:4px 12px;font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--text2);
  white-space:nowrap;
}
.version-pill{color:var(--cyan2);letter-spacing:.04em;font-size:.75rem;
}
.dot{width:7px;height:7px;border-radius:50%;background:var(--dim);}
.dot.live{background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 2s infinite;}
.dot.loading{background:var(--yellow);animation:pulse .6s infinite;}
.dot.error{background:var(--red);}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.topbar-right{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
#last-update{font-family:'JetBrains Mono',monospace;font-size:.76rem;color:var(--dim);}
.btn{
  background:var(--bg3);border:1px solid var(--border2);color:var(--text);
  font-family:'Chakra Petch',sans-serif;font-size:.8rem;font-weight:600;
  letter-spacing:.08em;padding:7px 14px;min-height:44px;border-radius:6px;cursor:pointer;
  text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;
  display:inline-flex;align-items:center;gap:6px;line-height:1;
}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;}
.btn:hover{background:var(--border2);color:var(--white);border-color:var(--cyan);}
.btn.primary{background:rgba(0,212,255,.12);border-color:var(--cyan);color:var(--cyan);}
.btn.primary:hover{background:rgba(0,212,255,.22);}
/* ── SYMBOL BAR ─────────────────────────────────────────── */
#sym-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:8px 20px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;position:relative;z-index:10;
}
.sym-chip{
  display:flex;align-items:center;gap:5px;
  background:var(--bg3);border:1px solid var(--border2);border-radius:6px;
  padding:4px 10px;font-size:.82rem;font-weight:600;letter-spacing:.08em;
}
.sym-prov{font-size:.68rem;opacity:.6;font-weight:400;}
.sym-remove{
  background:none;border:none;color:var(--dim);cursor:pointer;font-size:.92rem;
  line-height:1;transition:color .1s;padding:2px 4px;border-radius:3px;
  min-width:22px;min-height:22px;display:inline-flex;align-items:center;justify-content:center;
}
.sym-remove:hover{color:var(--red);}
.sym-remove:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;}
.sym-add-form{display:flex;gap:6px;}
.sym-input{
  background:var(--bg3);border:1px solid var(--border2);color:var(--white);
  font-family:'JetBrains Mono',monospace;font-size:.8rem;
  padding:5px 9px;border-radius:6px;outline:none;width:110px;text-transform:uppercase;
}
.sym-input:focus{border-color:var(--cyan);}
/* ── SECTIONS ──────────────────────────────────────────── */
.section{padding:14px 20px;position:relative;z-index:1;max-width:1440px;margin:0 auto;width:100%;}
.section-title{
  font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:10px;display:flex;align-items:center;gap:8px;
}
.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent);}
/* ── MAIN TABLE ─────────────────────────────────────────── */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',monospace;font-size:.8rem;}
th{
  background:var(--bg3);color:var(--text2);font-weight:500;
  letter-spacing:.05em;padding:7px 10px;text-align:right;
  border-bottom:1px solid var(--border2);white-space:nowrap;
  font-size:.72rem;text-transform:uppercase;
}
th:first-child{text-align:left;}
td{padding:8px 10px;text-align:right;border-bottom:1px solid rgba(30,38,64,.5);white-space:nowrap;}
td:first-child{text-align:left;font-family:'Chakra Petch',sans-serif;font-weight:700;font-size:.88rem;}
tr:hover td{background:var(--row-border);}
tr.shimmer td{color:var(--dim);animation:pulse .9s infinite;}
.bull{color:var(--green);}
.bear{color:var(--red);}
.neutral{color:var(--text2);}
.warn{color:var(--yellow);}
.tv-link{color:inherit;text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.2);}
.tv-link:hover{color:var(--cyan);border-bottom-color:var(--cyan);}
/* ── SIGNALS GRID ────────────────────────────────────────── */
.signals-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));}
.sig-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);}
.sig-card:hover{border-color:var(--border2);}
.sig-head{
  background:var(--bg3);padding:9px 13px;
  display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);
}
.sig-head .sym{font-weight:700;font-size:.96rem;letter-spacing:.1em;}
.sig-head .price{font-family:'JetBrains Mono',monospace;font-size:.86rem;}
.sig-head .prov-badge{font-size:.68rem;padding:2px 7px;border-radius:10px;background:rgba(0,212,255,.12);color:var(--cyan2);}
.sig-rows{padding:2px 0;}
.sig-row{display:flex;align-items:baseline;padding:6px 13px;gap:8px;border-bottom:1px solid var(--row-stripe);}
.sig-row:last-child{border-bottom:none;}
.sig-cat{font-size:.84rem;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;min-width:116px;}
.sig-val{font-weight:700;font-size:.92rem;min-width:124px;}
.sig-desc{font-size:.82rem;color:var(--text2);flex:1;}
/* ── DEEP CARD SCORE SECTION ─────────────────────────────── */
.deep-section-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);margin:8px 0 3px;}
.score-mini-table{width:100%;border-collapse:collapse;font-size:.82rem;}
.score-mini-table thead th{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);padding:2px 8px;border-bottom:1px solid var(--border2);text-align:left;}
.score-mini-table thead th:nth-child(2){text-align:right;width:52px;}
.score-mini-table tbody tr:nth-child(odd){background:var(--row-stripe);}
.score-mini-table tbody td{padding:3px 8px;border-bottom:1px solid rgba(30,38,64,.3);}
.score-mini-table tbody td:nth-child(2){text-align:right;font-weight:700;width:52px;}
.sc-reason{color:var(--text2);font-size:.78rem;}
.deep-card tr:hover td{background:inherit;}
/* ── BOT CARDS ───────────────────────────────────────────── */
.bot-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));}
.bot-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);}
.bot-head{padding:11px 15px;display:flex;align-items:center;justify-content:space-between;}
.bot-head.long{background:rgba(0,230,118,.08);border-bottom:1px solid rgba(0,230,118,.2);}
.bot-head.short{background:rgba(255,26,75,.08);border-bottom:1px solid rgba(255,26,75,.2);}
.bot-title{font-size:.96rem;font-weight:700;}
.bot-params{padding:6px 0;font-family:'JetBrains Mono',monospace;}
.param-row{display:flex;justify-content:space-between;padding:6px 16px;font-size:.93rem;border-bottom:1px solid var(--row-border);}
.param-row:last-child{border-bottom:none;}
.param-label{color:var(--text2);}
.param-val{font-weight:600;}
.bot-rules{background:var(--bg3);padding:11px 16px;font-size:.88rem;color:var(--text2);line-height:1.75;border-top:1px solid var(--border);}
.bot-rules p{margin:2px 0;}
/* ── LEGEND ──────────────────────────────────────────────── */
.legend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:8px;}
.legend-item{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:9px 13px;}
.legend-name{font-size:.88rem;font-weight:700;color:var(--cyan2);margin-bottom:4px;}
.legend-desc{font-size:.84rem;color:var(--text2);line-height:1.55;}
/* ── STATES ──────────────────────────────────────────────── */
.empty{text-align:center;padding:40px;color:var(--dim);font-size:.86rem;}
.s-high{color:var(--green);}
.s-mid{color:var(--yellow);}
.s-low{color:var(--red);}
/* ── MODAL ───────────────────────────────────────────────── */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:999;align-items:center;justify-content:center;}
#modal-overlay.show{display:flex;}
#modal{background:var(--bg2);border:1px solid var(--border2);border-radius:12px;padding:22px;min-width:300px;box-shadow:0 24px 80px rgba(0,0,0,.7);}
#modal h3{font-size:.96rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;}
#modal p{font-size:.82rem;color:var(--text2);margin-bottom:9px;}
.modal-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:14px;}
/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
/* ── FOCUS & MOTION ──────────────────────────────────────── */
:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:4px;}
@media(prefers-reduced-motion:reduce){
  .dot.live,.dot.loading,tr.shimmer td,.score-bar-fill{animation:none;transition:none;}
}
/* ── TOOLTIPS (CSS-only for non-header cells) ────────────── */
.tip{position:relative;cursor:help;}
.tip .tiptext{
  visibility:hidden;opacity:0;
  position:absolute;z-index:50;
  bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--bg3);border:1px solid var(--border2);border-radius:8px;
  padding:9px 13px;font-size:.72rem;line-height:1.6;
  white-space:normal;min-width:200px;max-width:320px;color:var(--text);
  box-shadow:0 8px 24px var(--shadow);
  transition:opacity .15s;pointer-events:none;
  font-family:'JetBrains Mono',monospace;font-weight:400;
}
.tip:hover .tiptext{visibility:visible;opacity:1;}
/* Header tooltips bypass overflow via fixed JS floater — hide native tiptext */
th .tiptext{display:none !important;}
/* Shared fixed floater (position set by JS) */
#th-tip-floater{
  position:fixed;z-index:9999;display:none;
  background:var(--bg3);border:1px solid var(--border2);border-radius:8px;
  padding:9px 13px;font-size:.72rem;line-height:1.6;
  color:var(--text);box-shadow:0 8px 24px var(--shadow);
  max-width:320px;white-space:normal;pointer-events:none;
  font-family:'JetBrains Mono',monospace;
}
/* ── COLLAPSIBLE TOGGLES ─────────────────────────────────── */
.ci{display:inline-block;transition:transform .2s;font-size:.7rem;}
.collapse-btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:none;border:none;color:var(--text2);
  font-family:'Chakra Petch',sans-serif;
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 0;transition:color .15s;
}
.collapse-btn:hover{color:var(--cyan);}
/* ── 3-COLUMN LEGEND ─────────────────────────────────────── */
.legend-3col{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-bottom:10px;}
.legend-box{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:11px 14px;transition:border-color .2s;}
.legend-box:hover{border-color:var(--border2);}
.legend-box-title{font-size:.82rem;font-weight:700;color:var(--cyan2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.legend-box-item{font-size:.86rem;color:var(--text2);margin:4px 0;line-height:1.55;}
/* ── ENHANCED HOVER EFFECTS ──────────────────────────────── */
.sig-card:hover{border-color:var(--cyan) !important;box-shadow:0 0 24px rgba(0,212,255,.12);transform:translateY(-2px);}
.sig-row{cursor:default;transition:background .1s;}
.sig-row:hover{background:var(--row-stripe);}
.bot-card:hover{border-color:var(--border2);box-shadow:0 8px 28px rgba(0,0,0,.45);transform:translateY(-2px);}
/* ── SIGNAL EDGE BARS ────────────────────────────────────────── */
.edge-bull{border-left:3px solid var(--green) !important;}
.edge-bear{border-left:3px solid var(--red) !important;}
.edge-neutral{border-left:3px solid var(--cyan) !important;}
.legend-item{transition:border-color .2s,background .2s;}
.legend-item:hover{border-color:var(--border2);background:var(--bg3);}
.sym-chip{cursor:default;transition:border-color .15s,background .15s;}
.sym-chip:hover{border-color:var(--cyan2);background:var(--bg2);}
.score-table tr:hover td{background:var(--row-border);}
/* ── FOOTER ──────────────────────────────────────────────── */
#footer{
  border-top:1px solid var(--border);padding:10px 20px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--dim);
  flex-wrap:wrap;gap:6px;position:relative;z-index:1;margin-top:4px;
}
/* ── TICKER BAR ──────────────────────────────────────────── */
.ticker-bar{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--border);
  position:relative;z-index:10;
}
/* ── FAST TABLE ──────────────────────────────────────────── */
.fast-table{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',monospace;font-size:.8rem;}
.fast-row{cursor:pointer;}
.fast-row:hover td{background:rgba(30,38,64,.6);}
.fast-row.expanded td{background:rgba(0,212,255,.04);border-bottom:none;}
/* ── DEEP CARD ───────────────────────────────────────────── */
.deep-row td{padding:0;background:var(--bg);}
.deep-row:hover td{background:var(--bg);}
.deep-card{padding:14px 18px;border-bottom:2px solid var(--border2);}
.deep-header{display:flex;gap:14px;align-items:baseline;margin-bottom:14px;flex-wrap:wrap;}
.deep-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0 18px;}
.deep-group{display:flex;flex-direction:column;}
.deep-group-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);padding:6px 0 4px;border-bottom:1px solid var(--border2);margin-bottom:2px;}
.deep-group-title.trend{color:var(--cyan);}
.deep-group-title.momentum{color:var(--green);}
.deep-group-title.volatility{color:var(--yellow);}
.deep-group-title.setup{color:var(--purple);}
.deep-row-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:3px;font-size:.83rem;}
.deep-row-item:nth-child(odd){background:var(--row-stripe);}
.deep-label{color:var(--text2);min-width:90px;flex-shrink:0;font-size:.79rem;}
.deep-value{font-weight:600;font-family:inherit;}
/* ── DIRECTION CHECKLIST ─────────────────────────────────── */
.dir-check{margin-top:12px;font-size:.74rem;}
.dir-check-item{padding:2px 0;}
.dir-check-item.met{color:var(--green);}
.dir-check-item.unmet{color:var(--red);}
/* ── BLOCKERS ────────────────────────────────────────────── */
.deep-blockers{
  margin-top:10px;background:rgba(255,215,0,.06);
  border-left:3px solid var(--yellow);padding:8px 12px;font-size:.74rem;
}
/* ── COLLAPSIBLE ─────────────────────────────────────────── */
.collapsible-toggle{cursor:pointer;user-select:none;}
.collapsible-toggle:hover{color:var(--cyan);}
.hidden{display:none !important;}
/* ── SCORE BADGE ─────────────────────────────────────────── */
.score-badge{padding:2px 7px;border-radius:4px;font-weight:700;font-size:.78rem;}
.score-badge.s-high{background:rgba(0,230,118,.15);color:var(--green);}
.score-badge.s-mid{background:rgba(255,215,0,.12);color:var(--yellow);}
.score-badge.s-low{background:rgba(255,26,75,.15);color:var(--red);}
/* ── REC BADGE ───────────────────────────────────────────── */
.rec-badge{padding:2px 8px;border-radius:4px;font-size:.76rem;font-weight:700;}
.rec-badge.bull{background:rgba(0,230,118,.15);color:var(--green);}
.rec-badge.warn{background:rgba(255,215,0,.12);color:var(--yellow);}
.rec-badge.bear{background:rgba(255,26,75,.15);color:var(--red);}
/* ── GRID BOT ADVISOR ────────────────────────────────────── */
.grid-risk-notice{border:1px solid var(--border2);border-radius:6px;background:var(--bg2);overflow:hidden;}
.grid-risk-notice summary{padding:11px 14px;font-size:.88rem;font-weight:700;color:var(--yellow);text-transform:uppercase;letter-spacing:.08em;}
.grid-risk-notice summary::-webkit-details-marker{display:none;}
.grid-risk-body{padding:11px 14px 14px;border-top:1px solid var(--border);}
.grid-risk-static div{font-size:.86rem;color:var(--text2);padding:4px 0;}
.grid-risk-dynamic{margin-top:9px;display:flex;flex-direction:column;gap:5px;}
.grid-risk-dynamic span{font-size:.86rem;padding:2px 0;}
.grid-bot-panel{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;margin-top:4px;}
.grid-card{background:var(--bg2);border:1px solid var(--border2);border-radius:8px;overflow:hidden;}
.grid-card-head{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02);}
.grid-ticker{font-weight:700;font-size:.96rem;letter-spacing:.1em;color:var(--white);}
.grid-price{font-family:'JetBrains Mono',monospace;font-size:.82rem;color:var(--cyan2);}
.grid-badge{padding:2px 9px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
.grid-badge.ok{background:rgba(0,230,118,.15);color:var(--green);}
.grid-badge.avoid{background:rgba(255,26,75,.15);color:var(--red);}
.grid-badge.caution{background:rgba(255,215,0,.13);color:var(--yellow);}
.grid-badge.dir-long{background:rgba(0,230,118,.10);color:var(--green);border:1px solid rgba(0,230,118,.25);}
.grid-badge.dir-short{background:rgba(255,26,75,.10);color:var(--red);border:1px solid rgba(255,26,75,.25);}
.grid-badge.dir-neutral{background:rgba(180,180,180,.08);color:var(--text2);border:1px solid rgba(180,180,180,.18);}
.grid-setup,.grid-drawdown,.grid-warnings,.grid-context{padding:10px 14px;border-top:1px solid var(--border);}
.grid-setup-title{font-size:.78rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.09em;margin-bottom:8px;}
.grid-context-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px 10px;}
.grid-ctx-item{display:flex;flex-direction:column;gap:2px;}
.grid-ctx-label{font-size:.60rem;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;}
.grid-ctx-val{font-family:'JetBrains Mono',monospace;font-size:.78rem;font-weight:500;}
@media(max-width:600px){.grid-context-grid{grid-template-columns:repeat(2,1fr);}}
.section-sub{font-size:.72rem;color:var(--text2);margin-top:5px;margin-bottom:4px;line-height:1.5;max-width:820px;}
.grid-active-signals{padding:10px 14px;border-top:1px solid var(--border);}
.gas-pills{display:flex;flex-wrap:wrap;gap:6px;}
.gas-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:4px;font-size:.72rem;background:rgba(255,255,255,.04);border:1px solid var(--border);}
.gas-pill.bull{border-color:rgba(0,230,118,.3);background:rgba(0,230,118,.07);}
.gas-pill.bear{border-color:rgba(255,26,75,.3);background:rgba(255,26,75,.07);}
.gas-pill.warn{border-color:rgba(255,215,0,.3);background:rgba(255,215,0,.07);}
.gas-name{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;font-size:.6rem;}
.gas-val{font-family:'JetBrains Mono',monospace;font-weight:500;}
.grid-params{display:flex;flex-direction:column;gap:5px;}
.grid-param-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.88rem;}
.grid-param-label{color:var(--text2);flex-shrink:0;margin-right:8px;}
.grid-param-val{font-family:'JetBrains Mono',monospace;font-size:.86rem;text-align:right;}
.grid-param-val em{font-style:normal;color:var(--text2);}
.grid-warnings{display:flex;flex-direction:column;gap:5px;}
.grid-warnings span{font-size:.86rem;}
.grid-checklist-text{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--text2);white-space:pre;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:9px 12px;margin-top:6px;overflow-x:auto;}
.grid-copy-btn{padding:2px 8px;font-size:.75rem;margin-left:8px;}
/* ── FULL METRICS TABLE: COMPACT MODE (hide 10 low-priority cols) ── */
/* Visible: Symbol Price RSI Flow% AVWAP-30d CVD-5d CVD-14d CVD-30d OI%-7d Str-4H Str-30d EMA-50 EMA-200 Conf FVG */
/* Hidden cols: 3=Fund% 5=ATR 7=POC-5d 8=POC-14d 9=AVWAP-5d 10=AVWAP-14d 15=OI-abs 21=Trend 23=Sweep 25=API */
.main-metrics-table th:nth-child(3),  .main-metrics-table td:nth-child(3),
.main-metrics-table th:nth-child(5),  .main-metrics-table td:nth-child(5),
.main-metrics-table th:nth-child(7),  .main-metrics-table td:nth-child(7),
.main-metrics-table th:nth-child(8),  .main-metrics-table td:nth-child(8),
.main-metrics-table th:nth-child(9),  .main-metrics-table td:nth-child(9),
.main-metrics-table th:nth-child(10), .main-metrics-table td:nth-child(10),
.main-metrics-table th:nth-child(15), .main-metrics-table td:nth-child(15),
.main-metrics-table th:nth-child(21), .main-metrics-table td:nth-child(21),
.main-metrics-table th:nth-child(23), .main-metrics-table td:nth-child(23),
.main-metrics-table th:nth-child(25), .main-metrics-table td:nth-child(25)
{ display: none; }
/* Show all when .expanded is toggled on */
.main-metrics-table.expanded th,
.main-metrics-table.expanded td
{ display: table-cell; }

/* ── MARKET PULSE PILLS ──────────────────────────────────────── */
.pulse-pill{padding:4px 12px;font-size:.84rem;gap:6px;}
.pulse-label{color:var(--dim);text-transform:uppercase;font-size:.72rem;letter-spacing:.05em;}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
/* ≤1024px — pulse pills wrap below logo row */
@media(max-width:1024px){
  .topbar-right{width:100%;justify-content:flex-start;}
}
/* ≤768px — tighten topbar padding, reduce pill sizes */
@media(max-width:768px){
  #topbar{padding:7px 14px;gap:6px;}
  .pulse-pill{font-size:.78rem;padding:3px 10px;}
  .pulse-label{font-size:.65rem;}
  .logo-mark{font-size:.95rem;}
  .logo-sub{display:none;}
}
/* ≤480px — single column stack, hide version pill */
@media(max-width:480px){
  #topbar{padding:6px 10px;gap:5px;}
  .version-pill{display:none;}
  .btn{padding:5px 10px;min-height:36px;font-size:.72rem;}
  .pulse-pill{font-size:.73rem;padding:3px 8px;}
}
/* ── MOTION SAFETY ───────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important;transform:none !important;}
}

/* ══════════════════════════════════════════════
   CIM v6 — Card Layout
   ══════════════════════════════════════════════ */

/* Section wrapper — mobile default: single column */
.cards-section {
  padding: 0 12px;
  margin-bottom: 32px;
}

/* Section header */
.section-header {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.section-header::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.section-header.cyan   { color: var(--cyan); }
.section-header.purple { color: var(--purple); }

/* Asset card */
.asset-card {
  background: rgba(16, 20, 40, 0.85);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: border-color .18s, background .18s;
  -webkit-tap-highlight-color: transparent;
}
.asset-card:active { background: rgba(16,20,40,1); }

/* Card color states */
.asset-card.card-bull  { border-color: rgba(0,230,118,.28); }
.asset-card.card-bear  { border-color: rgba(255,26,75,.28); }
.asset-card.card-avoid { border-color: rgba(255,215,0,.18); }
.asset-card.card-grid-ok   { border-color: rgba(0,230,118,.28); }
.asset-card.card-grid-warn { border-color: rgba(255,215,0,.28); }
.asset-card.card-grid-bad  { border-color: rgba(255,26,75,.18); }

/* Card header row */
.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.card-ticker {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .9rem;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: .06em;
}
.card-price {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  color: var(--text2);
  margin-top: 2px;
}
.card-meta {
  display: flex;
  align-items: center;
  gap: 7px;
}

/* Score ring */
.score-ring {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .86rem;
  font-weight: 700;
  flex-shrink: 0;
}
.score-ring.sr-high { border-color: var(--green); color: var(--green); }
.score-ring.sr-mid  { border-color: var(--yellow); color: var(--yellow); }
.score-ring.sr-low  { border-color: var(--red); color: var(--red); }

/* Indicator pills row */
.indicator-row {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-top: 7px;
}
.ind-pill {
  font-family: 'IBM Plex Mono', monospace;
  font-size: .6rem;
  padding: 2px 7px;
  border-radius: 3px;
  white-space: nowrap;
}
.ind-pill.p-bull    { color: var(--green);  background: rgba(0,230,118,.08);   border: 1px solid rgba(0,230,118,.22); }
.ind-pill.p-bear    { color: var(--red);    background: rgba(255,26,75,.08);   border: 1px solid rgba(255,26,75,.22); }
.ind-pill.p-warn    { color: var(--yellow); background: rgba(255,215,0,.08);   border: 1px solid rgba(255,215,0,.22); }
.ind-pill.p-purple  { color: var(--purple); background: rgba(179,136,255,.08); border: 1px solid rgba(179,136,255,.22); }
.ind-pill.p-neutral { color: var(--text2);   background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.12); }

/* Responsive: 2-col on tablet, 3-col on desktop */
@media (min-width: 640px) {
  .cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .cards-grid .asset-card { margin-bottom: 0; }
}
@media (min-width: 1024px) {
  .cards-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ══════════════════════════════════════════════
   CIM v6 — Bottom Sheet
   ══════════════════════════════════════════════ */

.sheet-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.sheet-backdrop.open {
  opacity: 1;
  pointer-events: all;
}

.bottom-sheet {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 72vh;
  background: rgba(10, 13, 28, 0.98);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px 18px 0 0;
  z-index: 101;
  transform: translateY(100%);
  transition: transform .28s cubic-bezier(0.32, 0.72, 0, 1);
  display: flex;
  flex-direction: column;
}
.bottom-sheet.open {
  transform: translateY(0);
}

.sheet-handle {
  width: 36px;
  height: 4px;
  background: #2a2f3e;
  border-radius: 2px;
  margin: 12px auto 8px;
  flex-shrink: 0;
}

.sheet-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--white);
  padding: 0 16px 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0;
}

#sheet-content {
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1;
  padding: 12px 16px 32px;
  -webkit-overflow-scrolling: touch;
}

/* Sheet detail table */
.sheet-table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .7rem;
}
.sheet-table td {
  padding: 5px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
  word-break: break-word;
  overflow-wrap: break-word;
}
.sheet-table td:first-child {
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: .04em;
  width: 45%;
}
.sheet-table td:last-child { text-align: right; }

.sheet-section-label {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cyan2);
  margin: 10px 0 4px;
}

.sheet-note {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  color: var(--text2);
  text-align: center;
  margin-top: 12px;
  font-style: italic;
}

/* Desktop: constrain sheet width */
@media (min-width: 640px) {
  .bottom-sheet {
    max-width: 760px;
    left: 50%;
    right: auto;
    transform: translateX(-50%) translateY(100%);
    border-radius: 18px 18px 0 0;
    height: 80vh;
    font-size: 1.05rem;
  }
  .bottom-sheet.open {
    transform: translateX(-50%) translateY(0);
  }
  .sheet-table { font-size: .78rem; }
  .sheet-table td { padding: 7px 0; }
}

/* Small inline badge for cards */
.badge-sm {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-family: 'Chakra Petch', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.badge-sm.green  { background: rgba(0,230,118,.15);  color: var(--green);  border: 1px solid rgba(0,230,118,.3); }
.badge-sm.red    { background: rgba(255,26,75,.15);   color: var(--red);    border: 1px solid rgba(255,26,75,.3); }
.badge-sm.yellow { background: rgba(255,215,0,.12);   color: var(--yellow); border: 1px solid rgba(255,215,0,.3); }
.badge-sm.cyan   { background: rgba(0,212,255,.12);   color: var(--cyan);   border: 1px solid rgba(0,212,255,.3); }
.badge-sm.purple { background: rgba(179,136,255,.12); color: var(--purple); border: 1px solid rgba(179,136,255,.3); }
