/* ============================================================
   慧盈智策 v16.4 · 高端量化平台视觉系统
   深空科技 · 玻璃拟态 · 霓虹数据 · 多维图表
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* 背景层 */
  --bg-void:#060914;
  --bg-deep:#0a0f1f;
  --bg-base:#0d1426;
  --bg-elev:#131c33;
  --bg-elev2:#1a2645;
  /* 玻璃 */
  --glass:rgba(20,30,56,.55);
  --glass-brd:rgba(86,156,255,.16);
  --glass-brd-hot:rgba(0,212,255,.40);
  /* 文字 */
  --txt:#e8eeff;
  --txt-2:#9fb0d4;
  --txt-3:#5d6e94;
  /* 主题 */
  --cyan:#00d4ff;
  --blue:#3b82f6;
  --indigo:#6366f1;
  --violet:#8b5cf6;
  --gold:#fbbf24;
  /* 涨跌（中国习惯） */
  /* 涨跌（中国习惯: 红涨绿跌） */
  --up:#ff4d6d;
  --up-soft:rgba(255,77,109,.12);
  --down:#00e88f;
  --down-soft:rgba(0,232,143,.12);
  --flat:#8a9bbf;
  /* 效果 */
  --glow-cyan:0 0 24px rgba(0,212,255,.35);
  --glow-up:0 0 18px rgba(255,77,109,.45);
  --glow-down:0 0 18px rgba(0,232,143,.45);
  --rad:14px;
  --rad-sm:9px;
  --rad-lg:20px;
  --mono:'JetBrains Mono','SF Mono','Roboto Mono',ui-monospace,monospace;
  --sans:'Inter',-apple-system,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
  /* === 旧版兼容变量 (映射到新色系) === */
  --text-primary:var(--txt);--text-secondary:var(--txt-2);--text-muted:var(--txt-3);
  --accent:var(--blue);--accent-hover:#2563eb;--accent-cyan:var(--cyan);--accent-amber:var(--gold);
  --gold:#fbbf24;--silver:#94a3b8;--bronze:#b45309;--success:#4ade80;--danger:var(--down);--info:var(--cyan);--white:#fff;
  --bg-card:rgba(20,30,56,.55);--bg-card-hover:rgba(26,38,69,.75);--bg-primary:var(--bg-base);--bg-secondary:var(--bg-elev);--bg-elevated:var(--bg-elev2);
  --border:rgba(86,156,255,.12);--border-strong:rgba(0,212,255,.2);
  --radius-xs:3px;--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:16px;--radius-full:9999px;
  --space-xs:.25rem;--space-sm:.5rem;--space-md:.75rem;--space-lg:1rem;--space-xl:1.5rem;--space-2xl:2rem;
  --sidebar-w:270px;--topbar-h:48px;--transition:all .2s;--shadow-card:0 8px 32px rgba(0,0,0,.35);--font-family:var(--sans);
  --accent-rgb:59,130,246;--cyan-rgb:0,212,255;--amber-rgb:251,191,36;--up-rgb:255,77,109;--down-rgb:0,232,143;
  --silver-rgb:148,163,184;--bronze-rgb:180,83,9;--success-rgb:74,222,128;--deep-rgb:6,9,20;--primary-rgb:13,20,38;--white-rgb:255,255,255;--black-rgb:0,0,0;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg-void);color:var(--txt);
  font-size:14px;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
/* 动态网格背景 */
body::before{
  content:'';position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 80% 50% at 20% 0%,rgba(59,130,246,.10),transparent 60%),
    radial-gradient(ellipse 60% 50% at 100% 100%,rgba(139,92,246,.08),transparent 55%),
    linear-gradient(180deg,var(--bg-void),var(--bg-deep) 40%,var(--bg-void));
}
body::after{
  content:'';position:fixed;inset:0;z-index:-1;opacity:.4;pointer-events:none;
  background-image:linear-gradient(rgba(86,156,255,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(86,156,255,.04) 1px,transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(ellipse 100% 80% at 50% 30%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 100% 80% at 50% 30%,#000,transparent 75%);
}

/* 滚动条 */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(86,156,255,.25);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(0,212,255,.45)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}

/* ===== 数字等宽 ===== */
.num,.num *{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.02em}

/* ===== 侧边栏 ===== */
.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:270px;z-index:100;
  background:linear-gradient(180deg,rgba(13,20,38,.95),rgba(6,9,20,.97));
  border-right:1px solid var(--glass-brd);
  backdrop-filter:blur(24px);display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.sidebar-brand{display:flex;align-items:center;gap:14px;padding:24px 22px 20px;border-bottom:1px solid rgba(86,156,255,.08)}
.brand-logo{width:48px;height:48px;border-radius:12px;
  box-shadow:0 0 24px rgba(0,212,255,.5),0 0 8px rgba(0,212,255,.2);object-fit:cover}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-name{font-size:18px;font-weight:800;letter-spacing:.5px;
  background:linear-gradient(90deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-sub{font-size:10px;color:var(--txt-3);letter-spacing:1.5px;text-transform:uppercase}
.sidebar-nav{flex:1;padding:8px 12px;overflow-y:auto}
.nav-item{
  display:flex;align-items:center;gap:14px;padding:13px 14px;margin:3px 0;border-radius:12px;
  color:var(--txt-2);font-size:14px;font-weight:600;position:relative;transition:all .25s;
}
.nav-item .nav-icon{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.nav-item .nav-icon svg{width:26px;height:26px;fill:none}
.nav-item:hover{background:var(--glass);color:var(--txt);transform:translateX(3px)}
.nav-item:hover .nav-icon svg{stroke:var(--cyan);filter:drop-shadow(0 0 6px rgba(0,212,255,.4))}
.nav-item.active{background:linear-gradient(90deg,rgba(0,212,255,.18),rgba(59,130,246,.06));color:#fff;font-weight:700}
.nav-item.active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 4px 4px 0;
  background:var(--cyan);box-shadow:0 0 12px rgba(0,212,255,.6)}
.nav-item.active .nav-icon svg{stroke:var(--cyan);filter:drop-shadow(0 0 8px rgba(0,212,255,.5))}
.nav-hot{font-size:9px;font-weight:800;padding:2px 7px;border-radius:8px;background:linear-gradient(135deg,#ff4d6d,#ff6b81);color:#fff;letter-spacing:.5px;margin-left:auto}
.sidebar-footer{padding:16px 16px;border-top:1px solid var(--glass-brd);display:flex;align-items:center;gap:12px}
.sidebar-footer .user-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:15px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06122a;flex-shrink:0}
.sidebar-footer .user-info{display:flex;flex-direction:column;flex:1;min-width:0}
.sidebar-footer .user-name{font-size:13px;font-weight:600;color:var(--txt);line-height:1.2}
.sidebar-footer .user-role{font-size:10px;color:var(--txt-muted);letter-spacing:.5px}
.logout-btn{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  color:var(--txt-3);transition:all .2s;flex-shrink:0}
.logout-btn:hover{background:rgba(255,77,109,.15);color:var(--down)}
.sidebar-overlay{display:none}
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}
}

/* ===== 主内容 ===== */
.main-content{margin-left:248px;min-height:100vh;transition:margin .35s}
@media(max-width:1024px){.main-content{margin-left:0}}
.topbar{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:16px;padding:14px 26px;
  background:rgba(10,15,31,.72);backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-brd);
}
.topbar-left{display:flex;align-items:center;gap:14px;flex:1}
.sidebar-toggle{display:none;width:38px;height:38px;border-radius:10px;align-items:center;justify-content:center;
  background:var(--glass);border:1px solid var(--glass-brd);color:var(--txt-2)}
@media(max-width:1024px){.sidebar-toggle{display:flex}}
.page-title{font-size:18px;font-weight:700;letter-spacing:.3px}
.topbar-search{flex:1;max-width:420px;position:relative;display:flex;align-items:center}
.topbar-search input{
  width:100%;padding:10px 16px 10px 40px;border-radius:11px;border:1px solid var(--glass-brd);
  background:var(--glass);color:var(--txt);font-size:13.5px;transition:all .2s}
.topbar-search input::placeholder{color:var(--txt-3)}
.topbar-search input:focus{outline:none;border-color:var(--glass-brd-hot);box-shadow:0 0 0 3px rgba(0,212,255,.12)}
.topbar-search svg{position:absolute;left:13px;width:16px;height:16px;color:var(--txt-3);pointer-events:none}
.search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-elev);
  border:1px solid var(--glass-brd);border-radius:11px;max-height:360px;overflow-y:auto;z-index:200;
  box-shadow:0 16px 48px rgba(0,0,0,.5);display:none}
.search-results.show{display:block}
.search-item{padding:11px 16px;display:flex;justify-content:space-between;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(86,156,255,.06)}
.search-item:hover{background:var(--glass)}
.search-item .si-code{font-family:var(--mono);color:var(--cyan);font-size:13px}
.search-item .si-name{color:var(--txt-2);font-size:13px}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--up);box-shadow:var(--glow-up);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.market-time{font-family:var(--mono);font-size:12px;color:var(--txt-3);white-space:nowrap}

