@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@300;400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap');

:root {
  --bg:#080a0e; --bg2:#0d1117; --bg3:#111820; --bg4:#161e28;
  --b1:#1e2a38; --b2:#2a3f55;
  --t1:#e2e8f0; --t2:#8899aa; --t3:#4a5568;
  --green:#00d084; --red:#ff4757; --orange:#ff8c00; --blue:#00aaff; --yellow:#ffd700;
  --mono:'IBM Plex Mono',monospace; --sans:'IBM Plex Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--t1);font-family:var(--mono);font-size:12px;overflow:hidden;height:100vh;width:100vw}
#app{display:flex;flex-direction:column;height:100vh}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;height:58px;background:var(--bg2);border-bottom:2px solid var(--green);padding:0 16px;flex-shrink:0}
.logo{font-size:13px;font-weight:600;letter-spacing:3px;color:var(--green)}
.ticker{display:flex;gap:20px;font-size:11px}
.ti{display:flex;gap:6px;align-items:center}
.tl{color:var(--t3)} .tv{font-weight:500}
.tc.up{color:var(--green)} .tc.down{color:var(--red)}
.clock{font-size:11px;color:var(--t2)}

/* LAYOUT */
.layout{display:flex;flex:1;overflow:hidden}
.sidebar{width:62px;background:var(--bg2);border-right:1px solid var(--b1);display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:1px;flex-shrink:0;overflow-y:auto}
.sidebar::-webkit-scrollbar{width:0}
.ni{width:56px;height:46px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;color:var(--t3);font-size:7px;gap:2px;transition:all .15s;border-left:2px solid transparent}
.ni:hover{background:var(--bg4);color:var(--t2)} .ni.active{background:var(--bg4);color:var(--green);border-left-color:var(--green)}
.ni img{opacity:1;transition:all .15s;filter:brightness(1)}
.ni svg{color:var(--t3);transition:color .15s}
.ni:hover svg{color:var(--t1)}
.ni.active svg{color:var(--green)}
.ni:hover img{opacity:1;filter:brightness(1.2)} .ni.active img{opacity:1;filter:brightness(1.4) drop-shadow(0 0 5px #00d084)}
.ni-icon{font-size:13px}
.content{flex:1;overflow:hidden;display:flex;flex-direction:column}
.tabbar{display:flex;align-items:center;height:30px;background:var(--bg2);border-bottom:1px solid var(--b1);padding:0 8px;gap:1px;flex-shrink:0;overflow-x:auto}
.tabbar::-webkit-scrollbar{height:0}
.tab{padding:0 10px;height:30px;display:flex;align-items:center;font-size:9px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.tab:hover{color:var(--t2)} .tab.active{color:var(--green);border-bottom-color:var(--green)}
.view{display:none;flex:1;overflow:hidden;flex-direction:column;min-height:0}
.view.active{display:flex}

/* PANELS */
.panel{background:var(--bg2);border:1px solid var(--b1);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}
.ph{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:1px solid var(--b1);background:var(--bg3);flex-shrink:0}
.pt{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--t2);font-weight:600}
.pb{font-size:8px;padding:1px 5px;border-radius:2px}
.pb.live{background:rgba(0,208,132,.1);color:var(--green);border:1px solid rgba(0,208,132,.3)}
.pb.macro{background:rgba(255,140,0,.1);color:var(--orange);border:1px solid rgba(255,140,0,.3)}
.pb.blue{background:rgba(0,170,255,.1);color:var(--blue);border:1px solid rgba(0,170,255,.3)}
.pbd{flex:1;overflow:auto;padding:8px}
.pbd::-webkit-scrollbar{width:3px} .pbd::-webkit-scrollbar-thumb{background:var(--b1)}
.sb{overflow-y:auto;max-height:230px}
.sb::-webkit-scrollbar{width:3px} .sb::-webkit-scrollbar-thumb{background:var(--b1)}
.s2{grid-column:span 2} .s3{grid-column:span 3}

/* DASHBOARD CUSTOM GRID */
.dash-grid{display:grid;gap:8px;align-content:start}
.dash-col-2{grid-template-columns:repeat(2,1fr)}
.dash-col-3{grid-template-columns:repeat(3,1fr)}
.dash-col-4{grid-template-columns:repeat(4,1fr)}
.dash-widget{background:var(--bg2);border:1px solid var(--b1);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;min-height:160px}
.dash-widget.w2{grid-column:span 2}
.dash-widget.w3{grid-column:span 3}
.dash-widget.w4{grid-column:span 4}
.dash-widget.tall{min-height:280px}
.dash-wh{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:1px solid var(--b1);background:var(--bg3);flex-shrink:0;cursor:default}
.dash-wh.dragging{cursor:grab}
.dash-wb{flex:1;overflow:auto;padding:8px}
.dash-wb::-webkit-scrollbar{width:3px} .dash-wb::-webkit-scrollbar-thumb{background:var(--b1)}
/* Edit mode */
.dash-edit .dash-widget{border-color:var(--green);border-style:dashed}
.dash-edit .dash-wh{cursor:grab;background:rgba(0,208,132,.08)}
.dash-controls{display:none;gap:4px;align-items:center}
.dash-edit .dash-controls{display:flex}
.dash-widget.drag-over{border-color:var(--green);background:rgba(0,208,132,.05)}

/* TABLES */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:9px;color:var(--t3);text-align:left;padding:3px 6px;border-bottom:1px solid var(--b1);font-weight:400;letter-spacing:1px}
.tbl td{padding:5px 6px;font-size:11px;border-bottom:1px solid rgba(30,42,56,.4)}
.tbl tr:hover td{background:var(--bg4)}
.up{color:var(--green)} .dn{color:var(--red)}
.bull{color:var(--green);font-size:10px} .bear{color:var(--red);font-size:10px} .neut{color:var(--t3);font-size:10px}

/* SENTIMENT BARS */
.srow{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.sbar{height:5px;background:var(--bg);border-radius:3px;overflow:hidden;display:flex}
.bl{background:var(--green);transition:width .8s} .bs{background:var(--red);transition:width .8s}

/* NEWS */
.nitem{padding:6px 0;border-bottom:1px solid var(--b1);cursor:pointer;transition:all .1s}
.nitem:hover{background:var(--bg4);padding-left:4px}
.nh{font-size:11px;color:var(--t1);line-height:1.4;margin-bottom:3px;font-family:var(--sans)}
.nm{display:flex;gap:8px;font-size:9px;color:var(--t3);align-items:center}
.ns{color:var(--blue)}
.ni2{padding:1px 5px;border-radius:2px;font-size:8px;letter-spacing:1px}
.ni2.high{background:rgba(255,71,87,.15);color:var(--red)}
.ni2.medium{background:rgba(255,140,0,.15);color:var(--orange)}
.ni2.low{background:rgba(0,170,255,.1);color:var(--blue)}

/* CB ITEMS */
.cbi{display:flex;justify-content:space-between;align-items:center;padding:5px 8px;border-radius:3px;margin-bottom:3px;background:var(--bg3);border:1px solid var(--b1)}
.cba{font-size:9px;padding:2px 5px;border-radius:2px}
.cba.hold{background:rgba(255,140,0,.15);color:var(--orange)}
.cba.cut{background:rgba(255,71,87,.15);color:var(--red)}
.cba.hike{background:rgba(0,208,132,.15);color:var(--green)}

/* MACRO ROW */
.mrow{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(30,42,56,.4)}

/* CB CARDS */
.ccard{background:var(--bg2);border:1px solid var(--b1);border-radius:4px;overflow:visible}
.cchead{padding:8px 12px;border-bottom:1px solid var(--b1);background:var(--bg3)}
.ccbody{padding:8px 12px}
.ccrow{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(30,42,56,.4);font-size:10px}
.probbar{height:4px;background:var(--bg);border-radius:2px;overflow:hidden;margin-top:6px}
.probfill{height:100%;border-radius:2px;transition:width .8s}

/* COT */
.cot-grid{padding:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:10px;overflow-y:auto;align-content:start;height:100%}
.cot-grid::-webkit-scrollbar{width:4px} .cot-grid::-webkit-scrollbar-thumb{background:var(--b1)}
.cotcard{background:var(--bg2);border:1px solid var(--b1);border-radius:4px;overflow:visible;min-width:0;height:fit-content}
.cothead{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--b1);background:var(--bg3)}
.cotbody{padding:0}
.cotbadge{font-size:8px;padding:2px 5px;border-radius:2px}
.cotbadge.bull{background:rgba(0,208,132,.1);color:var(--green);border:1px solid rgba(0,208,132,.3)}
.cotbadge.bear{background:rgba(255,71,87,.1);color:var(--red);border:1px solid rgba(255,71,87,.3)}
.cotbadge.neutral{background:rgba(136,153,170,.1);color:var(--t2);border:1px solid rgba(136,153,170,.2)}

/* FEAR GREED */
.fgrid{padding:10px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;overflow:auto;align-content:start}

/* SEASONALITY */
.seagrid{padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:10px;overflow-y:auto;align-content:start;height:100%}
.seagrid::-webkit-scrollbar{width:4px} .seagrid::-webkit-scrollbar-thumb{background:var(--b1)}

/* CONFLUENCE */
.conftable{width:100%;height:100%;border-collapse:collapse;table-layout:fixed}
.conftable th{font-size:11px;color:var(--t2);padding:0 10px;border-bottom:1px solid var(--b1);border-right:1px solid var(--b1);text-align:center;background:var(--bg3);position:sticky;top:0;z-index:2;letter-spacing:1px;font-weight:500;height:36px}
.conftable th:first-child{text-align:left;width:200px;position:sticky;left:0;z-index:3}
.conftable td{padding:0 8px;border-bottom:1px solid rgba(30,42,56,.4);border-right:1px solid rgba(30,42,56,.3);text-align:center;font-size:12px;height:44px}
.conftable td:first-child{text-align:left;font-size:12px;color:var(--t2);padding:0 14px;position:sticky;left:0;background:var(--bg2);z-index:1;font-weight:500}
.conftable tr.sh td{background:var(--bg3);color:var(--t2);font-size:10px;letter-spacing:2px;padding:0 14px;font-weight:700;height:32px}
.conftable tr.overall td{background:var(--bg3);font-weight:700;font-size:13px;height:48px}
.bvb{background:#1a4d2e;color:var(--green);border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap;font-weight:600}
.bb{background:#1a3a2a;color:#4ade80;border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}
.bn{background:#2a2a14;color:var(--yellow);border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}
.bbe{background:#3a1a1a;color:#ff8c69;border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}
.bvbe{background:#4d1a1a;color:var(--red);border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap;font-weight:600}
.bup{background:#1a2a3a;color:var(--blue);border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}
.bdn{background:#2a1a2a;color:#c084fc;border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}
.brg{background:#1a1a2a;color:var(--t2);border-radius:4px;padding:4px 8px;font-size:11px;white-space:nowrap}

/* PERF */
.perfgrid{padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:10px;overflow-y:auto;align-content:start}
.perfgrid::-webkit-scrollbar{width:4px} .perfgrid::-webkit-scrollbar-thumb{background:var(--b1)}
.strbar{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid rgba(30,42,56,.4)}
.strtrack{flex:1;height:5px;background:var(--bg);border-radius:3px;overflow:hidden}
.strfill{height:100%;border-radius:3px;transition:width .8s}

/* MULTI CHARTS */
.mcpage{flex:1;overflow:hidden;display:flex;flex-direction:column}
.mccontrols{padding:5px 10px;border-bottom:1px solid var(--b1);background:var(--bg2);display:flex;gap:6px;align-items:center;flex-shrink:0;flex-wrap:wrap}
.mcgrid{flex:1;display:grid;overflow:hidden}
.mcgrid.g22{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.mcgrid.g24{grid-template-columns:repeat(4,1fr);grid-template-rows:1fr 1fr}
.mcgrid.g33{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}
.mccell{border:1px solid var(--b1);display:flex;flex-direction:column;overflow:hidden}
.mcch{padding:3px 8px;background:var(--bg3);border-bottom:1px solid var(--b1);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.mccb{flex:1}

/* CURRENCY INDEX */
.cipage{flex:1;overflow:hidden;display:flex;flex-direction:column}
.cigrid{flex:1;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr 1fr;overflow:hidden}

/* CALENDAR */
.calpage{padding:10px;flex:1;overflow:hidden;display:flex;flex-direction:column;gap:8px}
.calfilters{display:flex;gap:5px;align-items:center;flex-shrink:0;flex-wrap:wrap}
.calscroll{overflow-y:auto;flex:1}
.calscroll::-webkit-scrollbar{width:4px} .calscroll::-webkit-scrollbar-thumb{background:var(--b1)}
.caltbl{width:100%;border-collapse:collapse}
.caltbl th{font-size:9px;color:var(--t3);text-align:left;padding:4px 8px;border-bottom:1px solid var(--b1);font-weight:400;letter-spacing:1px;position:sticky;top:0;background:var(--bg2);z-index:1}
.caltbl td{padding:6px 8px;font-size:11px;border-bottom:1px solid rgba(30,42,56,.4)}
.caltbl tr:hover td{background:var(--bg4)}
.daysep td{background:var(--bg3);color:var(--t2);font-size:9px;letter-spacing:2px;padding:3px 8px}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.dot.high{background:var(--red)} .dot.medium{background:var(--orange)} .dot.low{background:var(--t3)}

/* MACRO PAGE */
.macrogrid{padding:10px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;overflow:auto}
.macrogrid::-webkit-scrollbar{width:4px} .macrogrid::-webkit-scrollbar-thumb{background:var(--b1)}

/* BUTTONS */
.btn{padding:2px 8px;font-size:9px;font-family:var(--mono);border:1px solid var(--b1);background:transparent;color:var(--t3);cursor:pointer;border-radius:3px;transition:all .15s;letter-spacing:1px}
.btn:hover{color:var(--t2);border-color:var(--b2)}
.btn.active{border-color:var(--green);color:var(--green);background:rgba(0,208,132,.05)}
.btn.ora.active{border-color:var(--orange);color:var(--orange);background:rgba(255,140,0,.05)}

/* SEARCH INPUT */
.search-input{background:var(--bg3);border:1px solid var(--b1);border-radius:3px;color:var(--t1);font-family:var(--mono);font-size:10px;padding:4px 8px;outline:none}
.search-input:focus{border-color:var(--green)}

/* UTILS */
.loading{display:flex;align-items:center;justify-content:center;height:60px;color:var(--t3);font-size:10px;letter-spacing:2px}
.loading::after{content:'';width:10px;height:10px;border:1px solid var(--b1);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite;margin-left:8px}
@keyframes spin{to{transform:rotate(360deg)}}
.err{color:var(--red);font-size:10px;padding:8px;text-align:center}
.sdot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(0,208,132,.4)}50%{opacity:.8;box-shadow:0 0 0 4px rgba(0,208,132,0)}}

.ps-card{background:var(--bg2);border:1px solid var(--b1);border-radius:8px;padding:14px}
.ps-title{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--t2)}
