/* ===== Gate ===== */
#gate{position:fixed;inset:0;background:var(--bg-grad);display:grid;place-items:center;z-index:9999;}
.gate-box{
  background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--border);border-radius:var(--r-xl);padding:44px 40px;width:360px;text-align:center;box-shadow:var(--shadow-lg);
}
.gate-logo{width:56px;height:56px;border-radius:16px;margin:0 auto 18px;display:grid;place-items:center;font-size:26px;
  background:linear-gradient(135deg,var(--accent),#7b5cff);box-shadow:0 10px 30px -8px var(--accent);}
.gate-title{font-size:20px;font-weight:800;letter-spacing:-.3px;}
.gate-sub{color:var(--muted);font-size:13px;margin:6px 0 26px;}
.gate-input{width:100%;padding:13px 16px;border-radius:11px;border:1px solid var(--border);background:var(--bg);
  color:var(--text);font-size:15px;outline:none;text-align:center;letter-spacing:3px;transition:.15s;}
.gate-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.gate-btn{width:100%;margin-top:12px;padding:13px;border-radius:11px;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--accent),#6f7bff);color:#fff;font:700 14px var(--font);transition:.15s;}
.gate-btn:hover{filter:brightness(1.08);}
.gate-btn:disabled{opacity:.6;cursor:default;}
.gate-err{color:var(--red);font-size:12px;margin-top:12px;display:none;}

/* ===== Cards ===== */
.card{
  background:linear-gradient(180deg,var(--surface-2),var(--surface));
  border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s5);position:relative;box-shadow:var(--shadow);
}
.card.tight{padding:var(--s4);}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4);gap:var(--s3);}
.card-title{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center;gap:7px;}
.card-title .ic{font-size:14px;}

/* grids */
.grid{display:grid;gap:var(--s4);margin-bottom:var(--s4);}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
.g6{grid-template-columns:repeat(6,1fr);}
.span2{grid-column:span 2;}
.span3{grid-column:span 3;}
.span4{grid-column:span 4;}
@media(max-width:1100px){.g4{grid-template-columns:repeat(2,1fr);}.g6{grid-template-columns:repeat(3,1fr);}.g3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:820px){
  .g2,.g3,.g4{grid-template-columns:1fr;}.g6{grid-template-columns:repeat(2,1fr);}
  .span2,.span3,.span4{grid-column:auto;}
}

/* ===== KPI ===== */
.kpi{display:flex;flex-direction:column;gap:6px;}
.kpi-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px;}
.kpi-val{font-size:26px;font-weight:800;letter-spacing:-.6px;line-height:1;}
.kpi-val.sm{font-size:21px;}
.kpi-sub{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;}
.kpi-spark{position:absolute;right:14px;bottom:12px;width:96px;height:34px;opacity:.9;pointer-events:none;}
.hero{background:
   radial-gradient(600px 200px at 100% 0%, var(--accent-soft), transparent 70%),
   linear-gradient(180deg,var(--surface-2),var(--surface));}
.hero .kpi-val{font-size:34px;}