/* ===== 页面容器 ===== */
.page{display:none;animation:fadeUp .4s ease;padding:24px 26px 60px}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ===== 卡片 / 面板 (玻璃拟态) — 唯一权威定义 ===== */
.card,.panel{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--rad);
  backdrop-filter:blur(14px);position:relative;overflow:hidden;
  padding:16px 18px;margin-bottom:14px;
  transition:border-color .3s ease,box-shadow .3s ease;
}
.card::before,.panel::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;z-index:1;
  background:linear-gradient(90deg,transparent,rgba(0,212,255,.45),transparent);
}
.card:hover,.panel:hover{
  border-color:rgba(0,212,255,.25);
  box-shadow:0 10px 40px rgba(0,0,0,.3);
}
/* 卡片标题区（带分隔线） */
.card-h{
  display:flex;align-items:center;justify-content:space-between;
  margin:-16px -18px 14px;padding:13px 18px;
  border-bottom:1px solid rgba(86,156,255,.10);
}
/* 卡片标题 — 唯一权威定义 */
.card-title{
  font-size:13px;font-weight:700;color:var(--txt);
  display:flex;align-items:center;gap:8px;letter-spacing:.3px;
}
.card-title .ct-bar{
  width:3px;height:14px;border-radius:2px;
  background:linear-gradient(180deg,var(--cyan),var(--blue));
  box-shadow:var(--glow-cyan);flex-shrink:0;
}
/* 自动装饰条：没有手动ct-bar的card-title用伪元素添加 */
.card-title:not(:has(.ct-bar))::before{
  content:'';width:3px;height:14px;border-radius:2px;flex-shrink:0;
  background:linear-gradient(180deg,var(--cyan),var(--blue));box-shadow:var(--glow-cyan);
}
.card-body{padding:0}
.card-sub{font-size:11px;color:var(--txt-3);font-weight:400}

/* ===== 统一表格样式 ===== */
.data-table{width:100%;border-collapse:collapse;font-size:12px}
.data-table thead th{
  font-size:10px;font-weight:600;color:var(--txt-3);text-transform:uppercase;letter-spacing:.05em;
  padding:8px 10px;text-align:left;border-bottom:1px solid rgba(86,156,255,.15);
  position:sticky;top:0;background:var(--bg-elev);z-index:1;
}
.data-table tbody td{
  padding:7px 10px;border-bottom:1px solid rgba(86,156,255,.05);
  transition:background .15s;
}
.data-table tbody tr:hover td{background:rgba(0,212,255,.04)}
.data-table .num{font-family:var(--mono);text-align:right}

/* ===== 统一徽章/标签 ===== */
.tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;font-size:10px;font-weight:600;border-radius:4px;letter-spacing:.02em}
.tag-buy{background:var(--up-soft);color:var(--up)}
.tag-sell{background:var(--down-soft);color:var(--down)}
.tag-hold{background:rgba(138,155,191,.12);color:var(--flat)}
.tag-info{background:rgba(0,212,255,.10);color:var(--cyan)}

/* ===== 统一数字大字 ===== */
.big-num{font-family:var(--mono);font-size:24px;font-weight:800;line-height:1}
.big-num.up{color:var(--up)}.big-num.down{color:var(--down)}

