:root{
  --bg:#0f1115; --card:#1a1d24; --card2:#21252e; --line:#2a2f3a;
  --txt:#e6e8ec; --mut:#9aa3b2; --accent:#4c8bf5; --danger:#ef5350;
  --info:#5b9bff; --good:#3ddc97; --warn:#f5a623;
  --safe-top:env(safe-area-inset-top,0px);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,"PingFang TC","Noto Sans TC",system-ui,sans-serif;
  background:var(--bg);color:var(--txt);line-height:1.5;
  -webkit-text-size-adjust:100%;
}
button,input{font:inherit}
button{cursor:pointer}
.hidden{display:none !important}

/* 登入 */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px;width:100%;max-width:360px}
.login-card h1{font-size:19px;margin:0 0 4px}
.login-card p{color:var(--mut);font-size:13px;margin:0 0 18px}
#pw{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--line);background:#0f1115;color:var(--txt);margin-bottom:12px}
.remember{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--mut);margin-bottom:16px}
.btn{width:100%;padding:13px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-weight:600}
.err{color:var(--danger);font-size:13px;margin-top:8px;min-height:18px}

/* 版面 */
.app{max-width:720px;margin:0 auto;padding-bottom:40px}
.topbar{
  position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:8px;
  padding:calc(12px + var(--safe-top)) 16px 12px;background:rgba(15,17,21,.92);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);
}
.brand{font-size:16px;font-weight:600;margin-right:auto}
.icon-btn{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:9px;padding:7px 11px;font-size:13px}

/* 分頁切換 */
.segtab{display:flex;gap:6px;padding:12px 16px 4px}
.seg{flex:1;padding:10px;border-radius:11px;border:1px solid var(--line);background:transparent;color:var(--mut);font-size:14px;font-weight:500}
.seg.active{background:var(--accent);color:#fff;border-color:transparent}
.seg-badge{background:rgba(255,255,255,.25);border-radius:999px;padding:0 7px;font-size:11px;margin-left:4px}

.view{padding:8px 16px 0}

/* 摘要卡片 */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:8px 0 4px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 15px}
.stat .label{color:var(--mut);font-size:12px;margin-bottom:6px}
.stat .num{font-size:26px;font-weight:700;line-height:1}
.stat .sub{color:var(--mut);font-size:11px;margin-top:5px}
.stat.accent .num{color:var(--info)}
.stat.good .num{color:var(--good)}
.stat.warn .num{color:var(--warn)}

/* 圖表面板 */
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 15px;margin-top:12px}
.panel-title{font-size:14px;font-weight:600;margin-bottom:10px}
.chart-wrap{position:relative;height:200px}
.hint{color:var(--mut);font-size:12px;text-align:center;margin:16px 0 0}

/* 回報 */
.actions{display:flex;gap:8px;margin:8px 0 12px;flex-wrap:wrap}
.ghost{padding:8px 13px;border:1px solid var(--line);border-radius:10px;background:transparent;color:var(--mut);font-size:13px}
.ghost.danger{color:var(--danger)}
.filtertabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.ft{padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--mut);font-size:13px}
.ft.active{background:#23304a;color:#9cc0ff;border-color:transparent;font-weight:600}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 15px;margin-bottom:10px}
.card.is-read{opacity:.55}
.card .top{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.dot{width:8px;height:8px;border-radius:50%;background:var(--info);display:inline-block;flex:none}
.badge-cat{font-size:12px;padding:2px 9px;border-radius:999px;background:#23304a;color:#9cc0ff}
.time{margin-left:auto;color:var(--mut);font-size:12px}
.subj{font-weight:600;margin:2px 0 5px}
.content{white-space:pre-wrap;word-break:break-word;font-size:14px}
.meta{display:flex;align-items:center;gap:10px;color:var(--mut);font-size:12px;margin-top:11px;border-top:1px dashed var(--line);padding-top:10px;flex-wrap:wrap}
.src{word-break:break-all}
.mini{margin-left:auto;font-size:13px;padding:7px 11px;border:1px solid var(--line);border-radius:9px;background:transparent;color:var(--txt)}
.mini.del{margin-left:0;color:var(--danger);border-color:transparent}
.empty{color:var(--mut);text-align:center;padding:48px 0}
