:root{--blue-900:#003a8c;--blue-800:#064da6;--blue-700:#1262c4;--blue-100:#e9f3ff;--blue-050:#f5f9ff;--line:#d7e5f7;--text:#18263a;--muted:#6a7890;--green:#16a36b;--orange:#fa8c16;--red:#e53935;--card:#fff}*{box-sizing:border-box}body{color:var(--text);background:#f3f7fc;margin:0;font-family:Arial,Microsoft YaHei,PingFang SC,sans-serif;font-size:13px}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}.login-page{background:linear-gradient(120deg,#003a8c 0%,#0759b7 42%,#f3f7fc 42%);grid-template-columns:1fr 1.1fr;min-height:100vh;display:grid}.login-hero{color:#fff;flex-direction:column;justify-content:space-between;padding:64px 56px;display:flex}.login-hero h1{margin:16px 0 12px;font-size:34px}.login-hero p{max-width:460px;line-height:1.8}.role-grid{align-self:center;gap:18px;width:min(760px,92%);display:grid}.role-card{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;padding:24px;box-shadow:0 10px 30px #19457a1f}.role-card h2{color:var(--blue-900);margin:0 0 8px;font-size:20px}.role-card p{color:var(--muted);margin:0 0 18px}.primary-btn,.ghost-btn,.danger-btn,.success-btn{white-space:nowrap;border:1px solid #0000;border-radius:5px;align-items:center;gap:6px;min-height:30px;padding:0 12px;display:inline-flex}.primary-btn{color:#fff;background:var(--blue-800)}.success-btn{color:#fff;background:var(--green)}.danger-btn{color:#fff;background:var(--red)}.ghost-btn{color:var(--blue-800);border-color:var(--line);background:#fff}.group-layout{grid-template-columns:118px 1fr;min-height:100vh;display:grid}.side-nav{color:#fff;background:#003a8c;flex-direction:column;padding:14px 10px;display:flex}.brand-mark{padding:8px 6px 16px;font-size:17px;font-weight:700}.nav-link{color:#d7e8ff;border-radius:5px;align-items:center;gap:7px;min-height:34px;padding:0 8px;display:flex}.nav-link.active,.nav-link:hover{color:#fff;background:#1768c9}.app-main{min-width:0;padding:14px 18px}.topbar{color:#fff;background:linear-gradient(90deg,#003a8c,#075fc3);justify-content:space-between;align-items:center;height:48px;padding:0 18px;display:flex;box-shadow:0 3px 12px #1440822e}.topbar h1,.page-title h1{margin:0;font-size:20px}.topbar-actions,.filters,.toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.top-shell{background:#f3f7fc;min-height:100vh}.page-title{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.filter-bar{border:1px solid var(--line);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px;display:flex}.filter-bar select,.filter-bar input,.form-grid input,.form-grid textarea,.form-grid select{border:1px solid var(--line);min-height:30px;color:var(--text);background:#fff;border-radius:5px;padding:0 9px}.form-grid textarea{resize:vertical;min-height:72px;padding-top:8px}.dashboard-grid{grid-template-columns:repeat(12,1fr);gap:12px;display:grid}.kpi-row{grid-column:1/-1;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.kpi-card,.panel,.mini-card{background:var(--card);border:1px solid var(--line);border-radius:8px;box-shadow:0 3px 12px #11447e0f}.kpi-card{text-align:left;min-height:86px;padding:12px}.kpi-title{color:var(--muted);margin-bottom:6px;font-size:12px}.kpi-value{color:var(--blue-900);font-size:28px;font-weight:700}.kpi-delta{color:var(--red);margin-top:3px;font-size:12px}.panel{min-height:160px;padding:12px}.panel h2{color:var(--blue-900);justify-content:space-between;align-items:center;margin:0 0 10px;font-size:15px;display:flex}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-7{grid-column:span 7}.span-8{grid-column:span 8}.span-9{grid-column:span 9}.span-12{grid-column:span 12}.overview-list,.todo-list,.timeline,.audit-list{gap:8px;display:grid}.overview-item,.todo-item,.message-item,.timeline-item,.audit-item{background:#fbfdff;border:1px solid #e5eef9;border-radius:6px;padding:9px}.overview-item{grid-template-columns:1fr auto;gap:8px;display:grid}.status-pill,.badge{background:var(--blue-100);min-height:22px;color:var(--blue-800);border-radius:999px;justify-content:center;align-items:center;padding:0 8px;font-size:12px;display:inline-flex}.status-red{color:var(--red);background:#fff1f0}.status-orange{color:var(--orange);background:#fff7e6}.status-green{color:var(--green);background:#edf9f3}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #e8f0fa;padding:8px 7px}.data-table th{color:#4d6688;background:#f6faff;font-weight:600}.data-table tbody tr{cursor:pointer}.data-table tbody tr:hover{background:#f5f9ff}.progress{background:#edf3fb;border-radius:999px;height:7px;overflow:hidden}.progress span{background:linear-gradient(90deg,#2f7ff0,#19b78a);height:100%;display:block}.drawer-backdrop{z-index:20;background:#05152d33;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:#fff;width:min(520px,94vw);height:100%;padding:18px;overflow:auto;box-shadow:-8px 0 28px #0b2f602e}.drawer h2{color:var(--blue-900);margin:0 0 6px}.drawer-section{border-top:1px solid var(--line);margin-top:12px;padding-top:12px}.form-grid{gap:10px;display:grid}.chart-box{width:100%;height:210px}.module-page{min-height:100vh;padding:18px}.quick-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.mini-card{padding:14px}.mini-card strong{color:var(--blue-900);margin-bottom:8px;display:block}.metric-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.forbidden{background:#f3f7fc;place-items:center;min-height:100vh;display:grid}.forbidden>div{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;width:min(520px,92vw);padding:28px}@media (max-width:1100px){.kpi-row{grid-template-columns:repeat(3,1fr)}.span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.span-9{grid-column:span 12}.quick-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.login-page{background:#f3f7fc;grid-template-columns:1fr}.login-hero{background:var(--blue-900);min-height:260px}.group-layout{grid-template-columns:1fr}.side-nav{flex-direction:row;position:static;overflow-x:auto}.brand-mark{white-space:nowrap}.kpi-row,.metric-grid,.quick-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}}