/* ===== 统一进度条/评分条 ===== */
.score-track{height:5px;border-radius:3px;background:rgba(86,156,255,.10);overflow:hidden}
.score-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.score-fill.high{background:linear-gradient(90deg,var(--up),#ff8fa3)}
.score-fill.mid{background:linear-gradient(90deg,var(--gold),#fde68a)}
.score-fill.low{background:linear-gradient(90deg,var(--down),#6ee7b7)}

/* ===== 空状态/加载占位 ===== */
.empty-state{text-align:center;padding:40px 20px;color:var(--txt-3);font-size:13px}
.empty-state svg{width:36px;height:36px;opacity:.3;margin-bottom:10px}

/* ===== 统一网格布局（双列/三列/四列） ===== */
.data-grid{display:grid;gap:14px;margin-bottom:14px}
.data-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.data-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.data-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.data-grid.cols-3,.data-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.data-grid.cols-2,.data-grid.cols-3,.data-grid.cols-4{grid-template-columns:1fr}}

/* ===== 网格布局 ===== */
.grid{display:grid;gap:18px;grid-template-columns:repeat(12,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-6{grid-template-columns:repeat(6,1fr)}
.g-12{grid-template-columns:repeat(12,1fr)}
@media(max-width:1280px){.g-6{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.g-2,.g-3,.g-4,.g-6,.g-12{grid-template-columns:1fr}}
.col-1{grid-column:span 1}.col-2{grid-column:span 2}.col-3{grid-column:span 3}
.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}
@media(max-width:992px){.col-4,.col-6,.col-8{grid-column:span 12}}

/* ===== 指数卡片 ===== */
.index-card{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--rad);padding:18px;
  position:relative;overflow:hidden;transition:all .25s;cursor:pointer;
}
.index-card:hover{transform:translateY(-3px);border-color:var(--glass-brd-hot);box-shadow:0 12px 32px rgba(0,0,0,.4)}
.index-card .ic-glow{position:absolute;inset:0;opacity:.08;pointer-events:none}
.index-name{font-size:12px;color:var(--txt-2);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}
.index-price{font-family:var(--mono);font-size:26px;font-weight:700;letter-spacing:-.5px}
.index-chg{font-family:var(--mono);font-size:13px;margin-top:4px;display:flex;gap:10px}
.up-c{color:var(--up)}.down-c{color:var(--down)}.flat-c{color:var(--flat)}

/* ===== 徽章 / 标签 ===== */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.3px}
.badge-up{background:var(--up-soft);color:var(--up);border:1px solid rgba(255,77,109,.3)}
.badge-down{background:var(--down-soft);color:var(--down);border:1px solid rgba(255,77,109,.3)}
.badge-cyan{background:rgba(0,212,255,.12);color:var(--cyan);border:1px solid rgba(0,212,255,.3)}
.badge-gold{background:rgba(251,191,36,.12);color:var(--gold);border:1px solid rgba(251,191,36,.3)}
.badge-violet{background:rgba(139,92,246,.12);color:var(--violet);border:1px solid rgba(139,92,246,.3)}
.tag{display:inline-block;padding:2px 8px;border-radius:5px;font-size:11px;background:rgba(86,156,255,.1);color:var(--txt-2);margin:2px}

/* ===== 表格 ===== */
.rank-table{width:100%;border-collapse:collapse;font-size:13px}
.rank-table th{text-align:left;padding:9px 12px;color:var(--txt-3);font-weight:600;font-size:11px;
  text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(86,156,255,.1);position:sticky;top:0;background:var(--bg-elev)}
.rank-table td{padding:10px 12px;border-bottom:1px solid rgba(86,156,255,.05)}
.rank-table tbody tr{transition:background .15s;cursor:pointer}
.rank-table tbody tr:hover{background:rgba(0,212,255,.06)}
.rt-rank{display:inline-flex;width:22px;height:22px;border-radius:6px;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;font-family:var(--mono)}
.rt-rank.r1{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}
.rt-rank.r2{background:linear-gradient(135deg,#ffa502,#ff7f50);color:#fff}
.rt-rank.r3{background:linear-gradient(135deg,#feca57,#ff9f43);color:#06122a}

/* ===== 热力图 ===== */
.heatmap{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:5px}
.heat-cell{
  border-radius:7px;padding:9px 8px;text-align:center;cursor:pointer;transition:transform .15s;
  border:1px solid rgba(255,255,255,.04);min-height:62px;display:flex;flex-direction:column;justify-content:center;
}
.heat-cell:hover{transform:scale(1.06);z-index:2;border-color:rgba(255,255,255,.3)}
.heat-cell .hc-name{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.heat-cell .hc-pct{font-family:var(--mono);font-size:13px;font-weight:700}

/* ===== 选股卡片 ===== */
.pick-card{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--rad);padding:16px;
  cursor:pointer;transition:all .25s;position:relative;overflow:hidden;
}
.pick-card:hover{transform:translateY(-3px);border-color:var(--glass-brd-hot);box-shadow:0 10px 28px rgba(0,0,0,.4)}
.pick-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.pick-name{font-size:15px;font-weight:700}
.pick-code{font-family:var(--mono);font-size:11px;color:var(--txt-3)}
.pick-score{font-family:var(--mono);font-size:24px;font-weight:800}
.pick-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid rgba(86,156,255,.08)}
.pick-pct{font-family:var(--mono);font-size:14px;font-weight:600}

/* ===== 图表容器 ===== */
.chart{width:100%;height:100%}
.chart-sm{height:120px}.chart-md{height:260px}.chart-lg{height:340px}.chart-xl{height:420px}

/* ===== 宽度条 ===== */
.breadth-bar{height:26px;border-radius:7px;overflow:hidden;display:flex;position:relative}
.breadth-up{background:linear-gradient(90deg,var(--up),#e63956);transition:width .6s}
.breadth-down{background:linear-gradient(90deg,var(--down),#00b870);transition:width .6s}

/* ===== 按钮 ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:10px;font-size:13px;
  font-weight:600;transition:all .2s;border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06122a}
.btn-primary:hover{box-shadow:var(--glow-cyan);transform:translateY(-1px)}
.btn-ghost{background:var(--glass);border-color:var(--glass-brd);color:var(--txt-2)}
.btn-ghost:hover{border-color:var(--glass-brd-hot);color:var(--txt)}
.btn-sm{padding:6px 13px;font-size:12px;border-radius:8px}

/* ===== 加载/空态 ===== */
.loader{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--txt-3);font-size:13px}
.spinner{width:18px;height:18px;border:2px solid rgba(0,212,255,.2);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:50px 20px;color:var(--txt-3);font-size:13px}

/* ===== 扫描线装饰 ===== */
.scanline{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  opacity:.5;animation:scan 3s linear infinite;top:0}
@keyframes scan{0%{top:0;opacity:0}10%{opacity:.5}90%{opacity:.5}100%{top:100%;opacity:0}}

/* ===== 登录页 ===== */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}
.auth-card{width:100%;max-width:440px;background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--rad-lg);
  padding:40px;backdrop-filter:blur(20px);position:relative;overflow:hidden}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;justify-content:center}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:12px;color:var(--txt-2);margin-bottom:7px;font-weight:600}
.form-group input,.form-group select{
  width:100%;padding:12px 15px;border-radius:10px;border:1px solid var(--glass-brd);background:rgba(6,9,20,.6);
  color:var(--txt);font-size:14px;transition:all .2s}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--glass-brd-hot);box-shadow:0 0 0 3px rgba(0,212,255,.12)}
.btn-block{width:100%;justify-content:center;padding:13px}

/* ===== 股票详情页 (v16.3) ===== */
.detail-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:22px}
.detail-title h1{font-size:30px;font-weight:800;letter-spacing:-.5px}
.detail-title .dt-sub{font-family:var(--mono);font-size:14px;color:var(--txt-3);margin-top:4px}
.detail-quote{display:flex;align-items:baseline;gap:14px}
.detail-price{font-family:var(--mono);font-size:38px;font-weight:800;letter-spacing:-1px}
.detail-chg{font-family:var(--mono);font-size:18px;font-weight:600}

/* B1 仪表盘 */
.b1-gauge{display:flex;align-items:center;gap:18px}
.b1-ring{position:relative;width:110px;height:110px;flex-shrink:0}
.b1-val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.b1-num{font-family:var(--mono);font-size:30px;font-weight:800;line-height:1}
.b1-lbl{font-size:10px;color:var(--txt-3);letter-spacing:1px;margin-top:2px}

/* 五维评分条 */
.dim-row{margin-bottom:14px}
.dim-head{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:6px}
.dim-name{color:var(--txt-2);font-weight:600}
.dim-val{font-family:var(--mono);font-weight:700}
.dim-bar{height:8px;border-radius:5px;background:rgba(86,156,255,.1);overflow:hidden}
.dim-fill{height:100%;border-radius:5px;transition:width .8s cubic-bezier(.4,0,.2,1)}

/* Serenity / 增强层标记 */
.layer-flag{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:9px;font-size:12.5px;margin-bottom:7px}
.layer-flag .lf-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:5px;font-weight:700;font-size:11px}
.lf-on{background:var(--up-soft);border:1px solid rgba(0,232,143,.25);color:var(--up)}
.lf-off{background:rgba(86,156,255,.06);border:1px solid rgba(86,156,255,.12);color:var(--txt-3)}
.lf-warn{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);color:var(--gold)}

/* AI 点评 */
.ai-box{background:linear-gradient(135deg,rgba(139,92,246,.08),rgba(59,130,246,.05));border:1px solid rgba(139,92,246,.2);
  border-radius:var(--rad);padding:18px;font-size:13.5px;line-height:1.8;color:var(--txt-2)}
.ai-box .ai-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--violet);
  margin-bottom:10px;letter-spacing:.5px}

/* 资金流条 */
.mf-row{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:12.5px}
.mf-label{width:70px;color:var(--txt-2);flex-shrink:0}
.mf-track{flex:1;height:7px;border-radius:4px;background:rgba(86,156,255,.08);position:relative;overflow:hidden}
.mf-in-bar{position:absolute;top:0;bottom:0;left:50%;background:var(--up);border-radius:4px}
.mf-out-bar{position:absolute;top:0;bottom:0;right:50%;background:var(--down);border-radius:4px}
.mf-val{width:80px;text-align:right;font-family:var(--mono);font-size:12px;font-weight:600}

/* 工具栏 tabs */
.tab-bar{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.tab-btn{padding:8px 16px;border-radius:9px;font-size:13px;font-weight:600;color:var(--txt-3);transition:all .2s;
  background:var(--glass);border:1px solid var(--glass-brd)}
.tab-btn.active{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06122a;border-color:transparent}
.tab-btn:hover:not(.active){color:var(--txt);border-color:var(--glass-brd-hot)}

/* 进度/评分大字报 */
.big-stat{text-align:center;padding:14px}
.big-stat .bs-val{font-family:var(--mono);font-size:34px;font-weight:800;line-height:1}
.big-stat .bs-lbl{font-size:11px;color:var(--txt-3);margin-top:6px;letter-spacing:.5px}

/* 历史/通用列表 */
.list-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;transition:background .15s;cursor:pointer}
.list-item:hover{background:var(--glass)}

/* 设置页 */
.settings-section{margin-bottom:24px}
.settings-section h3{font-size:14px;margin-bottom:12px;color:var(--txt)}

/* 自选 */
.watch-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:11px;
  background:var(--glass);border:1px solid var(--glass-brd);margin-bottom:9px;transition:all .2s}
.watch-row:hover{border-color:var(--glass-brd-hot)}

/* Toast */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{padding:13px 20px;border-radius:11px;background:var(--bg-elev2);border:1px solid var(--glass-brd);
  font-size:13px;box-shadow:0 12px 36px rgba(0,0,0,.5);animation:slideIn .3s;display:flex;align-items:center;gap:10px}
.toast.ok{border-color:rgba(0,232,143,.4)}.toast.err{border-color:rgba(255,77,109,.4)}
@keyframes slideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}

/* 工具类 */
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}
.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--txt-3)}
.text-center{text-align:center}.font-bold{font-weight:700}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hidden{display:none!important}
.scroll-y{overflow-y:auto}.scroll-y-md{max-height:360px;overflow-y:auto}

