/* stock-lab 深色主題（移植 ch-admin 風格 + 左側導覽版面） */
:root{
  --bg:#0f1419; --panel:#1a2027; --panel2:#222b35; --border:#2c3947;
  --text:#e6edf3; --muted:#8b98a5; --accent:#ffb000; --green:#26a69a; --red:#ef5350;
  --blue:#42a5f5; --sidebar-w:200px;
}
*{box-sizing:border-box}
[x-cloak]{display:none !important}
html,body{height:100%}
body{margin:0;font-family:-apple-system,"Segoe UI","Microsoft JhengHei",sans-serif;
  background:var(--bg);color:var(--text);font-size:14px}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- 版面：左側導覽 + 主內容 ---- */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);
  background:var(--panel);border-right:1px solid var(--border);
  display:flex;flex-direction:column;z-index:20}
.sidebar .logo{padding:16px;font-size:17px;font-weight:700;color:var(--accent);
  border-bottom:1px solid var(--border)}
.sidebar nav{display:flex;flex-direction:column;padding:8px 0}
.sidebar nav a{color:var(--muted);padding:11px 16px;border-left:3px solid transparent;font-size:14px}
.sidebar nav a:hover{color:var(--text);background:var(--panel2);text-decoration:none}
.sidebar nav a.active{color:var(--accent);border-left-color:var(--accent);background:var(--panel2)}
.layout-main{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}
.topbar{background:var(--panel);border-bottom:1px solid var(--border);
  padding:10px 20px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10}
.content{padding:20px;max-width:1400px;width:100%;margin:0 auto;flex:1}

/* ---- 頂列常駐「我的事 ＋ 收件匣」---- */
.topdock{margin-left:auto;display:flex;align-items:center;gap:2px;font-size:12px;white-space:nowrap}
.topdock .td-row{display:flex;align-items:center;gap:2px}
.topdock .td-item{display:inline-flex;align-items:center;gap:4px;color:var(--muted);padding:4px 8px;border-radius:6px}
.topdock .td-item:hover{background:var(--panel2);text-decoration:none}
.topdock .td-item b{color:var(--text);font-weight:600}
.topdock .td-item .ic{font-size:13px}
.topdock .td-sep{width:1px;height:18px;background:var(--border);margin:0 5px}
.topdock .td-err{color:var(--red);font-size:11px}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
@media (max-width:1040px){ .topdock .k{display:none} }   /* 空間不足先收標籤，留數字 */
@media (max-width:780px){ .topdock{display:none} }        /* 極窄螢幕隱藏，避免擠壓搜尋框 */

/* ---- 全域搜尋 ---- */
.searchbox{position:relative;width:340px;max-width:60vw}
.searchbox input{width:100%}
.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:var(--panel2);border:1px solid var(--border);border-radius:8px;
  max-height:380px;overflow:auto;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:30}
.search-results a{display:flex;gap:10px;align-items:baseline;padding:9px 12px;
  color:var(--text);border-bottom:1px solid var(--border)}
.search-results a:last-child{border-bottom:none}
.search-results a:hover{background:var(--panel);text-decoration:none}
.search-results .muted{margin-left:auto;font-size:12px}

/* ---- 元件 ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px}
.card .label{color:var(--muted);font-size:12px}
.card .val{font-size:24px;font-weight:600;margin-top:4px}
a.navcard{display:block;color:var(--text)}
a.navcard:hover{border-color:var(--accent);text-decoration:none}
a.navcard h3{margin:0 0 6px;color:var(--accent);font-size:15px}
a.navcard p{margin:0;color:var(--muted);font-size:13px}

table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);white-space:nowrap}
th{color:var(--muted);font-weight:500;position:sticky;top:0;background:var(--panel2);user-select:none}
tbody tr:hover{background:var(--panel2)}
.tablewrap{overflow:auto;max-height:70vh;border:1px solid var(--border);border-radius:8px;background:var(--panel)}
.num{text-align:right;font-variant-numeric:tabular-nums}
/* 長文字欄：搭配 max-width 用——td 全域 nowrap，沒有 overflow 裁切會畫到隔壁欄上 */
td.clip{overflow:hidden;text-overflow:ellipsis}
.pos{color:var(--red)}   /* 台股慣例：紅漲 */
.neg{color:var(--green)} /* 綠跌 */

.btn{background:var(--accent);color:#000;border:none;padding:8px 16px;border-radius:6px;
  cursor:pointer;font-weight:600;font-size:13px}
.btn:hover{opacity:.9}
.btn.sec{background:var(--panel2);color:var(--text);border:1px solid var(--border)}
.btn:disabled{opacity:.45;cursor:not-allowed}
a.btn{display:inline-block}
a.btn:hover{text-decoration:none}
input,select,textarea{background:var(--panel2);border:1px solid var(--border);color:var(--text);
  padding:8px 10px;border-radius:6px;font-size:13px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{width:100%;min-height:120px;resize:vertical}

.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.muted{color:var(--muted)}
.mono{font-family:"SF Mono",Menlo,Consolas,monospace}
.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;background:var(--panel2);
  border:1px solid var(--border);color:var(--muted)}
.badge-ok{color:var(--green)} .badge-warn{color:var(--accent)} .badge-bad{color:var(--red)}
.chartbox{background:var(--panel);border:1px solid var(--border);border-radius:8px;
  padding:16px;margin-bottom:16px}
.chartbox h3{margin:0 0 12px;font-size:14px;color:var(--text)}
.chart{width:100%;height:360px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.split{display:grid;grid-template-columns:280px 1fr;gap:16px}
.err{background:#3a1a1a;border:1px solid var(--red);color:#ffb4b4;padding:10px 14px;
  border-radius:6px;margin-bottom:12px}
.loading{color:var(--muted);padding:20px;text-align:center}

/* 手機版漢堡 / 抽屜式側欄（桌機隱藏） */
.navtoggle{display:none;background:none;border:none;color:var(--text);font-size:22px;
  cursor:pointer;padding:0 6px;line-height:1}
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:35}

@media(max-width:900px){
  .split,.grid2{grid-template-columns:1fr}
  .navtoggle{display:block}
  .sidebar{transform:translateX(-100%);transition:transform .2s ease;z-index:40}
  body.nav-open .sidebar{transform:none}
  body.nav-open .nav-backdrop{display:block}
  .layout-main{margin-left:0}
  .content{padding:14px}
  .searchbox{width:auto;flex:1}
  .topdock .k{display:none}
  table th,table td{padding:7px 8px}
}

/* 資料時間列（base.html 全頁共用，緊貼 topbar 下方） */
.data-freshness{display:flex;flex-wrap:wrap;gap:6px;align-items:center;
  padding:5px 20px;font-size:12px;color:var(--muted);
  background:var(--panel);border-bottom:1px solid var(--border)}
.data-freshness .df-title{color:var(--muted);margin-right:2px}
.data-freshness .df-chip{background:var(--panel2);border:1px solid var(--border);
  border-radius:10px;padding:1px 8px;cursor:default;white-space:nowrap}
.data-freshness .df-chip b{color:var(--text);font-weight:600}
.data-freshness .df-chip.lag{border-color:var(--red);color:var(--red)}
.data-freshness .df-chip.lag b{color:var(--red)}
