/* CheckAI online audit — 共享样式
   design tokens / 排版规则全部来自 token-audit-demo.html, 此文件只是抽取共用部分.
   index.html / audit.html 都引用 /static/assets/style.css. */

:root{
  --paper:        #f3eede;
  --paper-2:      #ecdfb4;
  --paper-soft:   #f8f3e3;
  --paper-warm:   #ebe4cf;

  --ink:          #1a1a1a;
  --ink-soft:     #3d3a35;
  --ink-mute:     #7a746a;
  --ink-faint:    #a8a195;

  --navy:         #1a2332;
  --red:          #c8344a;
  --red-dark:     #a52938;
  --red-soft:     #e8a5af;
  --red-wash:     #f4e2e4;

  --gold:         #b8985a;
  --gold-soft:    #d8bd7e;
  --green:        #4a7a4a;
  --green-soft:   #c0d8b8;

  --line:         #c8bf9c;
  --line-soft:    #ddd4b3;
  --line-faint:   #ebe4cb;

  --serif:  'Instrument Serif','Noto Serif SC',Georgia,serif;
  --sans:   'Geist','PingFang SC',system-ui,sans-serif;
  --mono:   'JetBrains Mono','SF Mono',Menlo,monospace;

  --shadow-soft: 0 1px 0 rgba(26,26,26,.04), 0 4px 14px rgba(26,26,26,.06);
  --shadow-card: 0 1px 0 rgba(26,26,26,.06), 0 10px 28px rgba(26,26,26,.08);
}

*{box-sizing:border-box;-webkit-font-smoothing:antialiased}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:15px;
  line-height:1.55;
  background-image:
    radial-gradient(rgba(120,100,60,.05) 1px,transparent 1px),
    radial-gradient(rgba(120,100,60,.04) 1px,transparent 1px);
  background-size:3px 3px,5px 5px;
  background-position:0 0,1px 2px;
  min-height:100vh;
}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}
input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
.hidden{display:none !important}

/* ─── appbar ───────────────────────────────────────── */
.appbar{
  position:sticky;top:0;z-index:50;
  background:rgba(243,238,222,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.appbar-inner{max-width:1400px;margin:0 auto;padding:14px 32px;display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;letter-spacing:.5px}
.brand-mark{
  width:30px;height:30px;background:var(--red);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  border-radius:3px;font-family:var(--serif);font-size:18px;
}
.brand-tag{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute)}

.page{max-width:1400px;margin:0 auto;padding:48px 32px 80px}

/* ─── hero ─────────────────────────────────────────── */
.idle{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:start}
.hero-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink-mute);
  padding-bottom:14px;border-bottom:1px solid var(--line);
  margin-bottom:28px;display:flex;align-items:center;gap:10px;
}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
.hero-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px,6vw,76px);line-height:1.05;letter-spacing:-1px;
  margin:0 0 28px;color:var(--ink);
}
.hero-title em{font-style:italic;color:var(--red);position:relative}
.hero-title em::after{
  content:'';position:absolute;left:0;right:0;bottom:.08em;height:.18em;
  background:linear-gradient(transparent 50%,rgba(200,52,74,.18) 50%);
}
.hero-lead{font-size:17px;line-height:1.7;color:var(--ink-soft);max-width:480px;margin-bottom:32px}
.hero-bullets{list-style:none;padding:0;margin:0 0 40px;font-size:14px}
.hero-bullets li{display:flex;gap:12px;padding:11px 0;border-bottom:1px dashed var(--line-soft);color:var(--ink-soft)}
.hero-bullets li:last-child{border-bottom:none}
.hero-bullets .num{font-family:var(--mono);font-size:11px;color:var(--ink-mute);min-width:24px;padding-top:3px}
.hero-bullets .txt strong{color:var(--ink);font-weight:600}

/* ─── form card ───────────────────────────────────── */
.formcard{
  background:var(--paper-soft);
  border:1px solid var(--line);
  border-radius:4px;
  padding:32px;
  position:relative;
  box-shadow:var(--shadow-card);
}
.formcard::before{
  content:'';position:absolute;top:-1px;left:-1px;right:-1px;height:5px;
  background:repeating-linear-gradient(90deg,var(--ink) 0 8px,transparent 8px 14px);
  opacity:.85;
}
.formcard-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--line-soft);
}
.formcard-head h2{font-family:var(--serif);font-weight:400;font-size:30px;margin:0;letter-spacing:-.5px}
.formcard-head .step{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--ink-mute)}