/* ====== BASE ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--font-family);font-size:15px;color:var(--text-primary);background:var(--bg-deep);overflow:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

/* ====== NATIVE ELEMENTS ====== */
input,textarea,select{
    padding:.55rem .75rem;
    background:rgba(255,255,255,0.04);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    color:var(--text-primary);
    font-size:.85rem;
    outline:none;
    transition:border .2s;
    font-family:inherit;
}
input:focus,textarea:focus,select:focus{border-color:var(--accent)}
input::placeholder,textarea::placeholder{color:var(--text-muted)}
button{
    cursor:pointer;
    font-family:inherit;
    border:none;
    outline:none;
}
button:disabled{opacity:.4;cursor:not-allowed}

/* ====== AUTH PAGE (登录/注册) ====== */
.auth-page{display:flex;min-height:100vh;overflow:hidden}

/* 左侧品牌区 */
.auth-brand{
  flex:0 0 52%;position:relative;display:flex;flex-direction:column;justify-content:center;
  padding:3rem 4rem;overflow:hidden;
  background:linear-gradient(135deg,#080d1a 0%,#0d1530 50%,#0a1228 100%);
  border-right:1px solid rgba(0,212,255,.12);
}
.auth-brand-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 50% at 30% 20%,rgba(0,212,255,.12),transparent 60%),
    radial-gradient(ellipse 50% 40% at 70% 80%,rgba(99,102,241,.10),transparent 60%);
}
.auth-brand-bg::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(0,212,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,212,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 70% 70% at center,black,transparent);
}
.auth-brand-content{position:relative;z-index:1;max-width:420px}
.auth-brand-logo{width:64px;height:64px;border-radius:16px;overflow:hidden;margin-bottom:1.2rem;
  box-shadow:0 8px 32px rgba(0,212,255,.2);border:1px solid rgba(0,212,255,.2)}
.auth-brand-logo img{width:100%;height:100%;object-fit:contain}
.auth-brand-title{font-size:2.4rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.3rem;
  background:linear-gradient(135deg,#fff 30%,#00d4ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.auth-brand-slogan{font-size:.85rem;color:var(--txt-3);letter-spacing:.05em;margin-bottom:2.5rem}

.auth-features{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:2.5rem}
.auth-feature{display:flex;align-items:center;gap:.9rem;opacity:0;animation:authSlideIn .5s ease forwards}
.auth-feature:nth-child(1){animation-delay:.1s}
.auth-feature:nth-child(2){animation-delay:.2s}
.auth-feature:nth-child(3){animation-delay:.3s}
.auth-feature:nth-child(4){animation-delay:.4s}
.auth-feature-icon{
  flex-shrink:0;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.15);color:var(--cyan)}
.auth-feature-name{font-size:.9rem;font-weight:600;color:var(--txt)}
.auth-feature-desc{font-size:.75rem;color:var(--txt-3)}

.auth-brand-stats{display:flex;align-items:center;gap:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(86,156,255,.1)}
.auth-stat{display:flex;flex-direction:column;gap:2px}
.auth-stat-num{font-size:1.6rem;font-weight:800;color:var(--cyan);font-family:var(--mono)}
.auth-stat-label{font-size:.7rem;color:var(--txt-3)}
.auth-stat-divider{width:1px;height:30px;background:rgba(86,156,255,.15)}

.auth-brand-footer{position:absolute;bottom:1.5rem;left:4rem;right:4rem;font-size:.7rem;color:var(--txt-3);opacity:.5;z-index:1}

@keyframes authSlideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}

/* 右侧表单区 */
.auth-form-area{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;
  background:var(--bg-void);position:relative}
.auth-form-area::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 30% at 50% 40%,rgba(59,130,246,.06),transparent 70%)}

.auth-card{
  position:relative;width:100%;max-width:380px;
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--rad-lg);
  padding:2.5rem 2rem;backdrop-filter:blur(20px);
  box-shadow:0 20px 60px rgba(0,0,0,.4);
  animation:authCardIn .4s ease}
@keyframes authCardIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

.auth-card-header{text-align:center;margin-bottom:1.8rem}
.auth-card-header h2{font-size:1.4rem;font-weight:700;color:var(--txt);margin-bottom:.3rem}
.auth-card-header p{font-size:.8rem;color:var(--txt-3)}

.auth-form{display:flex;flex-direction:column;gap:1.1rem}
.auth-field{display:flex;flex-direction:column;gap:.4rem}
.auth-field label{font-size:.78rem;color:var(--txt-2);font-weight:600;letter-spacing:.02em}
.auth-input-wrap{position:relative;display:flex;align-items:center}
.auth-input-icon{position:absolute;left:12px;color:var(--txt-3);pointer-events:none;z-index:1}
.auth-input-wrap input{
  width:100%;padding:11px 14px 11px 38px;
  background:rgba(10,16,32,.6);border:1px solid var(--glass-brd);border-radius:10px;
  color:var(--txt);font-size:.85rem;font-family:var(--sans);
  transition:border-color .2s,box-shadow .2s}
.auth-input-wrap input:focus{outline:none;border-color:var(--glass-brd-hot);box-shadow:0 0 0 3px rgba(0,212,255,.12)}
.auth-input-wrap input::placeholder{color:var(--txt-3)}
.auth-input-wrap:not(:has(.auth-input-icon)) input{padding-left:14px}

.auth-error{font-size:.78rem;color:var(--up);min-height:1.2rem;text-align:center}
.auth-success{font-size:.78rem;color:var(--down);text-align:center}
.auth-submit{
  width:100%;padding:12px;border:none;border-radius:10px;cursor:pointer;
  background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06122a;
  font-size:.9rem;font-weight:700;letter-spacing:.05em;
  transition:transform .15s,box-shadow .2s;margin-top:.3rem}
.auth-submit:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,212,255,.3)}
.auth-submit:active{transform:translateY(0)}
.auth-submit:disabled{opacity:.6;cursor:wait}

.auth-switch{text-align:center;margin-top:1.5rem;font-size:.8rem;color:var(--txt-3)}
.auth-switch a{color:var(--cyan);font-weight:600;cursor:pointer}
.auth-switch a:hover{text-decoration:underline}

/* 移动端：隐藏品牌区 */
@media(max-width:860px){
  .auth-brand{display:none}
  .auth-form-area{flex:1}
}

/* ====== LIVE DOT ====== */
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--down);display:inline-block;margin-right:.3rem;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ====== LOADING OVERLAY ====== */
.loading-overlay{
    position:fixed;inset:0;background:rgba(var(--deep-rgb),0.85);
    display:flex;align-items:center;justify-content:center;z-index:9999;
}
.loading-card{
    text-align:center;padding:2rem;
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:16px;min-width:200px;
}
.loading-spinner{
    width:36px;height:36px;border:3px solid var(--border);
    border-top-color:var(--accent);border-radius:50%;
    animation:spin .8s linear infinite;margin:0 auto 1rem;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:.82rem;color:var(--text-secondary)}

/* ====== SCROLLBAR ====== */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:3px}

/* ====== SIDEBAR ====== */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:linear-gradient(180deg,var(--bg-primary),rgba(var(--deep-rgb),0.95));border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:transform .2s}
.sidebar-brand{display:flex;align-items:center;gap:.6rem;padding:1rem 1.2rem;border-bottom:1px solid var(--border)}
.brand-logo{width:32px;height:32px;border-radius:8px}
.brand-name{font-size:1rem;font-weight:700;color:var(--text-primary);display:block}
.brand-sub{font-size:.65rem;color:var(--text-muted);display:block;text-transform:uppercase;letter-spacing:.05em}
.sidebar-nav{flex:1;padding:.6rem 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:.7rem;padding:.55rem 1.2rem;font-size:.9rem;color:var(--text-secondary);transition:all .2s;border-left:3px solid transparent;margin:.1rem 0}
.nav-item:hover{background:rgba(var(--accent-rgb),0.06);color:var(--text-primary)}
.nav-item.active{background:rgba(var(--accent-rgb),0.1);color:var(--accent);border-left-color:var(--accent);font-weight:600}
.nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-icon svg{width:18px;height:18px;fill:currentColor}
.nav-label{flex:1}
.sidebar-footer{padding:.6rem 1.2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.user-info{display:flex;align-items:center;gap:.5rem;font-size:.8rem}
.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-cyan));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;color:var(--white)}
.logout-btn{font-size:1.1rem;color:var(--text-muted);padding:.3rem;border-radius:var(--radius-sm);transition:all .2s;background:none}
.logout-btn:hover{color:var(--up);background:rgba(239,68,68,0.08)}