/* pills / badges */
.pill{display:inline-flex;align-items:center;gap:4px;font:700 11px var(--mono);padding:3px 8px;border-radius:20px;line-height:1;}
.pill.up{background:var(--green-soft);color:var(--green);}
.pill.down{background:var(--red-soft);color:var(--red);}
.pill.flat{background:var(--surface-3);color:var(--muted);}
.badge{display:inline-flex;align-items:center;font:700 9px var(--font);letter-spacing:.4px;padding:2px 6px;border-radius:5px;text-transform:uppercase;}
.badge.div{background:#f5b23d22;color:var(--yellow);}
.badge.ai{background:#26c28122;color:var(--green);}
.badge.mgd{background:#a06bff22;color:var(--purple);}
.badge.fifo{background:#4f8cff22;color:var(--accent);}
.tag{font:600 10px var(--font);color:var(--faint);background:var(--surface-3);padding:2px 7px;border-radius:6px;}

.up-t{color:var(--green);}.down-t{color:var(--red);}.flat-t{color:var(--muted);}

/* progress bar */
.bar{height:6px;border-radius:6px;background:var(--surface-3);overflow:hidden;}
.bar>span{display:block;height:100%;border-radius:6px;background:var(--accent);}

/* ===== Tables ===== */
.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.tbl th{
  text-align:right;font:700 10.5px var(--font);color:var(--faint);text-transform:uppercase;letter-spacing:.5px;
  padding:8px 12px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);cursor:pointer;user-select:none;white-space:nowrap;
}
.tbl th:first-child{text-align:left;}
.tbl th.sorted{color:var(--accent);}
.tbl th .arw{font-size:9px;margin-left:3px;}
.tbl td{padding:11px 12px;text-align:right;border-bottom:1px solid var(--border);white-space:nowrap;}
.tbl td:first-child{text-align:left;}
.tbl tbody tr{cursor:pointer;transition:.12s;}
.tbl tbody tr:hover{background:var(--surface-3);}
.sym{display:flex;align-items:center;gap:9px;}
.sym .av{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font:800 11px var(--font);color:#fff;flex-shrink:0;}
.sym .nm{font-weight:700;font-size:13.5px;}
.sym .meta{font-size:11px;color:var(--faint);}

/* holdings mobile cards */
.hcards{display:none;flex-direction:column;gap:8px;}
.hcard{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:13px 14px;cursor:pointer;}
.hcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.hcard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.hcard-cell .l{font-size:9.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;}
.hcard-cell .v{font-size:13.5px;font-weight:600;}
@media(max-width:820px){.tbl-wrap{display:none;}.hcards{display:flex;}}

/* chips / segmented */
.seg{display:inline-flex;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:3px;}
.seg button{border:none;background:transparent;color:var(--muted);font:600 11.5px var(--font);padding:5px 11px;border-radius:6px;cursor:pointer;transition:.15s;}
.seg button.active{background:var(--surface-3);color:var(--text);}

/* movers list */
.row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);}
.row:last-child{border-bottom:none;}
.row .r-l{display:flex;align-items:center;gap:9px;}
.row .r-r{text-align:right;}

/* chart holders */
.chart-h{position:relative;width:100%;}
.spark{width:100%;height:40px;display:block;}

/* drawer */
.drawer-ov{position:fixed;inset:0;background:#000a;backdrop-filter:blur(3px);z-index:200;opacity:0;transition:.2s;}
.drawer-ov.show{opacity:1;}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(460px,94vw);z-index:201;
  background:linear-gradient(180deg,var(--surface-2),var(--surface));border-left:1px solid var(--border-strong);
  box-shadow:var(--shadow-lg);transform:translateX(100%);transition:.25s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding:var(--s5);}
.drawer.show{transform:none;}
.drawer-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:9px;border:1px solid var(--border);
  background:var(--surface-3);color:var(--muted);cursor:pointer;font-size:16px;}
.drawer-close:hover{color:var(--text);}

/* misc */
.muted{color:var(--muted);}.faint{color:var(--faint);}
.empty{color:var(--faint);text-align:center;padding:30px;font-size:13px;}
.divider{height:1px;background:var(--border);margin:var(--s4) 0;}
.stat-line{display:flex;justify-content:space-between;padding:7px 0;font-size:13px;border-bottom:1px solid var(--border);}
.stat-line:last-child{border:none;}
.stat-line .k{color:var(--muted);}
.stat-line .v{font-weight:700;font-variant-numeric:tabular-nums;}
.soon{display:grid;place-items:center;min-height:50vh;text-align:center;color:var(--faint);gap:10px;}
.soon .big{font-size:40px;}

/* refresh modal */
.modal-ov{position:fixed;inset:0;background:#000b;backdrop-filter:blur(4px);z-index:300;display:grid;place-items:center;padding:20px;}
.modal{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:var(--r-lg);
  padding:26px;width:min(440px,94vw);box-shadow:var(--shadow-lg);}
.modal h3{font-size:16px;margin-bottom:6px;}
.modal p{color:var(--muted);font-size:13px;margin-bottom:14px;line-height:1.5;}
.step{display:flex;align-items:center;gap:9px;padding:8px 0;font-size:13px;color:var(--muted);}
.step.active{color:var(--text);}.step.done{color:var(--green);}.step.err{color:var(--red);}
.code-box{background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:11px 13px;font:500 12px var(--mono);
  color:var(--accent);margin-bottom:14px;user-select:all;white-space:pre-wrap;word-break:break-word;}
.btn{padding:10px 14px;border-radius:9px;border:1px solid var(--border);background:var(--surface-3);color:var(--text);
  font:600 13px var(--font);cursor:pointer;transition:.15s;}
.btn:hover{border-color:var(--border-strong);}
.btn.primary{background:linear-gradient(135deg,var(--accent),#6f7bff);border:none;color:#fff;}
.btn.primary:hover{filter:brightness(1.08);}
textarea.paste{width:100%;height:96px;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:10px;
  color:var(--text);font:500 12px var(--mono);resize:vertical;}

/* heatmap */
.heat{display:grid;gap:5px;}
.heat-cell{border-radius:8px;padding:9px 10px;display:flex;flex-direction:column;gap:3px;min-height:58px;justify-content:center;}
.heat-cell .hs{font-weight:800;font-size:13px;}
.heat-cell .hp{font:700 11px var(--mono);}
