:root{--brand: #103D38;--brand-2: #1A6B62;--brand-accent: #2E9B8C;--sidebar-bg: #0e3b36;--sidebar-fg: #cfe3df;--sidebar-fg-dim: #7fa8a1;--sidebar-active: #1A6B62;--bg: #f4f6f7;--surface: #ffffff;--line: #e6eaec;--line-strong: #d3dadd;--text: #1d2b2a;--text-dim: #6b7b79;--text-mute: #9aa8a6;--pos: #128a5e;--neg: #c0392b;--warn: #d98a1f;--info: #2c6fb0;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 2px rgba(16,61,56,.06), 0 1px 3px rgba(16,61,56,.05);--font: "Hiragino Kaku Gothic ProN", "Hiragino Sans", -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:232px;flex-shrink:0;background:linear-gradient(180deg,#124540 0%,var(--sidebar-bg) 100%);color:var(--sidebar-fg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar .brand{padding:22px 20px 18px;font-weight:700;font-size:16px;letter-spacing:.06em;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar .brand small{display:block;font-weight:400;font-size:11px;letter-spacing:.18em;color:var(--sidebar-fg-dim);margin-top:4px}.nav{padding:10px;overflow-y:auto;flex:1}.nav-group{font-size:10.5px;letter-spacing:.16em;color:var(--sidebar-fg-dim);padding:14px 12px 6px}.nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;margin:1px 0;color:var(--sidebar-fg);font-size:13.5px}.nav a .ic{width:18px;text-align:center;opacity:.85;font-size:15px}.nav a:hover{background:#ffffff0f}.nav a.active{background:var(--sidebar-active);color:#fff;font-weight:600}.sidebar .foot{padding:12px 18px;font-size:11px;color:var(--sidebar-fg-dim);border-top:1px solid rgba(255,255,255,.08)}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:58px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:10}.topbar h1{font-size:17px;margin:0;font-weight:700;letter-spacing:.02em}.topbar .spacer{flex:1}.topbar .asof{font-size:12px;color:var(--text-dim)}.content{padding:24px 28px 60px;max-width:1280px;width:100%}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card .card-h{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}.card .card-h .kicker{font-size:11px;letter-spacing:.14em;color:var(--text-mute)}.card .card-h h2{font-size:14.5px;margin:0;font-weight:700}.card .card-b{padding:16px 18px}.grid{display:grid;gap:16px}.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.stat .label{font-size:12px;color:var(--text-dim);display:flex;align-items:center;gap:6px}.stat .value{font-size:26px;font-weight:700;margin-top:6px;letter-spacing:.01em;font-variant-numeric:tabular-nums}.stat .sub{font-size:11.5px;color:var(--text-mute);margin-top:4px}.stat.accent{border-top:3px solid var(--brand-accent)}.acct{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);position:relative}.acct .name{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:8px}.acct .tag{font-size:10px;padding:2px 7px;border-radius:20px;background:#eef3f2;color:var(--brand-2)}.acct .tag.card{background:#fef2e9;color:#b5721f}.acct .bal{font-size:23px;font-weight:700;margin-top:10px;font-variant-numeric:tabular-nums}.acct .meta{font-size:11px;color:var(--text-mute);margin-top:8px}.tbl-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13px}table.tbl th{text-align:left;font-weight:600;color:var(--text-dim);font-size:11.5px;letter-spacing:.03em;padding:9px 12px;border-bottom:1px solid var(--line-strong);white-space:nowrap;background:#fafbfb;position:sticky;top:0}table.tbl td{padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap}table.tbl tr:hover td{background:#f8fafa}table.tbl td.num,table.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}.pos{color:var(--pos)}.neg{color:var(--neg)}.muted{color:var(--text-mute)}.badge{display:inline-block;font-size:11px;padding:2px 9px;border-radius:20px;font-weight:600}.badge.b-ca{background:#e7f2f0;color:var(--brand-2)}.badge.b-pca{background:#eef0fa;color:#4a56a6}.badge.b-ok{background:#e6f5ee;color:var(--pos)}.badge.b-warn{background:#fdf0e0;color:var(--warn)}.badge.b-neg{background:#fbe9e7;color:var(--neg)}.badge.b-gray{background:#eef1f1;color:var(--text-dim)}.badge.b-info{background:#e8f1f9;color:var(--info)}.filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.filters input[type=text],.filters select{height:34px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:0 10px;font-size:13px;font-family:var(--font);background:#fff;color:var(--text)}.filters input[type=text]{min-width:200px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px}.tabs button{background:none;border:none;padding:10px 16px;font-size:13.5px;font-family:var(--font);color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent}.tabs button.active{color:var(--brand);font-weight:700;border-bottom-color:var(--brand-accent)}.btn{height:34px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:#fff;font-size:13px;cursor:pointer;font-family:var(--font);color:var(--text)}.btn:hover{background:#f5f7f7}.btn.primary{background:var(--brand-2);border-color:var(--brand-2);color:#fff}.btn.primary:hover{background:var(--brand)}.section-title{font-size:12px;letter-spacing:.14em;color:var(--text-mute);margin:4px 0 10px;padding-left:10px;border-left:3px solid var(--brand-accent)}.loading{padding:40px;text-align:center;color:var(--text-mute)}.chart-box{width:100%;height:300px}.hint{font-size:11.5px;color:var(--text-mute);margin-top:8px}.pill-row{display:flex;gap:8px;flex-wrap:wrap}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#1028256b;display:flex;align-items:flex-start;justify-content:center;z-index:100;padding:40px 16px;overflow-y:auto}.modal{background:var(--surface);border-radius:12px;width:100%;max-width:880px;box-shadow:0 20px 60px #103d3840}.modal-h{padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}.modal-h h2{margin:0;font-size:16px}.modal-h .x{margin-left:auto;cursor:pointer;font-size:20px;color:var(--text-mute);background:none;border:none}.modal-b{padding:20px 22px}.modal-f{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;align-items:center}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 18px}.form-grid .full{grid-column:1 / -1}.field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:5px;font-weight:600}.field label .req{color:var(--neg);margin-left:3px}.field input,.field select{width:100%;height:36px;border:1px solid var(--line-strong);border-radius:6px;padding:0 10px;font-size:13.5px;font-family:var(--font);background:#fff;color:var(--text)}.field input:focus,.field select:focus{outline:none;border-color:var(--brand-accent)}.field.invalid input,.field.invalid select{border-color:var(--neg);background:#fdf4f2}.seg{display:inline-flex;border:1px solid var(--line-strong);border-radius:8px;overflow:hidden}.seg button{border:none;background:#fff;padding:8px 18px;font-size:13.5px;cursor:pointer;font-family:var(--font);color:var(--text-dim)}.seg button.on{background:var(--brand-2);color:#fff;font-weight:700}.preview{background:#f6f9f8;border:1px solid var(--line);border-radius:10px;padding:14px 16px}.preview .pv-row{display:flex;justify-content:space-between;padding:5px 0;font-size:13px;border-bottom:1px dashed var(--line)}.preview .pv-row:last-child{border-bottom:none}.preview .pv-row b{font-variant-numeric:tabular-nums}.toggle{display:inline-flex;align-items:center;gap:8px;height:36px;cursor:pointer}.toggle input{width:auto;height:auto}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#103d38,#1a6b62);padding:20px}.login-card{background:var(--surface);border-radius:14px;padding:34px 32px;width:100%;max-width:380px;box-shadow:0 20px 60px #00000040}.login-brand{font-size:19px;font-weight:700;letter-spacing:.05em;margin-bottom:24px;color:var(--brand);text-align:center}.login-brand small{display:block;font-weight:400;font-size:11px;letter-spacing:.2em;color:var(--text-mute);margin-top:5px}.login-err{background:#fbe9e7;color:var(--neg);font-size:13px;padding:9px 12px;border-radius:6px;margin-bottom:14px}.userbox{display:flex;align-items:center;gap:10px}.userbox .uinfo{text-align:right;line-height:1.3}.userbox .uinfo .un{font-size:13px;font-weight:600}.userbox .uinfo .ur{font-size:11px;color:var(--text-mute)}.userbox .uav{width:34px;height:34px;border-radius:50%;background:var(--brand-2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