/* ====== MAIN ====== */
.main-content{margin-left:var(--sidebar-w);height:100vh;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--topbar-h);background:rgba(11,20,36,0.9);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.4rem;flex-shrink:0;backdrop-filter:blur(8px)}
.topbar-left{display:flex;align-items:center;gap:.8rem}
.topbar-title{font-size:.85rem;font-weight:600;color:var(--text-secondary)}
.topbar-right{display:flex;align-items:center;gap:1.2rem}
.topbar-time{font-size:.75rem;color:var(--text-muted)}
.sidebar-toggle{display:none;background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer}
.market-ticker{display:flex;gap:1rem;font-size:.78rem}
.ticker-item{color:var(--text-muted)}
.ticker-item span{margin-left:.3rem;font-weight:600}

/* ====== DATA STATUS ====== */
.data-status{font-size:.7rem;padding:.2rem .55rem;border-radius:100px;background:rgba(var(--amber-rgb),0.08);color:var(--accent-amber)}
.data-status.ok{background:rgba(16,185,129,0.08);color:var(--down)}
.data-status.stale{background:rgba(239,68,68,0.08);color:var(--up)}

/* ====== PAGE ====== */
.page-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem 1.4rem}
.page{display:none}
.page.active{display:block}
.section-title{margin-bottom:.6rem;margin-top:.2rem;display:flex;align-items:center}
.section-title h2{font-size:1rem;font-weight:700;color:var(--text-primary);padding-bottom:.3rem;border-bottom:2px solid var(--border-strong);display:inline-block}

/* ====== CARDS ====== */
.gloss-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem 1rem;backdrop-filter:blur(12px);transition:all .2s}
.gloss-card:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}
.gloss-card.compact{padding:.55rem .8rem}
.card-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.15rem}
.card-value{font-size:1.55rem;font-weight:700;color:var(--text-primary);line-height:1.2}
.card-change{font-size:.82rem;font-weight:600;margin-top:.1rem}
.card-change.up{color:var(--up)}.card-change.down{color:var(--down)}
.card-header{font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}
.badge-encrypted{display:inline-block;padding:.1rem .5rem;font-size:.65rem;border-radius:4px;background:rgba(var(--success-rgb),.15);color:var(--success);margin-left:.4rem;font-weight:500;vertical-align:middle}
.card-row{display:grid;gap:.5rem}
.card-row-2{grid-template-columns:repeat(2,1fr)}
.card-row-3{grid-template-columns:repeat(3,1fr)}
.card-row-4{grid-template-columns:repeat(4,1fr)}

/* ====== STOCK DETAIL - GENERAL ====== */
.chart-container{width:100%;min-height:200px}

/* Two-column layout */
.stock-two-col{display:flex;gap:.6rem;align-items:flex-start}
.stock-col-left{flex:0 0 55%;min-width:0}
.stock-col-right{flex:0 0 45%;min-width:0;display:flex;flex-direction:column}

/* ====== SIGNAL BANNER ====== */
.signal-banner{display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;border-radius:var(--radius);margin-bottom:.6rem;font-weight:600}
.signal-banner-buy{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);color:var(--up)}
.signal-banner-over{background:rgba(var(--amber-rgb),0.08);border:1px solid rgba(var(--amber-rgb),0.2);color:var(--accent-amber)}
.signal-banner-hold{background:rgba(var(--silver-rgb),0.06);border:1px solid rgba(var(--silver-rgb),0.15);color:var(--text-secondary)}
.signal-banner-sell{background:rgba(16,185,129,0.06);border:1px solid rgba(16,185,129,0.15);color:var(--down)}
.signal-banner-icon{font-size:1.3rem;flex-shrink:0}
.signal-banner-text{font-size:1rem;flex-shrink:0}
.signal-banner-sub{font-size:.68rem;color:var(--text-muted);margin-left:auto}

/* ====== PRICE INFO ROW ====== */
.price-info-row{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem;margin-bottom:.6rem}
.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .6rem;text-align:center}
.info-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:.15rem}
.info-value{font-size:.9rem;font-weight:700}
.info-value.up{color:var(--up)}.info-value.down{color:var(--down)}

/* ====== RATE COMPONENTS (Score Bars) ====== */
.rate-components{padding:.1rem 0}
.rate-components.compact .rate-bar-row{padding:.18rem 0}
.rate-bar-row{display:flex;align-items:center;gap:.5rem;padding:.22rem 0;border-bottom:1px solid rgba(255,255,255,0.02)}
.rate-bar-row:last-child{border-bottom:none}
.rate-bar-label{font-size:.7rem;color:var(--text-secondary);flex:0 0 55px;white-space:nowrap}
.rate-bar-score{font-size:.65rem;color:var(--text-muted);flex:0 0 42px;text-align:right}
.rate-bar-bg{flex:1;height:5px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.rate-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}

/* ====== SCREEN GRID ====== */
.screen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem}
.screen-grid.compact{grid-template-columns:repeat(2,1fr);gap:.15rem}
.screen-item{font-size:.65rem;padding:.2rem .3rem;border-radius:3px;text-align:center}
.screen-pass{background:rgba(16,185,129,0.08);color:var(--down)}
.screen-fail{background:rgba(239,68,68,0.05);color:var(--text-muted)}

/* ====== INDICATOR GRID ====== */
.indicator-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.15rem}
.indicator-item{display:flex;justify-content:space-between;padding:.18rem .3rem;background:rgba(255,255,255,0.02);border-radius:3px}
.indicator-item .indicator-label{font-size:.68rem;color:var(--text-muted)}
.indicator-item .indicator-value{font-size:.72rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}

/* ====== SUPPORT / RESISTANCE ====== */
.sr-body{display:flex;flex-direction:column;gap:.3rem}
.sr-row{display:flex;align-items:center;gap:.5rem;padding:.3rem .4rem;background:rgba(255,255,255,0.02);border-radius:var(--radius-sm)}
.sr-label{font-size:.68rem;color:var(--text-muted);flex-shrink:0;min-width:32px}
.sr-value{font-size:.82rem;font-weight:600;color:var(--text-primary)}
.sr-delta{font-size:.65rem;margin-left:.3rem}
.sr-delta.up{color:var(--up)}.sr-delta.down{color:var(--down)}
.sr-bar-wrap{height:6px;background:rgba(255,255,255,0.05);border-radius:3px;margin:.25rem 0;overflow:hidden}
.sr-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.sr-meta{font-size:.62rem;color:var(--text-muted);margin-top:.2rem;line-height:1.4}

/* ====== AI TEXT ====== */
.ai-text{font-size:.82rem;color:var(--text-secondary);line-height:1.7;white-space:pre-wrap}