.field{margin-bottom:18px}
.field-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.field-label span{font-size:13px;font-weight:500}
.field-label .hint{font-family:var(--mono);font-size:10px;color:var(--ink-mute)}

.input,.select{
  width:100%;padding:11px 14px;
  background:var(--paper);border:1px solid var(--line);border-radius:3px;
  font-size:14px;transition:border-color .15s,box-shadow .15s;
}
.input:focus,.select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(26,26,26,.05)}
.input.mono{font-family:var(--mono);font-size:13px;letter-spacing:.3px}

.destroy-note{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;color:var(--green);margin-top:6px;letter-spacing:.5px;
}
.destroy-note .pulse{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ─── pill 选择器 (cliMode / depth / modelpill) ───── */
.pillgrid{display:grid;gap:8px}
.pillgrid-2{grid-template-columns:1fr 1fr}
.pillgrid-3{grid-template-columns:1fr 1fr 1fr}
.pill{
  padding:10px 12px;background:var(--paper);border:1px solid var(--line);
  border-radius:3px;cursor:pointer;transition:all .15s;text-align:left;position:relative;
}
.pill .v{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink)}
.pill .l{font-size:11px;color:var(--ink-mute);margin-top:2px}
.pill .tag{
  position:absolute;top:6px;right:8px;font-size:9px;
  background:var(--ink);color:var(--paper);padding:1px 5px;border-radius:2px;
  font-family:var(--mono);letter-spacing:.5px;
}
.pill:hover{border-color:var(--ink-mute)}
.pill.active{border-color:var(--ink);background:var(--paper-warm);box-shadow:inset 0 0 0 1px var(--ink)}

.modelgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ─── 主按钮 ──────────────────────────────────────── */
.btn-primary{
  width:100%;padding:16px;
  background:var(--ink);color:var(--paper);
  font-family:var(--serif);font-size:21px;letter-spacing:.3px;
  border-radius:3px;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .1s,background .2s;
}
.btn-primary:hover{background:var(--navy);transform:translateY(-1px)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-secondary{
  padding:10px 18px;background:transparent;border:1px solid var(--line);
  border-radius:3px;font-family:var(--mono);font-size:12px;color:var(--ink-soft);
}
.btn-secondary:hover{border-color:var(--ink)}

.form-foot{margin-top:14px;font-family:var(--mono);font-size:10px;color:var(--ink-mute);text-align:center;letter-spacing:.5px}
.form-foot .sep{margin:0 6px;opacity:.4}

/* ─── detecting / 进度 ────────────────────────────── */
.detect-head{display:flex;align-items:baseline;gap:18px;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:26px}
.detect-head .badge{
  background:var(--red);color:var(--paper);
  font-family:var(--mono);font-size:10px;padding:4px 10px;border-radius:2px;letter-spacing:2px;
}
.detect-head .target{font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.detect-head .target .ep{color:var(--ink-mute);margin-left:6px}
.detect-title{font-family:var(--serif);font-weight:400;font-size:46px;line-height:1.05;letter-spacing:-.6px;margin:0 0 14px}
.detect-title em{font-style:italic;color:var(--red)}
.detect-sub{font-size:15px;color:var(--ink-soft);max-width:560px;margin-bottom:26px}

.progress-track{height:6px;background:var(--paper-warm);border:1px solid var(--line-soft);border-radius:3px;overflow:hidden;margin-bottom:8px}
.progress-fill{height:100%;background:var(--ink);transition:width .4s ease}
.progress-meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);margin-bottom:24px}

.stages{display:flex;flex-direction:column;gap:0;margin-bottom:28px}
.stage-row{
  display:grid;grid-template-columns:36px 1fr auto;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--line-soft);align-items:center;
  transition:opacity .25s;
}
.stage-row:last-child{border-bottom:none}
.stage-row.pending{opacity:.4}
.stage-row .idx{font-family:var(--mono);font-size:11px;color:var(--ink-mute)}
.stage-row.active .idx::after{content:' ●';color:var(--red);animation:pulse 1.4s infinite}
.stage-row .title{font-size:14px;font-weight:500}
.stage-row .desc{font-family:var(--mono);font-size:11px;color:var(--ink-mute);margin-top:2px}
.stage-row .stat{font-family:var(--mono);font-size:11px;letter-spacing:.3px}
.stage-row.done .stat{color:var(--green)}
.stage-row.active .stat{color:var(--red)}
.stage-row.fail .stat{color:var(--red);font-weight:600}

