/* ── 简约科技风 · CDS 令牌（深色为主，可切浅色）── */
:root{
  /* 浅色 */
  --bg:#f6f7f9; --sf:#ffffff; --sf2:#fbfcfd; --sf3:#f1f3f6;
  --ink:#14171c; --sub:#697078; --muted:#9aa0a6;
  --bd:#e9ebef; --bd2:#dcdfe4;
  --ac:#2f6bff; --ac-d:#1d4fd0; --acs:#eaf1ff;
  --ok:#1d9e75; --oks:#e1f5ee; --wn:#ba7517; --wns:#faeeda; --dg:#dc4b4a; --dgs:#fbeaea;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --radius:9px; --card-r:13px;
  --shadow:0 1px 2px rgba(20,23,28,.04);
  --t:.32s cubic-bezier(.4,0,.2,1);
}
:root[data-theme="dark"]{
  --bg:#0d1117; --sf:#151b23; --sf2:#11161d; --sf3:#1c232d;
  --ink:#e6edf3; --sub:#8b949e; --muted:#646d78;
  --bd:#222a34; --bd2:#2d3741;
  --ac:#4d8bff; --ac-d:#6ba0ff; --acs:#15233b;
  --ok:#3fbf94; --oks:#10271f; --wn:#e0a23c; --wns:#2a2008; --dg:#f0716f; --dgs:#2a1414;
  --shadow:0 1px 2px rgba(0,0,0,.3);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:-apple-system,"PingFang SC","Microsoft YaHei",sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.6;
  transition:background var(--t),color var(--t);-webkit-font-smoothing:antialiased}
a{color:var(--ac);text-decoration:none}
button{cursor:pointer;font-family:inherit}
::selection{background:var(--acs);color:var(--ac-d)}
.ti{vertical-align:-2px}

/* ── 布局 ── */
.layout{display:flex;min-height:100vh}
.sidebar{width:212px;background:var(--sf2);border-right:.5px solid var(--bd);
  display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;
  transition:background var(--t),border-color var(--t)}
.brand{font-size:15px;font-weight:500;padding:18px 18px 14px;display:flex;align-items:center;gap:9px}
.brand .logo{width:9px;height:9px;border-radius:50%;background:var(--ac);box-shadow:0 0 0 4px var(--acs);transition:var(--t)}
.sidebar nav{flex:1;display:flex;flex-direction:column;gap:1px;padding:6px 10px;overflow-y:auto;position:relative}
.nav-ind{position:absolute;left:10px;right:10px;height:36px;background:var(--acs);border-radius:var(--radius);
  z-index:0;opacity:0;transition:transform .34s cubic-bezier(.34,1.3,.5,1),opacity .25s,background var(--t)}
.nav-ind::before{content:"";position:absolute;left:0;top:8px;height:20px;width:3px;border-radius:0 3px 3px 0;background:var(--ac)}
.sidebar nav a{position:relative;z-index:1;color:var(--sub);padding:9px 12px;border-radius:var(--radius);
  display:flex;align-items:center;gap:10px;font-size:13.5px;transition:color .2s}
.sidebar nav a .ti{font-size:17px;width:18px;text-align:center}
.sidebar nav a:hover{color:var(--ink)}
.sidebar nav a.active{color:var(--ac);font-weight:500}
.badge{background:var(--dg);color:#fff;border-radius:11px;padding:0 6px;font-size:11px;
  margin-left:auto;font-family:var(--mono);min-width:18px;text-align:center;line-height:18px}
.user-box{padding:12px 12px 14px;border-top:.5px solid var(--bd);font-size:13px;
  display:flex;flex-direction:column;gap:8px;transition:border-color var(--t)}
.user-row{display:flex;align-items:center;gap:8px;padding:0 4px}
.role-tag{background:var(--sf3);border-radius:6px;padding:1px 7px;font-size:11px;color:var(--sub)}
.theme-toggle{width:100%;height:36px;border:.5px solid var(--bd2);border-radius:var(--radius);
  background:var(--sf);color:var(--ink);display:flex;align-items:center;justify-content:center;gap:7px;
  font-size:13px;transition:var(--t)}
.theme-toggle .ti{font-size:16px}
.theme-toggle:hover{color:var(--ac);border-color:var(--ac)}
.theme-toggle:active{transform:scale(.98)}
.logout{color:var(--muted);font-size:12.5px;display:flex;align-items:center;gap:6px;padding:0 4px}
.logout:hover{color:var(--dg)}
.content{margin-left:212px;flex:1;padding:24px 28px;max-width:1440px;animation:pageIn .4s cubic-bezier(.2,.7,.3,1)}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── 页头/工具条 ── */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-head h1{font-size:21px;margin:0;font-weight:500;display:flex;align-items:center;gap:9px}
.page-head h1 .ti{color:var(--ac);font-size:22px}
.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}

/* ── 按钮 ── */
.btn{padding:7px 14px;border:.5px solid var(--bd2);background:var(--sf);border-radius:var(--radius);
  color:var(--ink);font-size:13.5px;transition:var(--t);display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--ac);color:var(--ac)}