/* ====== SELL SIGNALS ====== */
.sell-signal-list{font-size:.75rem;color:var(--down)}
.sell-signal-item{padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.sell-signal-item:last-child{border-bottom:none}

/* ====== SEARCH BAR INLINE ====== */
.search-bar-inline{display:flex;gap:.35rem;align-items:center}
.search-bar-inline input{padding:.35rem .6rem;width:140px;font-size:.8rem}
.search-bar-inline button{padding:.35rem .8rem;font-size:.75rem;font-weight:600;background:var(--accent);color:var(--white);border-radius:var(--radius-sm);white-space:nowrap}

/* ====== HISTORY ====== */
.history-day{margin-bottom:.6rem}
.history-date{font-size:.82rem;font-weight:600;color:var(--text-primary);margin-bottom:.4rem}
.history-picks{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem}
.history-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .6rem;display:flex;align-items:center;gap:.4rem;transition:all .15s}
.history-item:hover{border-color:var(--accent)}
.history-rank{font-size:.7rem;font-weight:700;width:18px;text-align:center;flex-shrink:0}
.history-rank.gold{color:var(--gold)}.history-rank.silver{color:var(--silver)}.history-rank.bronze{color:var(--bronze)}.history-rank.normal{color:var(--text-muted)}
.history-name{font-size:.78rem;font-weight:500;flex-shrink:0;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-code{font-size:.62rem;color:var(--text-muted);flex-shrink:0}
.history-reason{font-size:.6rem;color:var(--text-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-score{font-size:.7rem;font-weight:700;flex-shrink:0}

/* ====== ADD-WATCH ====== */
.add-watch{display:flex;gap:.4rem;margin-bottom:.8rem}
.add-watch input{flex:1;padding:.45rem .7rem}
.add-watch button{padding:.45rem 1rem;font-size:.78rem;font-weight:600;background:var(--accent);color:var(--white);border-radius:var(--radius-sm)}

/* ====== PICKS MINI GRID ====== */
.picks-mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.35rem}
.picks-mini-item{display:flex;align-items:center;gap:.35rem;padding:.35rem .45rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}
.picks-mini-item:hover{border-color:var(--accent);background:var(--bg-card-hover)}
.picks-mini-rank{font-size:.6rem;font-weight:700;width:16px;text-align:center;flex-shrink:0;color:var(--text-muted)}
.picks-mini-rank.gold{color:var(--gold)}.picks-mini-rank.silver{color:var(--silver)}.picks-mini-rank.bronze{color:var(--bronze)}
.picks-mini-name{font-size:.72rem;font-weight:500;color:var(--text-primary);flex-shrink:0;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.picks-mini-code{font-size:.58rem;color:var(--text-muted);flex-shrink:0}
.picks-mini-rating{font-size:.55rem;padding:1px 5px;border-radius:3px;flex-shrink:0;font-weight:600}
.picks-mini-score{font-size:.68rem;font-weight:700;flex-shrink:0;margin-left:auto}

/* ====== FUND HOT GRID ====== */
.fund-hot-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.35rem}
.fund-hot-item{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem .4rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-align:center}
.fund-hot-item:hover{border-color:var(--accent);background:var(--bg-card-hover)}
.fund-hot-code{font-size:.68rem;font-weight:600;color:var(--accent)}
.fund-hot-name{font-size:.7rem;color:var(--text-primary);line-height:1.3}
.fund-hot-type{font-size:.58rem;color:var(--text-muted)}
.fund-hot-note{font-size:.55rem;color:var(--text-muted);line-height:1.2}

/* ====== SEARCH BAR ====== */
.search-bar{display:flex;gap:.35rem;margin-bottom:.5rem}
.search-bar input{flex:1;padding:.5rem .75rem}
.search-bar button{padding:.5rem 1rem;font-weight:600;background:var(--accent);color:var(--white);border-radius:var(--radius-sm);white-space:nowrap}

/* ====== DASHBOARD LAYOUT ====== */
.dashboard-mid-row{display:flex;gap:.75rem;margin-bottom:.4rem}
.dashboard-mid-left{flex:0 0 58%;min-width:0}
.dashboard-mid-right{flex:1;min-width:0}
.dashboard-bottom-row{display:flex;gap:.75rem}
.dashboard-bottom-left{flex:1;min-width:0}
.dashboard-bottom-right{flex:0 0 260px;min-width:0}
.compact-title{margin-bottom:.2rem!important;margin-top:0!important}
.compact-title h2{font-size:.92rem!important;margin-bottom:0!important;padding-bottom:.2rem!important;padding-top:0!important}
.compact-title .section-badge{margin-left:.5rem;font-size:.72rem;opacity:.7}

/* ====== TOP8 GRID ====== */
.top10-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem;margin-bottom:.6rem}
.top10-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.55rem .65rem;display:flex;gap:.5rem;align-items:flex-start;transition:all .2s;overflow:hidden;min-width:0}
.top10-item:hover{background:var(--bg-card-hover);border-color:var(--border-strong);transform:translateY(-1px)}
.top10-rank{width:26px;height:26px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem;flex-shrink:0}
.top10-rank.gold{background:rgba(var(--amber-rgb),0.18);color:var(--gold)}
.top10-rank.silver{background:rgba(var(--silver-rgb),0.15);color:var(--silver)}
.top10-rank.bronze{background:rgba(var(--bronze-rgb),0.18);color:var(--bronze)}
.top10-rank.normal{background:rgba(var(--silver-rgb),0.08);color:var(--text-muted)}
.top10-info{flex:1;min-width:0}
.top10-name{font-size:.82rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top10-code{font-size:.65rem;color:var(--text-muted);margin-top:1px}
.top10-reason{font-size:.65rem;color:var(--text-muted);line-height:1.3;margin-top:.25rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.top10-score{flex-shrink:0;text-align:center;min-width:50px}
.top10-score-val{font-size:.9rem;font-weight:700}
.prob-bar-bg{width:100%;height:4px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden}
.prob-bar-fill{height:100%;border-radius:2px;transition:width .6s ease}

/* ====== BREADTH ====== */
.breadth-row{display:flex;gap:1.5rem;margin-bottom:.5rem;padding:.3rem 0}
.breadth-item{text-align:center;flex:1}
.breadth-count{font-size:1.4rem;font-weight:700}
.breadth-label{font-size:.68rem;color:var(--text-muted);margin-top:3px}
.breadth-bar-container{display:flex;height:6px;border-radius:3px;overflow:hidden;gap:2px;margin-top:.5rem}
.breadth-bar-up{background:var(--up);height:100%;min-width:0}
.breadth-bar-flat{background:var(--text-muted);height:100%;min-width:0}
.breadth-bar-down{background:var(--down);height:100%;min-width:0}

/* ====== TOP5 ====== */
.top5-list{padding:.3rem 0}
.top5-item{display:flex;align-items:center;gap:.4rem;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,0.02)}
.top5-item:last-child{border-bottom:none}
.top5-rank{width:20px;text-align:center;font-size:.7rem;font-weight:700;color:var(--text-muted);flex-shrink:0}
.top5-item:nth-child(1) .top5-rank{background:rgba(var(--amber-rgb),0.2);color:var(--gold);border-radius:3px}
.top5-item:nth-child(2) .top5-rank{background:rgba(var(--silver-rgb),0.15);color:var(--silver);border-radius:3px}
.top5-item:nth-child(3) .top5-rank{background:rgba(var(--bronze-rgb),0.15);color:var(--bronze);border-radius:3px}
.top5-name{flex:1;font-size:.78rem;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top5-val{font-size:.75rem;font-weight:600;flex-shrink:0}
.top5-val.up{color:var(--up)}.top5-val.down{color:var(--down)}

/* ====== SECTOR TREEMAP ====== */
#sectorHeatmap{width:100%;height:240px;min-height:200px}

/* ====== FORM ====== */
.form-group{margin-bottom:.85rem}
.form-group label{display:block;font-size:.82rem;color:var(--text-secondary);margin-bottom:.35rem;font-weight:500}
.form-group input{width:100%}
.form-input,.search-input{width:100%}
.form-input:focus,.search-input:focus{border-color:var(--accent)}
.form-error{color:var(--up);font-size:.8rem;margin-top:.3rem}
.form-success{color:var(--down);font-size:.8rem;margin-top:.3rem}
.form-hint{font-size:.7rem;color:var(--text-muted);margin-top:.2rem}

/* ====== BUTTONS ====== */
.btn-primary{padding:.5rem 1.2rem;background:var(--accent);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.3rem}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-primary.btn-sm{padding:.35rem .8rem;font-size:.75rem}
.btn-full{width:100%;padding:.7rem!important;font-size:.9rem!important}
.btn-text{font-size:inherit}
.btn-danger{background:var(--up)}

/* ====== SEARCH ====== */
.search-bar{display:flex;gap:.5rem;margin-bottom:1rem}
.search-bar input{flex:1}
.search-results{margin-top:.5rem}

/* ====== WATCHLIST ====== */
.watch-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.35rem;transition:all .2s}
.watch-item:hover{background:var(--bg-card-hover)}
.watch-name{font-size:.82rem;font-weight:600;color:var(--text-primary);min-width:80px}
.watch-code{font-size:.7rem;color:var(--text-muted)}
.watch-price{font-size:.85rem;font-weight:700;margin-left:auto}
.watch-change{font-size:.78rem;font-weight:600;min-width:60px;text-align:right}
.watch-change.up{color:var(--up)}.watch-change.down{color:var(--down)}

/* ====== HISTORY ====== */
.history-day{margin-bottom:1rem}
.history-date{font-size:.85rem;font-weight:600;color:var(--accent);margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}
.history-picks{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}

/* ====== STOCK PANEL ====== */
.stock-panel{margin-top:1rem}
.stock-quick-stats{display:none;grid-template-columns:repeat(4,1fr);gap:.4rem;margin-bottom:.6rem}
.stock-analysis-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;margin-bottom:.6rem}