.eventlog{
  background:var(--paper-soft);border:1px solid var(--line-soft);border-radius:3px;
  padding:12px 14px;max-height:240px;overflow-y:auto;
  font-family:var(--mono);font-size:11.5px;line-height:1.6;color:var(--ink-soft);
}
.eventlog .ev{padding:2px 0;border-bottom:1px dashed var(--line-faint)}
.eventlog .ev:last-child{border-bottom:none}
.eventlog .ev .ts{color:var(--ink-faint);margin-right:8px}
.eventlog .ev.fail{color:var(--red)}
.eventlog .ev.done{color:var(--green)}

.errbox{
  margin-top:20px;padding:16px 18px;
  background:var(--red-wash);border:1px solid var(--red-soft);border-radius:3px;
}
.errbox h3{margin:0 0 8px;font-family:var(--serif);font-weight:400;font-size:20px;color:var(--red-dark)}
.errbox .body{font-size:13px;color:var(--ink-soft)}
.errbox pre{
  background:var(--paper);padding:10px 12px;font-family:var(--mono);font-size:11px;
  margin-top:10px;overflow-x:auto;border:1px solid var(--line-soft);max-height:240px;
}

/* ─── result ────────────────────────────────────── */
.result-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.verdict-block{}
.verdict-eyebrow{
  display:flex;gap:10px;align-items:baseline;
  font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:1px;
  padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.verdict-eyebrow b{color:var(--ink-soft);font-weight:600}
.verdict-title{font-family:var(--serif);font-weight:400;font-size:54px;line-height:1.05;letter-spacing:-.5px;margin:0 0 26px}
.verdict-title em{font-style:italic;color:var(--red)}

.verdict-stamp{display:flex;align-items:center;gap:24px;margin-bottom:32px}
.stamp-svg{width:140px;height:140px;flex-shrink:0}
.verdict-conf{font-family:var(--mono);font-size:12px;color:var(--ink-mute)}
.verdict-conf b{display:block;font-family:var(--serif);font-size:30px;color:var(--ink);font-weight:400;margin-bottom:4px}

.scores4{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.score-card{
  background:var(--paper-soft);border:1px solid var(--line-soft);border-radius:3px;
  padding:14px 16px;
}
.score-card .lbl{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute);text-transform:uppercase}
.score-card .v{font-family:var(--serif);font-size:30px;font-weight:400;margin-top:4px;line-height:1}
.score-card .l{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);margin-top:6px}
.score-card.good .v{color:var(--green)}
.score-card.bad .v{color:var(--red)}
.score-card.warn .v{color:var(--gold)}

.report-frame{
  width:100%;border:1px solid var(--line);border-radius:3px;
  background:var(--paper);
}
.report-link{margin-top:14px;display:inline-block;font-family:var(--mono);font-size:11px;color:var(--ink-soft);border-bottom:1px solid var(--ink-soft)}

/* ─────────────────────────────────────────────────────────
   v0.3 — 用户系统 + 个人信息 + 历史 + 水印
   ───────────────────────────────────────────────────────── */

/* appbar 用户态 */
.appbar-spacer{flex:1}
.appbar-links{display:flex;align-items:center;gap:18px}
.appbar-links a,.appbar-links button{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.5px;color:var(--ink-mute);
  padding:6px 8px;border-radius:3px;transition:all .15s;
}
.appbar-links a:hover,.appbar-links button:hover{color:var(--ink);background:var(--paper-warm)}
.appbar-links a.active{color:var(--red)}
.userpill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink);
  padding:5px 12px;background:var(--paper-soft);
  border:1px solid var(--line-soft);border-radius:30px;
}
.userpill .avatar{
  width:22px;height:22px;border-radius:50%;background:var(--ink);
  color:var(--paper);display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:12px;
}