.btn:active{transform:scale(.97)}
.btn.primary{background:var(--ac);color:#fff;border-color:var(--ac)}
.btn.primary:hover{background:var(--ac-d);border-color:var(--ac-d);color:#fff}
.btn.sm{padding:4px 10px;font-size:12.5px}
.btn.danger{color:var(--dg);border-color:transparent;background:var(--dgs)}
.btn.danger:hover{border-color:var(--dg)}

/* ── 卡片/表格 ── */
.card{background:var(--sf);border:.5px solid var(--bd);border-radius:var(--card-r);box-shadow:var(--shadow);transition:var(--t)}
table.grid{width:100%;border-collapse:collapse;background:var(--sf);border-radius:var(--card-r);
  overflow:hidden;border:.5px solid var(--bd);transition:var(--t)}
table.grid th,table.grid td{padding:10px 13px;text-align:left;border-bottom:.5px solid var(--bd);white-space:nowrap}
table.grid th{background:var(--sf2);color:var(--sub);font-weight:500;font-size:12.5px;letter-spacing:.02em}
table.grid tbody tr{transition:background .15s}
table.grid tbody tr:last-child td{border-bottom:none}
table.grid tbody tr:hover td{background:var(--sf3)}
table.grid .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:13px}
table.grid td a{font-family:var(--mono);font-size:13px}

/* ── 表单 ── */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px 22px;background:var(--sf);
  padding:22px;border:.5px solid var(--bd);border-radius:var(--card-r);transition:var(--t)}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12.5px;color:var(--sub)}
.field input,.field select,.field textarea{padding:9px 11px;border:.5px solid var(--bd2);border-radius:var(--radius);
  font-size:14px;font-family:inherit;background:var(--sf2);color:var(--ink);transition:border-color .2s,box-shadow .2s,background var(--t)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px var(--acs)}
.field textarea{min-height:68px;resize:vertical}
.form-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end;margin-top:6px}

/* ── 标签 ── */
.pill{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;background:var(--sf3);color:var(--sub)}
.pill.ok{background:var(--oks);color:var(--ok)} .pill.warn{background:var(--wns);color:var(--wn)} .pill.danger{background:var(--dgs);color:var(--dg)}

/* ── 看板 ── */
.kanban{display:flex;gap:13px;overflow-x:auto;padding-bottom:12px}
.kcol{flex:0 0 250px;background:var(--sf2);border:.5px solid var(--bd);border-radius:var(--card-r);padding:9px;transition:var(--t)}
.kcol h3{font-size:12.5px;margin:5px 7px 9px;color:var(--sub);font-weight:500;display:flex;justify-content:space-between}
.kcol h3 span{font-family:var(--mono);background:var(--sf3);border-radius:10px;padding:0 7px}
.kcard{background:var(--sf);border:.5px solid var(--bd);border-radius:10px;padding:11px;margin-bottom:9px;
  box-shadow:var(--shadow);cursor:grab;transition:transform .2s,border-color .2s,box-shadow .2s;animation:fadeUp .45s backwards}
.kcard:hover{transform:translateY(-3px);border-color:var(--ac);box-shadow:0 0 0 3px var(--acs)}
.kcard.drag{opacity:.45}
.kcard .t{font-weight:500;margin-bottom:6px;font-family:var(--mono);font-size:13px}
.kcard .t a{color:var(--ink)} .kcard .t a:hover{color:var(--ac)}
.kcard .m{font-size:12px;color:var(--sub);display:flex;justify-content:space-between;gap:6px;align-items:center;margin-top:3px}
.kcard .m .num{font-family:var(--mono)}

/* ── 看板/仪表盘动画 ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── 仪表盘 ── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:20px}
.stat{background:var(--sf);border:.5px solid var(--bd);border-radius:var(--card-r);padding:16px 18px;
  transition:transform .2s,border-color .2s,background var(--t);animation:fadeUp .5s backwards}
.stat:hover{transform:translateY(-3px);border-color:var(--ac)}
.stat .k{font-size:12.5px;color:var(--sub);margin-bottom:7px}
.stat .v{font-size:25px;font-weight:500;font-family:var(--mono);letter-spacing:-.5px}
.stat .v.dg{color:var(--dg)}
.charts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.chart-box{background:var(--sf);border:.5px solid var(--bd);border-radius:var(--card-r);padding:16px;transition:var(--t);animation:fadeUp .55s backwards}
.chart-box h3{margin:0 0 12px;font-size:14px;font-weight:500;color:var(--sub)}
.chart{height:300px}

/* ── 详情 ── */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px 24px;background:var(--sf);
  padding:20px;border:.5px solid var(--bd);border-radius:var(--card-r);margin-bottom:18px;transition:var(--t)}
.detail-grid .kv{display:flex;flex-direction:column;gap:3px}
.detail-grid .kv .k{font-size:12px;color:var(--sub)}
.detail-grid .kv .v{font-size:14px}
.section{margin-top:22px}
.section h2{font-size:16px;margin:0 0 12px;font-weight:500;display:flex;align-items:center;gap:7px}
.muted{color:var(--sub)}
.empty{padding:30px;text-align:center;color:var(--muted);background:var(--sf);border:.5px dashed var(--bd2);border-radius:var(--card-r)}

/* ── 登录 ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 50% 0%,var(--sf2) 0%,var(--bg) 60%)}
.login-card{background:var(--sf);padding:38px 32px;border-radius:16px;border:.5px solid var(--bd);
  box-shadow:0 12px 40px rgba(0,0,0,.12);width:340px;display:flex;flex-direction:column;gap:13px;text-align:center;
  animation:fadeUp .5s}
.login-card h1{font-size:20px;margin:0;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}
.login-card h1 .ti{color:var(--ac)}
.login-card .sub{color:var(--sub);margin:0 0 6px;font-size:13px}
.login-card input{padding:11px 13px;border:.5px solid var(--bd2);border-radius:var(--radius);font-size:14px;
  background:var(--sf2);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.login-card input:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px var(--acs)}
.login-card button{padding:11px;background:var(--ac);color:#fff;border:none;border-radius:var(--radius);font-size:15px;transition:var(--t)}
.login-card button:hover{background:var(--ac-d)}
.err{background:var(--dgs);color:var(--dg);padding:9px;border-radius:var(--radius);font-size:13px}

/* 滚动条 */
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:9px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