/* ====== SIGNAL BANNER ====== */
.signal-banner{display:none;border-radius:var(--radius);padding:.8rem 1.2rem;margin-bottom:.6rem;animation:fadeIn .4s ease}
.signal-banner-inner{display:flex;align-items:center;gap:.8rem}
.signal-icon{font-size:1.5rem;flex-shrink:0}
.signal-text{font-weight:700;font-size:1.05rem}
.signal-sub{font-size:.78rem;opacity:.8;margin-left:auto;text-align:right}
.signal-buy{background:linear-gradient(135deg,rgba(239,68,68,0.15),rgba(239,68,68,0.05));border:1px solid rgba(239,68,68,0.2)}
.signal-buy .signal-text{color:var(--up)}
.signal-sell{background:linear-gradient(135deg,rgba(16,185,129,0.15),rgba(16,185,129,0.05));border:1px solid rgba(16,185,129,0.2)}
.signal-sell .signal-text{color:var(--down)}
.signal-hold{background:linear-gradient(135deg,rgba(var(--amber-rgb),0.12),rgba(var(--amber-rgb),0.03));border:1px solid rgba(var(--amber-rgb),0.15)}
.signal-hold .signal-text{color:var(--accent-amber)}

/* ====== SCREEN GRID ====== */
.screen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem .6rem;max-height:180px;overflow-y:auto}
.screen-item{font-size:.72rem;padding:.15rem 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.screen-item.pass{color:var(--up)}
.screen-item.fail{color:var(--text-muted);text-decoration:line-through}

/* ====== SELL SIGNAL ====== */
.sell-signal-list{font-size:.78rem;line-height:1.9}
.sell-item{padding:.1rem 0}

/* ====== SCORE BAR ====== */
.score-bar{width:100%;height:6px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden;margin:.2rem 0}
.score-bar-fill{height:100%;border-radius:3px;transition:width .6s ease;background:linear-gradient(90deg,var(--accent),var(--accent-cyan))}
.score-bar-fill.high{background:linear-gradient(90deg,var(--accent),var(--up))}
.score-bar-fill.mid{background:linear-gradient(90deg,var(--accent-amber),var(--accent))}
.score-bar-fill.low{background:linear-gradient(90deg,var(--down),var(--accent-cyan))}

/* ====== STOCK TWO-COLUMN LAYOUT ====== */
.stock-two-col{display:none;grid-template-columns:7fr 3fr;gap:1rem;padding:0 1.4rem 1rem;flex:1;overflow-y:auto}
.stock-col-left,.stock-col-right{display:flex;flex-direction:column;gap:.7rem;min-width:0}

/* ====== SIGNAL BANNER (new) ====== */
.signal-banner{display:none;align-items:center;gap:.8rem;border-radius:var(--radius);padding:.75rem 1.2rem;margin:0 1.4rem .6rem;animation:fadeIn .4s ease}
.signal-banner-icon{font-size:1.4rem;flex-shrink:0}
.signal-banner-text{font-weight:700;font-size:1.05rem}
.signal-banner-sub{font-size:.72rem;opacity:.75;margin-left:auto;text-align:right}
.signal-banner-buy{background:linear-gradient(135deg,rgba(239,68,68,0.15),rgba(239,68,68,0.05));border:1px solid rgba(239,68,68,0.2);color:var(--up)}
.signal-banner-over{background:linear-gradient(135deg,rgba(6,182,212,0.12),rgba(6,182,212,0.03));border:1px solid rgba(6,182,212,0.15);color:var(--accent-cyan)}
.signal-banner-hold{background:linear-gradient(135deg,rgba(var(--amber-rgb),0.12),rgba(var(--amber-rgb),0.03));border:1px solid rgba(var(--amber-rgb),0.15);color:var(--accent-amber)}
.signal-banner-sell{background:linear-gradient(135deg,rgba(16,185,129,0.15),rgba(16,185,129,0.05));border:1px solid rgba(16,185,129,0.2);color:var(--down)}

/* ====== PRICE INFO ROW ====== */
.price-info-row{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}
.info-card{background:rgba(255,255,255,0.025);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .65rem;text-align:center}
.info-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}
.info-value{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-top:.15rem}
.info-value.up{color:var(--up)}.info-value.down{color:var(--down)}

/* ====== SUPPORT/RESISTANCE ====== */
.sr-body{padding:.3rem 0}
.sr-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.sr-label{font-size:.75rem;color:var(--text-muted)}
.sr-value{font-size:.95rem;font-weight:700}
.sr-bar-wrap{height:4px;background:rgba(255,255,255,0.08);border-radius:2px;margin:.2rem 0 .5rem;overflow:hidden}
.sr-bar-fill{height:100%;border-radius:2px;transition:width .6s ease}
.sr-meta{font-size:.68rem;color:var(--text-muted);text-align:center;margin-top:.3rem}

/* ====== INDICATOR GRID ====== */
.indicator-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem .6rem}
.indicator-item{display:flex;justify-content:space-between;padding:.18rem 0;border-bottom:1px solid rgba(255,255,255,0.03);font-size:.72rem}
.indicator-label{color:var(--text-muted)}
.indicator-value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}

/* ====== RATE COMPONENTS (B1 + 五维) ====== */
.rate-components{padding:.2rem 0}
.rate-bar-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}
.rate-bar-label{font-size:.7rem;color:var(--text-muted);width:70px;flex-shrink:0;text-align:right}
.rate-bar-score{font-size:.72rem;font-weight:600;color:var(--text-primary);width:34px;flex-shrink:0}
.rate-bar-bg{flex:1;height:5px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.rate-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}

/* ====== SCREEN GRID (updated) ====== */
.screen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.2rem .5rem;max-height:160px;overflow-y:auto}
.screen-item{font-size:.7rem;padding:.12rem 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.screen-item.screen-pass{color:var(--up)}
.screen-item.screen-fail{color:var(--text-muted);text-decoration:line-through}

/* ====== SELL SIGNAL LIST ====== */
.sell-signal-list{font-size:.75rem;line-height:1.8}
.sell-item{padding:.05rem 0;color:var(--accent-amber)}

/* ====== AI TEXT ====== */
.ai-text{font-size:.78rem;color:var(--text-secondary);line-height:1.7}

/* ====== FUND (new) ====== */
.fund-info-card{margin-bottom:.8rem}
.fund-info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}
.holdings-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}
.holdings-table-wrap{overflow-x:auto}
.holdings-table{width:100%;border-collapse:collapse;font-size:.75rem}
.holdings-table th{padding:.4rem .5rem;text-align:left;color:var(--text-muted);font-weight:600;font-size:.68rem;text-transform:uppercase;border-bottom:1px solid var(--border)}
.holdings-table td{padding:.35rem .5rem;border-bottom:1px solid rgba(255,255,255,0.03)}
.holdings-table .up{color:var(--up)}.holdings-table .down{color:var(--down)}
.fund-rating-row{display:flex;align-items:center}
.fund-rating-badge{padding:.3rem .8rem;border-radius:var(--radius-sm);font-weight:700;font-size:1rem}
.fund-rating-badge.up{background:rgba(239,68,68,0.12);color:var(--up)}
.fund-rating-badge.down{background:rgba(16,185,129,0.12);color:var(--down)}

/* ====== SEARCH BAR INLINE ====== */
.search-bar-inline{display:flex;align-items:center;gap:.4rem}
.search-bar-inline input{width:140px;padding:.35rem .55rem;font-size:.8rem}
.search-bar-inline button{padding:.35rem .65rem;background:var(--accent);color:var(--white);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}

/* ====== TEXT MUTED ====== */
.text-muted{color:var(--text-muted);font-size:.78rem}

