:root{
  --navy:#1A2332; --teal:#2D8B8B; --teal-d:#236f6f;
  --bg:#f4f6f8; --card:#fff; --line:#e2e8ee; --ink:#1f2a37; --muted:#6b7a8d;
  --danger:#c0392b; --warn:#b7791f; --ok:#2e7d5b;
}
*{box-sizing:border-box} body{margin:0;font-family:-apple-system,"Segoe UI","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--ink)}
a{color:var(--teal);text-decoration:none}
.hidden{display:none!important}
/* 登录 */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy),#0d1620)}
.login-card{background:#fff;border-radius:14px;padding:36px 32px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.login-card h1{font-size:18px;margin:0 0 4px;color:var(--navy)} .login-card p{margin:0 0 20px;color:var(--muted);font-size:13px}
/* 布局 */
#shell{display:flex;min-height:100vh}
#side{width:210px;background:var(--navy);color:#cdd7e0;flex-shrink:0;display:flex;flex-direction:column}
#side .brand{padding:18px 16px;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.08);font-size:15px}
#side .brand small{display:block;color:var(--teal);font-weight:400;font-size:11px;margin-top:2px}
#side nav a{display:block;padding:11px 16px;color:#cdd7e0;font-size:14px;border-left:3px solid transparent}
#side nav a:hover{background:rgba(255,255,255,.05)} #side nav a.active{background:rgba(45,139,139,.18);border-left-color:var(--teal);color:#fff}
#side .who{margin-top:auto;padding:14px 16px;font-size:12px;color:#8ea0b3;border-top:1px solid rgba(255,255,255,.08)}
#main{flex:1;padding:22px 26px;overflow:auto}
h2.page{margin:0 0 16px;font-size:19px;color:var(--navy)}
/* 组件 */
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:16px}
.btn{background:var(--teal);color:#fff;border:0;border-radius:7px;padding:9px 15px;font-size:13px;cursor:pointer}
.btn:hover{background:var(--teal-d)} .btn.sec{background:#eef2f6;color:var(--navy)} .btn.danger{background:var(--danger)}
.btn.sm{padding:5px 10px;font-size:12px}
input,select{width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:7px;font-size:13px;background:#fff}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;background:#fafbfc}
.row{display:flex;gap:14px;flex-wrap:wrap} .row>*{flex:1;min-width:120px}
.tag{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px}
.tag.warn{background:#fdf0d5;color:var(--warn)} .tag.ok{background:#dcf3e7;color:var(--ok)} .tag.danger{background:#fde0dd;color:var(--danger)} .tag.muted{background:#eef2f6;color:var(--muted)}
.kpi{font-size:24px;font-weight:700;color:var(--navy)} .kpi small{font-size:12px;color:var(--muted);font-weight:400;display:block}
.alert{padding:10px 12px;border-radius:7px;font-size:13px;margin:10px 0}
.alert.warn{background:#fdf0d5;color:#7a5b14} .alert.err{background:#fde0dd;color:#8c2c20} .alert.ok{background:#dcf3e7;color:#1d5d40}
.muted{color:var(--muted);font-size:12px}
@media(max-width:760px){ #side{width:60px} #side .brand small,#side nav a span{display:none} #main{padding:14px} }