/* 小卡 (登录/profile/简单表单) */
.cardpage{max-width:520px;margin:80px auto;padding:0 24px}
.cardpage h1{font-family:var(--serif);font-weight:400;font-size:38px;margin:0 0 6px}
.cardpage h1 em{font-style:italic;color:var(--red)}
.cardpage .lead{font-size:14px;color:var(--ink-mute);margin:0 0 24px}
.card{
  background:var(--paper-soft);border:1px solid var(--line);border-radius:3px;
  padding:32px;box-shadow:var(--shadow-card);
}
.card .tabs{display:flex;gap:0;margin:-16px -16px 24px;border-bottom:1px solid var(--line-soft)}
.card .tabs button{
  flex:1;padding:14px;background:transparent;color:var(--ink-mute);
  font-family:var(--mono);font-size:11.5px;letter-spacing:1px;text-transform:uppercase;
  border-bottom:2px solid transparent;
}
.card .tabs button.active{color:var(--red);border-bottom-color:var(--red)}
.note{font-size:12.5px;color:var(--ink-mute);margin-top:18px}
.note .lk{color:var(--red);border-bottom:1px solid var(--red);cursor:pointer}
.flash{
  padding:12px 14px;border-radius:3px;font-size:13px;margin-bottom:18px;
  background:var(--red-wash);color:var(--red-dark);border:1px solid var(--red-soft);
}
.flash.ok{background:#e7efde;border-color:var(--green-soft);color:var(--green)}

/* 个人信息 */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:8px 0 24px}
.pi{background:var(--paper);border:1px solid var(--line-soft);border-radius:3px;padding:16px}
.pi .lbl{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.pi .v{font-family:var(--serif);font-size:28px;line-height:1.2}
.pi .v small{font-family:var(--mono);font-size:11px;color:var(--ink-mute);margin-left:6px}
.pi .l{font-family:var(--mono);font-size:11px;color:var(--ink-mute);margin-top:6px}
.quota-bar{position:relative;height:6px;background:var(--paper-warm);border-radius:3px;overflow:hidden;margin-top:10px}
.quota-bar > span{position:absolute;left:0;top:0;bottom:0;background:var(--green);transition:width .3s}
.quota-bar.warn > span{background:var(--gold)}
.quota-bar.full > span{background:var(--red)}

/* 历史表格 */
.history-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;border-bottom:1px solid var(--line);padding-bottom:14px}
.history-head h1{font-family:var(--serif);font-weight:400;font-size:46px;margin:0;letter-spacing:-.5px}
.history-head h1 em{font-style:italic;color:var(--red)}
.history-head .sub{font-family:var(--mono);font-size:12px;color:var(--ink-mute);letter-spacing:.5px}
.history-table{width:100%;border-collapse:collapse;font-size:13.5px}
.history-table thead th{
  text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-mute);
}
.history-table tbody td{padding:14px;border-bottom:1px dashed var(--line-soft);vertical-align:top}
.history-table tbody tr:hover{background:var(--paper-soft)}
.history-table .nm{font-family:var(--serif);font-size:16px;color:var(--ink)}
.history-table .ts{font-family:var(--mono);font-size:11px;color:var(--ink-mute)}
.history-table .ch{font-family:var(--mono);font-size:11.5px;color:var(--ink-soft);display:block;margin-top:2px}
.history-table .act{display:flex;gap:8px}
.history-table .act a, .history-table .act button{
  font-family:var(--mono);font-size:11px;padding:6px 10px;
  border:1px solid var(--line);border-radius:2px;background:var(--paper);color:var(--ink-soft);
  cursor:pointer;
}
.history-table .act a:hover, .history-table .act button:hover{background:var(--paper-warm);color:var(--ink)}
.history-table .act .dl{color:var(--red);border-color:var(--red-soft)}
.empty-state{
  text-align:center;padding:80px 32px;color:var(--ink-mute);
  font-family:var(--serif);font-size:22px;
}
.empty-state .sub{font-family:var(--mono);font-size:12px;margin-top:8px;color:var(--ink-faint)}

