:root {
  --blue:#1a56db;--blue2:#1e429f;--blue3:#e8f0fe;--blue4:#dbeafe;
  --green:#057a55;--green-bg:#def7ec;--red:#c81e1e;--red-bg:#fde8e8;
  --amber:#92400e;--amber-bg:#fef3c7;--gray:#6b7280;--gray2:#f3f4f6;
  --bg:#f8fafc;--card:#fff;--text:#111827;--text2:#374151;--text3:#6b7280;
  --border:#e5e7eb;--shadow:0 1px 3px rgba(0,0,0,.1);--shadow2:0 4px 12px rgba(0,0,0,.08);
  --radius:12px;--radius-sm:8px;
}
[data-theme=dark]{
  --bg:#0f172a;--card:#1e293b;--text:#f1f5f9;--text2:#cbd5e1;--text3:#94a3b8;
  --border:#334155;--gray2:#1e293b;--blue3:#1e3a5f;--blue4:#1e3a5f;
  --green-bg:#064e3b;--red-bg:#7f1d1d;--amber-bg:#78350f;
  --shadow:0 1px 3px rgba(0,0,0,.4);--shadow2:0 4px 12px rgba(0,0,0,.3);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .2s,color .2s}

/* ── HEADER ── */
.header{background:linear-gradient(135deg,var(--blue2) 0%,var(--blue) 100%);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.header-left{display:flex;align-items:center;gap:12px}
.logo{width:36px;height:36px;background:rgba(255,255,255,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px}
.header-title{color:#fff;font-size:18px;font-weight:700;letter-spacing:-.3px}
.header-sub{color:rgba(255,255,255,.7);font-size:12px;margin-top:1px}
.header-right{display:flex;align-items:center;gap:10px}
.btn-icon{background:rgba(255,255,255,.15);border:none;color:#fff;border-radius:8px;padding:8px 10px;cursor:pointer;font-size:14px;transition:background .15s;display:flex;align-items:center;gap:6px}
.btn-icon:hover{background:rgba(255,255,255,.25)}
.refresh-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.last-updated{color:rgba(255,255,255,.6);font-size:11px}

/* ── TABS (now anchor links — multi-page nav) ── */
.tabs-wrap{background:var(--card);border-bottom:1px solid var(--border);padding:0 24px;position:sticky;top:68px;z-index:99}
.tabs{display:flex;gap:0;overflow-x:auto}
.tab{padding:14px 20px;font-size:14px;font-weight:500;color:var(--text3);cursor:pointer;border-bottom:3px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:8px;text-decoration:none}
.tab:hover{color:var(--text)}
.tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-badge{font-size:11px;background:var(--blue3);color:var(--blue);border-radius:10px;padding:1px 6px;font-weight:600}
.tab-dot{width:8px;height:8px;border-radius:50%}

/* ── LAYOUT ── */
.page{padding:24px;max-width:1400px;margin:0 auto}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.grid4,.grid3{grid-template-columns:1fr 1fr}.grid2{grid-template-columns:1fr}}
@media(max-width:600px){.grid4,.grid3,.grid2{grid-template-columns:1fr}}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-size:13px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.card-icon{font-size:20px}

/* ── STAT CARDS ── */
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent,var(--blue))}
.stat-label{font-size:12px;color:var(--text3);font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.stat-value{font-size:28px;font-weight:700;color:var(--text);line-height:1;margin-bottom:4px}
.stat-value.sm{font-size:22px}
.stat-sub{font-size:12px;color:var(--text3)}
.stat-change{font-size:13px;font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:3px;border-radius:6px;padding:3px 8px}
.stat-change.up{color:var(--green);background:var(--green-bg)}
.stat-change.dn{color:var(--red);background:var(--red-bg)}
.stat-change.neu{color:var(--amber);background:var(--amber-bg)}

/* ── BROKER HEADER CARDS ── */
.broker-card{background:linear-gradient(135deg,var(--card-from,#1a56db),var(--card-to,#1e429f));border-radius:var(--radius);padding:20px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow2)}
.broker-card::after{content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.08)}
.broker-name{font-size:12px;opacity:.8;font-weight:500;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.broker-balance{font-size:32px;font-weight:800;margin-bottom:2px;letter-spacing:-1px}
.broker-stats{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap}
.broker-stat{font-size:12px;opacity:.85}
.broker-stat strong{font-weight:700}
.broker-live{background:rgba(255,255,255,.2);border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:13px}
th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;background:var(--gray2);border-bottom:1px solid var(--border)}
td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--blue3)}
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}
.pill.win{background:var(--green-bg);color:var(--green)}
.pill.loss{background:var(--red-bg);color:var(--red)}
.pill.pending{background:var(--amber-bg);color:var(--amber)}
.pill.signal{background:var(--blue4);color:var(--blue)}
.pill.abandoned{background:var(--gray2);color:var(--text3)}
.dir-call{color:#057a55;font-weight:600;font-size:11px}
.dir-put{color:#c81e1e;font-weight:600;font-size:11px}
.profit-pos{color:#057a55;font-weight:600}
.profit-neg{color:#c81e1e;font-weight:600}

/* ── OPEN POSITIONS ── */
.position-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.position-row:last-child{border-bottom:none}
.pos-symbol{font-weight:700;font-size:14px}
.pos-meta{font-size:11px;color:var(--text3);margin-top:2px}
.pos-pnl{font-size:16px;font-weight:700;text-align:right}
.pos-live{font-size:11px;text-align:right;margin-top:2px}

/* ── CHART ── */
.chart-wrap{position:relative;height:220px}
.chart-wrap.tall{height:280px}

/* ── COMBINED FEED ── */
.feed-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.feed-item:last-child{border-bottom:none}
.feed-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.feed-icon.bo{background:#dbeafe;color:#1a56db}
.feed-icon.fx{background:#d1fae5;color:#065f46}
.feed-icon.qx{background:#ede9fe;color:#5b21b6}
.feed-content{flex:1;min-width:0}
.feed-title{font-size:13px;font-weight:600;color:var(--text)}
.feed-sub{font-size:11px;color:var(--text3);margin-top:2px}
.feed-pnl{font-size:13px;font-weight:700;text-align:right;white-space:nowrap}
.feed-time{font-size:10px;color:var(--text3);text-align:right;margin-top:2px}

/* ── STATUS ── */
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.status-badge.online{background:#d1fae5;color:#065f46}
.status-badge.offline{background:#fde8e8;color:#c81e1e}
.status-badge.demo{background:var(--blue4);color:var(--blue2)}

/* ── SECTION TITLE ── */
.section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.section-title small{font-size:12px;font-weight:400;color:var(--text3)}

/* ── LOADING ── */
.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--gray2) 50%,var(--border) 75%);background-size:200%;animation:shimmer 1.5s infinite;border-radius:4px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.loading-text{height:20px;width:80px;display:inline-block}
.empty{text-align:center;padding:32px;color:var(--text3);font-size:13px}
.error-banner{background:#fde8e8;color:#c81e1e;padding:10px 16px;border-radius:8px;font-size:13px;margin-bottom:12px;border:1px solid #fca5a5}

/* ── RISK BAR ── */
.risk-bar-wrap{margin-top:8px}
.risk-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text3);margin-bottom:4px}
.risk-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.risk-bar-fill{height:100%;border-radius:3px;transition:width .5s}
.risk-bar-fill.safe{background:#10b981}
.risk-bar-fill.warn{background:#f59e0b}
.risk-bar-fill.danger{background:#ef4444}

/* ── MISC ── */
.divider{height:1px;background:var(--border);margin:20px 0}
.flex-row{display:flex;align-items:center;gap:8px}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt20{margin-top:20px}
.gap8{gap:8px}

/* ── MOBILE ── */
@media(max-width:600px){
  .header{padding:10px 14px;gap:8px}
  .header-sub{display:none}
  .last-updated{display:none}
  .header-title{font-size:15px}
  .logo{width:30px;height:30px;font-size:16px}
  .btn-icon{padding:7px 9px;font-size:13px}

  .tabs-wrap{padding:0 8px;top:56px}
  .tab{padding:11px 12px;font-size:12px;gap:4px}

  .page{padding:12px}
  .card{padding:14px}
  .stat-card{padding:14px}
  .broker-card{padding:16px}

  .broker-balance{font-size:26px;letter-spacing:-.5px}
  .stat-value{font-size:24px}
  .stat-value.sm{font-size:19px}
  .broker-stats{gap:10px}

  .chart-wrap{height:180px}
  .chart-wrap.tall{height:210px}

  th,td{padding:9px 10px;font-size:12px}

  .feed-icon{width:28px;height:28px;font-size:12px}
  .feed-title{font-size:12px}
}

@media(max-width:380px){
  .broker-balance{font-size:22px}
  .tab{padding:10px 9px;font-size:11px}
  .page{padding:8px}
}
@media(max-width:480px){.hide-xs{display:none}}
