/* BoBo Server — GitHub-dark 配色，对齐 dashboard.html / BoBoNews 桌面。
   调色板源自 bobo_news_app/dashboard_components/constants.py。 */
:root {
  --bg: #0d1117;
  --panel: #161b22;
  --border: #21262d;
  --border2: #30363d;
  --text: #c9d1d9;
  --head: #f0f6fc;
  --muted: #8b949e;
  --dim: #484f58;
  --pos: #4ecdc4;
  --neg: #ff6b6b;
  --accent: #388bfd;
  --accent2: #58a6ff;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }
body {
  background: var(--bg); color: var(--text);
  font-family: 'Microsoft YaHei', -apple-system, sans-serif;
  display: flex; flex-direction: column;
}

/* ---- Navbar ---- */
.navbar {
  display: flex; align-items: center; gap: 4px;
  padding: 0 16px; height: 48px;
  background: var(--panel); border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10;
  flex-wrap: nowrap; overflow-x: auto;          /* 窄屏不换行，改横向滚动 */
  -webkit-overflow-scrolling: touch;
}
.navbar::-webkit-scrollbar { height: 0; }       /* 隐藏导航横滚条 */
.navbar .brand { font-weight: 700; color: var(--head); margin-right: 18px; white-space: nowrap; flex-shrink: 0; }
.navbar .nav-logo { width: 26px; height: 26px; margin-right: 14px; flex-shrink: 0; border-radius: 5px; }
.navbar a {
  color: var(--muted); text-decoration: none; font-size: 14px;
  padding: 6px 12px; border-radius: 6px; transition: all .15s;
  white-space: nowrap; flex-shrink: 0;
}
.navbar a:hover { color: var(--head); background: rgba(56,139,253,.08); }
.navbar a.active { color: var(--accent2); background: rgba(56,139,253,.15); }

/* ---- Content ---- */
.content { flex: 1; padding: 16px; min-height: 0; }
.content.flush { padding: 0; display: flex; flex-direction: column; }
.full-frame { flex: 1; width: 100%; border: 0; background: var(--bg); }

/* ---- KPI cards ---- */
.kpi-row { display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.kc {
  background: var(--panel); border: 1px solid var(--border); border-radius: 10px;
  padding: 12px 18px; flex: 1; min-width: 110px; text-align: center;
  transition: border-color .2s;
}
.kc:hover { border-color: var(--accent); }
.kl { font-size: 12px; color: var(--muted); margin-bottom: 4px; }
.kv { font-size: 20px; font-weight: 700; color: var(--head); white-space: nowrap; }
.kv.pos { color: var(--pos); }
.kv.neg { color: var(--neg); }

/* ---- Toolbar / filters ---- */
.toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.inline-form { display: flex; align-items: center; gap: 6px; }
.toolbar label { font-size: 13px; color: var(--muted); }
.toolbar input.search, .toolbar select {
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border2); border-radius: 6px;
  padding: 6px 10px; font-size: 13px; font-family: inherit; outline: none;
}
.toolbar input.search { min-width: 260px; }
.toolbar input.search.sm { min-width: 110px; }
.toolbar input.search:focus, .toolbar select:focus { border-color: var(--accent); }
.toolbar .counter { font-size: 12px; color: var(--muted); }
.toolbar .hint { font-size: 12px; color: var(--dim); margin-left: auto; }

/* ---- Banner ---- */
.banner {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 14px; margin-bottom: 12px;
  font-size: 13px; color: var(--muted);
}
.banner.warn { border-color: #E8A838; color: #E8A838; }

/* ---- Table ---- */
.table-wrap {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; overflow: auto; max-height: calc(100vh - 200px);
}
table.grid { width: 100%; border-collapse: collapse; font-size: 13px; }
table.grid thead th {
  position: sticky; top: 0; background: #1c2128; color: var(--muted);
  text-align: left; font-weight: 600; padding: 9px 12px;
  border-bottom: 1px solid var(--border); white-space: nowrap; z-index: 1;
}
table.grid tbody td {
  padding: 7px 12px; border-bottom: 1px solid #1c2128;
  white-space: nowrap; color: var(--text);
}
table.grid tbody tr:nth-child(even) { background: rgba(255,255,255,.015); }
table.grid tbody tr:hover { background: rgba(56,139,253,.07); }
table.grid td.pos { color: var(--pos); font-weight: 600; }
table.grid td.neg { color: var(--neg); font-weight: 600; }

/* ---- 冻结列（sticky left，offset 由 app.js 计算）---- */
table.grid td.frozen-col { background: var(--panel); }      /* 不透明盖住下层滚动内容 */
table.grid th.frozen-col { background: #1c2128; }
table.grid .frozen-last { box-shadow: 2px 0 0 var(--border2); }  /* 冻结区右侧分隔线 */

/* ---- Misc ---- */
.empty { color: var(--dim); padding: 40px; text-align: center; font-size: 14px; }
/* flush 布局里的涨停日期选择条，给点内边距别贴边 */
.uplimit-bar { padding: 8px 12px; margin: 0; border-bottom: 1px solid var(--border); }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }

/* ---- 手机端 / 窄屏适配 ---- */
@media (max-width: 640px) {
  .content { padding: 10px; }
  .content.flush { padding: 0; }

  .navbar { gap: 2px; padding: 0 8px; height: 44px; }
  .navbar .nav-logo { width: 22px; height: 22px; margin-right: 8px; }
  .navbar .brand { margin-right: 10px; font-size: 14px; }
  .navbar a { padding: 6px 9px; font-size: 13px; }

  /* KPI：每行 3 个，数字缩小不截断 */
  .kpi-row { gap: 8px; }
  .kc { min-width: calc(33.33% - 6px); padding: 10px 6px; }
  .kl { font-size: 11px; }
  .kv { font-size: 15px; }

  /* 工具栏：输入框自适应、可换行，隐藏右侧提示 */
  .toolbar { gap: 6px; }
  .toolbar input.search,
  .toolbar input.search.sm { min-width: 0; flex: 1 1 110px; }
  .toolbar select { flex: 1 1 100px; }
  .toolbar .inline-form { flex: 1 1 100%; }
  .toolbar .inline-form select { flex: 1; }
  .toolbar .hint { display: none; }

  /* 表格：字号/内边距收紧；横向滚动看更多列 */
  table.grid { font-size: 12px; }
  table.grid thead th,
  table.grid tbody td { padding: 6px 8px; }
  .table-wrap { max-height: calc(100vh - 240px); }
}