/* ====== MISSING CLASSES (added 2026-06-13) ====== */
.dashboard-body{overflow:auto}
.brand-text{font-size:.82rem;font-weight:600;color:var(--text-primary);line-height:1.3}
.brand-text small{display:block;font-size:.6rem;color:var(--text-muted);font-weight:400;text-transform:uppercase;letter-spacing:.05em}
.user-name{font-size:.78rem;color:var(--text-secondary)}
.data-table{width:100%;border-collapse:collapse;font-size:.78rem}
.data-table th{padding:.5rem .6rem;text-align:left;color:var(--text-muted);font-weight:600;font-size:.7rem;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}
.data-table td{padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,0.04);white-space:nowrap}
.data-table tr:hover td{background:rgba(255,255,255,0.02)}
.chart-container{position:relative;width:100%;min-height:200px;overflow:hidden}
.chart-container.small{min-height:160px}
.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.8rem}
.big-score{font-weight:800;color:var(--text-primary);line-height:1.1}
.card-icon{font-size:.7rem;margin-right:.3rem;color:var(--accent)}
.card-subtitle{font-size:.7rem;color:var(--text-muted);margin-top:.15rem}
.compact-text{font-size:.75rem;color:var(--text-secondary);line-height:1.5}
.ai-analysis-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-top:.5rem}
.ai-content{font-size:.78rem;color:var(--text-secondary);line-height:1.6}
.tab-group{display:flex;gap:.3rem;flex-wrap:wrap}
.tab-btn{padding:.35rem .75rem;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:100px;font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:all .2s;white-space:nowrap}
.tab-btn:hover{background:rgba(255,255,255,0.06);color:var(--text-secondary)}
.tab-btn.active{background:rgba(var(--accent-rgb),0.15);border-color:var(--accent);color:var(--accent);font-weight:600}
.tab-btn.sm{padding:.2rem .5rem;font-size:.68rem}
.add-watch{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .7rem;background:rgba(var(--accent-rgb),0.08);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--accent);font-size:.75rem;font-weight:500;cursor:pointer;transition:var(--transition)}
.add-watch:hover{background:rgba(var(--accent-rgb),0.15)}
.fundflow-summary{font-size:.75rem;color:var(--text-secondary);padding:.5rem;background:rgba(255,255,255,0.02);border-radius:var(--radius-sm);line-height:1.5}
.watchlist-container{display:flex;flex-direction:column;gap:.5rem}
.loading-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted);font-size:.82rem;gap:.5rem}
.loading-sub{font-size:.7rem;color:var(--text-muted);opacity:.7}
.pulse{animation:pulse 2s infinite}

/* ====== RESPONSIVE ====== */
@media(max-width:1200px){
    .stock-two-col{grid-template-columns:1fr}
    .price-info-row{grid-template-columns:repeat(3,1fr)}
    .holdings-two-col{grid-template-columns:1fr}
    .fund-info-grid{grid-template-columns:repeat(2,1fr)}
    .top10-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}

/* ====== TABLET / SMALL SCREEN ====== */
@media(max-width:900px){
    :root{--sidebar-w:0px}
    .sidebar{transform:translateX(-100%);box-shadow:4px 0 20px rgba(0,0,0,.5)}
    .sidebar.open{transform:translateX(0)}
    .sidebar-toggle{display:flex!important;align-items:center;justify-content:center}
    .main-content{margin-left:0!important}
    .dashboard-mid-row{flex-direction:column;gap:.5rem}
    .dashboard-mid-left{flex:1}
    .dashboard-mid-right{flex:1}
    .dashboard-bottom-row{flex-direction:column;gap:.5rem}
    .dashboard-bottom-left{flex:1}
    .dashboard-bottom-right{flex:auto}
    .top10-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem}
    .card-row-3,.card-row-4{grid-template-columns:repeat(2,1fr)}
    .breadth-row{gap:.8rem}
    .card-value{font-size:1.3rem}
    .top10-score-val{font-size:.8rem}
    .top10-name{font-size:.75rem}
    .stock-two-col{grid-template-columns:1fr}
    .top5-list{gap:.3rem}
    /* Sidebar overlay */
    .sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}
    .sidebar.open ~ .sidebar-overlay{display:block}
}

/* ====== MOBILE ====== */
@media(max-width:768px){
    html,body{font-size:14px}
    .page-container{padding:.6rem .8rem}
    .topbar{padding:0 .8rem}
    .market-ticker{flex-wrap:wrap;gap:.3rem .8rem;font-size:.72rem}
    .topbar-title{font-size:.78rem}
    /* Login */
    .login-container{padding:.8rem}
    .login-card{padding:1.5rem 1.2rem;border-radius:12px}
    .login-header h1{font-size:1.3rem}
    /* Dashboard cards */
    .card-row-2{grid-template-columns:repeat(2,1fr)}
    .card-row-3{grid-template-columns:repeat(2,1fr)}
    .card-row-4{grid-template-columns:repeat(2,1fr)}
    .card-body{padding:.65rem .8rem}
    .card-value{font-size:1.2rem}
    .card-change{font-size:.75rem}
    .card-header{font-size:.72rem}
    /* Top picks */
    .top10-grid{gap:.35rem}
    .top10-item{padding:.45rem .5rem;gap:.35rem}
    .top10-rank{width:22px;height:22px;font-size:.7rem}
    .top10-reason{-webkit-line-clamp:1}
    .top10-score{min-width:40px}
    .top10-score-val{font-size:.75rem}
    .prob-bar-bg{width:36px}
    /* Breadth */
    .breadth-row{gap:.4rem;flex-wrap:wrap}
    .breadth-count{font-size:.9rem}
    .breadth-label{font-size:.6rem}
    /* Charts */
    #sectorHeatmap{height:220px!important}
    #klineChart{height:280px!important}
    #fundflowChart{height:200px!important}
    #allSectorChart{min-height:180px}
    /* Stock detail */
    .signal-banner{flex-direction:column;text-align:center;gap:.3rem;padding:.8rem}
    .signal-banner-sub{margin-left:0}
    .screen-grid{grid-template-columns:repeat(2,1fr)}
    .indicator-grid{grid-template-columns:1fr}
    .price-info-row{grid-template-columns:repeat(2,1fr)}
    .fund-info-grid{grid-template-columns:1fr}
    .ai-analysis-grid{grid-template-columns:1fr}
    /* Data table scroll */
    .data-table{font-size:.7rem}
    .data-table th,.data-table td{padding:.3rem .4rem}
    /* Tabs */
    .tab-btn{font-size:.7rem;padding:.25rem .55rem}
    /* History */
    .history-pick-grid{grid-template-columns:repeat(2,1fr)}
    /* Funds */
    .holdings-two-col{grid-template-columns:1fr}
    /* Search */
    .search-bar-inline input{width:100px}
    /* Settings */
    .settings-grid{grid-template-columns:1fr}
    .form-group input,.form-group select{font-size:.8rem}
}

/* ====== SMALL MOBILE ====== */
@media(max-width:480px){
    .card-row-2,.card-row-3,.card-row-4{grid-template-columns:1fr}
    .top10-grid{grid-template-columns:1fr;gap:.3rem}
    .top10-item{gap:.4rem}
    .market-ticker{display:none}
    .page-container{padding:.4rem .5rem}
    .card-body{padding:.5rem .65rem}
    .card-value{font-size:1.1rem}
    .card-header{font-size:.7rem;margin-bottom:.2rem}
    /* Tabs overflow scroll */
    .tab-group{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.2rem;-webkit-overflow-scrolling:touch}
    .tab-btn{flex-shrink:0}
    /* Sidebar wider for touch */
    .sidebar{width:260px}
    /* Login */
    .login-card{padding:1.2rem .9rem}
    /* Charts */
    #sectorHeatmap{height:180px!important}
    #klineChart{height:220px!important}
    #fundflowChart{height:160px!important}
    #allSectorChart{min-height:140px}
    /* History */
    .history-pick-grid{grid-template-columns:1fr}
    /* Data table */
    .data-table{font-size:.65rem}
    /* Signal banner */
    .signal-banner{padding:.6rem;font-size:.8rem}
    /* Score bar */
    .top10-score{min-width:35px}
    .top10-score-val{font-size:.7rem}
    .prob-bar-bg{width:30px;height:3px}
}

/* ====== SIDEBAR V2 (子模板共用) ====== */
.sidebar-v2 .nav-item{padding:.58rem .9rem;border-radius:8px;margin:2px .5rem;transition:all .18s}
.sidebar-v2 .nav-item:hover{background:rgba(255,255,255,.04)}
.sidebar-v2 .nav-item.active{background:var(--accent);color:#fff;box-shadow:0 2px 12px rgba(59,130,246,.25)}
.sidebar-v2 .nav-item.active .nav-icon{color:#fff}
.sidebar-v2 .nav-icon{margin-right:.5rem;font-size:18px}
.sidebar-v2 .nav-hot{font-size:9px;font-weight:800;padding:2px 7px;border-radius:8px;background:linear-gradient(135deg,#ff4d6d,#ff6b81);color:#fff;letter-spacing:.5px;margin-left:auto}