/* verdict / status 徽章 */
.tag{
  display:inline-block;padding:3px 8px;border-radius:2px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;
  border:1px solid;
}
.tag.genuine{color:var(--green);border-color:var(--green-soft);background:#eef5e8}
.tag.impostor{color:var(--red-dark);border-color:var(--red-soft);background:var(--red-wash)}
.tag.inconclusive{color:var(--gold);border-color:var(--gold-soft);background:#f5ecd2}
.tag.running{color:var(--navy);border-color:#c3cfdb;background:#dfe7ef}
.tag.failed{color:var(--ink-mute);border-color:var(--line);background:var(--paper-soft)}

/* 水印 layer (报告页背景叠加) */
.wm-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:2}
.wm-tile{
  position:absolute;color:rgba(26,26,26,.08);
  font-family:var(--mono);font-size:13px;white-space:nowrap;
  transform:rotate(-28deg);letter-spacing:.5px;
}

/* admin 通用样式 (M5 写 admin.html 用) */
.admin-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;max-width:1400px;margin:0 auto;padding:24px}
.admin-nav{position:sticky;top:80px;align-self:start;background:var(--paper-soft);border:1px solid var(--line-soft);border-radius:3px;padding:14px 8px;height:fit-content}
.admin-nav .lbl{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute);text-transform:uppercase;padding:4px 12px;margin-bottom:6px}
.admin-nav .nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;font-family:var(--mono);font-size:12px;color:var(--ink-soft);cursor:pointer;border-radius:2px}
.admin-nav .nav-item:hover{background:var(--paper-warm)}
.admin-nav .nav-item.active{background:var(--ink);color:var(--paper)}
.admin-nav .nav-item .ix{font-size:9px;letter-spacing:1px;color:var(--ink-mute);min-width:18px}
.admin-nav .nav-item.active .ix{color:var(--paper)}
.admin-main{min-height:60vh}
.admin-h{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.admin-h h1{font-family:var(--serif);font-weight:400;font-size:38px;margin:0}
.admin-h h1 em{font-style:italic;color:var(--red)}
.badge{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute);padding:4px 10px;border:1px solid var(--line);border-radius:30px}
.admin-desc{font-size:13.5px;color:var(--ink-soft);margin:0 0 24px}
.adm-section{background:var(--paper-soft);border:1px solid var(--line-soft);border-radius:3px;margin-bottom:18px}
.adm-sec-head{display:flex;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line-soft)}
.adm-sec-head h3{font-family:var(--serif);font-weight:400;font-size:20px;margin:0}
.adm-sec-head .meta{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute)}
.adm-sec-body{padding:18px}
.adm-row{display:grid;grid-template-columns:1fr auto;gap:16px;padding:12px 0;border-bottom:1px dashed var(--line-soft);align-items:center}
.adm-row:last-child{border-bottom:none}
.adm-row .lbl{font-size:14px;color:var(--ink)}
.adm-row .desc{font-size:12px;color:var(--ink-mute);margin-top:2px}
.toggle{width:42px;height:22px;background:var(--line);border-radius:11px;position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}
.toggle::after{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on{background:var(--green)}
.toggle.on::after{transform:translateX(20px)}
.num-input{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;color:var(--ink-mute)}
.num-input input{width:64px;padding:6px 8px;border:1px solid var(--line);border-radius:2px;background:var(--paper);font-family:var(--mono);text-align:center}
.list-editor{margin-top:8px;background:var(--paper);border:1px solid var(--line-soft);border-radius:2px;padding:8px;font-family:var(--mono);font-size:12px;min-height:80px}
.list-editor .item{display:flex;justify-content:space-between;padding:6px 8px;border-bottom:1px dashed var(--line-faint)}
.list-editor .item:last-child{border-bottom:none}
.list-editor button{font-size:10px;color:var(--red);cursor:pointer}
.list-editor input{width:100%;border:none;background:transparent;padding:4px 0;font-family:var(--mono);font-size:12px;outline:none;border-bottom:1px solid var(--line-faint)}

/* KPI 卡 (dashboard) */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kpi{background:var(--paper-soft);border:1px solid var(--line);border-radius:3px;padding:18px}
.kpi .l{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--ink-mute);margin-bottom:8px}
.kpi .v{font-family:var(--serif);font-size:42px;line-height:1;letter-spacing:-1px;margin-bottom:4px}
.kpi .d{font-family:var(--mono);font-size:11px;color:var(--ink-mute)}
.bar-chart{background:var(--paper-soft);border:1px solid var(--line);border-radius:3px;padding:24px;min-height:240px}
.bar-chart h4{font-family:var(--serif);font-weight:400;font-size:20px;margin:0 0 18px}
.bars{display:flex;gap:6px;height:160px;align-items:flex-end}
.bar{flex:1;background:var(--ink);border-radius:1px 1px 0 0;position:relative;transition:background .15s}
.bar:hover{background:var(--red)}
.bar .b-l{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;color:var(--ink-mute);white-space:nowrap}
.bar .b-v{position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;color:var(--ink)}

@media (max-width: 980px){
  .profile-grid{grid-template-columns:1fr}
  .admin-layout{grid-template-columns:1fr}
  .admin-nav{position:relative;top:0}
  .kpi-grid{grid-template-columns:1fr 1fr}
}
