:root{--moss:#3d5a3e;--moss-dark:#2c4230;--moss-light:#4f7251;--gold:#c9a84c;--gold-light:#e0c575;--bark:#8b6f47;--cream:#faf8f4;--sand:#f0ede6;--gray:#888780;--gray-light:#bcbab3;--ink:#1a1a18;--danger:#b43f3f;--danger-bg:#fdeeee;--warn:#d88b2e;--warn-bg:#fff6e8;--ok:#4f8a57;--shadow-sm:0 1px 3px #1a1a180f;--shadow:0 2px 8px #1a1a1814}*{box-sizing:border-box}html,body,#root{background:var(--cream);min-height:100vh;color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;padding:0;font:14px/1.5 -apple-system,BlinkMacSystemFont,Segoe UI,Microsoft JhengHei,PingFang TC,Noto Sans TC,sans-serif}a{color:var(--moss);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer;border:0;border-radius:6px;padding:8px 16px;transition:opacity .15s,background .15s}button:disabled{opacity:.4;cursor:not-allowed}button:active{transform:scale(.98)}.btn-primary{background:var(--moss);color:#fff}.btn-primary:hover:not(:disabled){background:var(--moss-dark)}.btn-secondary{background:var(--sand);color:var(--ink)}.btn-secondary:hover:not(:disabled){background:var(--gray-light)}.btn-gold{background:var(--gold);color:var(--ink);font-weight:600}.btn-gold:hover:not(:disabled){background:var(--gold-light)}.btn-danger{background:var(--danger);color:#fff}.btn-link{color:var(--moss);background:0 0;padding:4px 8px}.btn-link:hover{background:var(--sand)}input,select,textarea{font:inherit;border:1px solid var(--gray-light);color:var(--ink);background:#fff;border-radius:6px;width:100%;padding:8px 10px}input:focus,select:focus,textarea:focus{outline:2px solid var(--moss);outline-offset:-2px}.app{min-height:100vh;display:flex}.sidebar{background:var(--moss);color:#fff;flex-direction:column;flex-shrink:0;width:220px;padding:16px 0;display:flex}.sidebar-brand{border-bottom:1px solid #ffffff26;padding:8px 20px 20px}.sidebar-brand h1{color:#fff;margin:0;font-size:16px;font-weight:700}.sidebar-brand p{color:#ffffffb3;margin:4px 0 0;font-size:11px}.sidebar-nav{flex:1;padding-top:12px}.sidebar-section{border-top:1px solid #ffffff1a;margin:12px 0}.sidebar-item{color:#ffffffd9;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:14px;display:flex}.sidebar-item:hover{color:#fff;background:#ffffff14;text-decoration:none}.sidebar-item.active{color:#fff;border-left-color:var(--gold);background:#ffffff1a;font-weight:600}.sidebar-item .icon{text-align:center;width:22px;font-size:18px}.sidebar-item .badge{background:var(--gold);color:var(--ink);border-radius:10px;margin-left:auto;padding:2px 7px;font-size:11px;font-weight:700}.main{flex-direction:column;flex:1;display:flex}.topbar{border-bottom:1px solid var(--sand);background:#fff;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.topbar h2{color:var(--bark);margin:0;font-size:18px;font-weight:600}.topbar .right{color:var(--gray);align-items:center;gap:12px;font-size:13px;display:flex}.content{width:100%;max-width:1280px;padding:24px}.card{box-shadow:var(--shadow-sm);background:#fff;border-radius:8px;margin-bottom:16px;padding:20px}.card h3{color:var(--bark);margin:0 0 14px;font-size:15px}.stat-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px;display:grid}.stat-card{box-shadow:var(--shadow-sm);border-left:4px solid var(--moss);background:#fff;border-radius:8px;padding:16px 20px}.stat-card.warn{border-left-color:var(--warn)}.stat-card.gold{border-left-color:var(--gold)}.stat-card.bark{border-left-color:var(--bark)}.stat-card .label{color:var(--gray);margin-bottom:6px;font-size:12px}.stat-card .value{color:var(--ink);font-size:28px;font-weight:700}.stat-card .unit{color:var(--gray);margin-left:4px;font-size:13px;font-weight:400}.banner{background:var(--warn-bg);color:var(--warn);border-left:4px solid var(--warn);border-radius:8px;align-items:center;gap:14px;margin-bottom:16px;padding:14px 18px;display:flex}.banner.danger{background:var(--danger-bg);color:var(--danger);border-left-color:var(--danger)}.banner .text{flex:1;font-weight:500}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:left;border-bottom:1px solid var(--sand);padding:10px 12px}thead th{background:var(--cream);color:var(--bark);border-bottom:2px solid var(--sand);font-size:12px;font-weight:600}tbody tr:hover{background:var(--cream)}td .actions{gap:6px;display:flex}.tag{background:var(--sand);color:var(--gray);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.tag.moss{color:var(--moss);background:#3d5a3e1f}.tag.gold{color:#8a7028;background:#c9a84c2e}.tag.bark{color:var(--bark);background:#8b6f4726}.tag.ok{color:var(--ok);background:#4f8a5726}.tag.warn{background:var(--warn-bg);color:var(--warn)}.tag.danger{background:var(--danger-bg);color:var(--danger)}.dot{background:var(--gray-light);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.dot.bound{background:var(--ok)}.form-row{grid-template-columns:140px 1fr;align-items:center;gap:12px;margin-bottom:14px;display:grid}.form-row label{color:var(--bark);font-size:13px;font-weight:500}.form-row .hint{color:var(--gray);margin-top:4px;font-size:11px}.filter-bar{background:var(--sand);border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.filter-bar>*{min-width:0}.filter-bar label{color:var(--bark);margin-right:4px;font-size:12px}.filter-bar input,.filter-bar select{width:auto}.pager{justify-content:space-between;align-items:center;padding-top:12px;display:flex}.pager .info{color:var(--gray);font-size:12px}.pager .controls{gap:6px;display:flex}.pager button{padding:6px 12px;font-size:12px}.modal-overlay{z-index:999;background:#1a1a1873;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:480px;max-width:90vw;max-height:88vh;overflow:auto;box-shadow:0 20px 50px #0000004d}.modal-header{border-bottom:1px solid var(--sand);justify-content:space-between;padding:16px 20px;display:flex}.modal-header h3{color:var(--bark);margin:0;font-size:16px}.modal-header .close{color:var(--gray);background:0 0;padding:4px 8px;font-size:18px}.modal-body{padding:18px 20px}.modal-footer{border-top:1px solid var(--sand);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.toast-wrap{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{box-shadow:var(--shadow);border-left:4px solid var(--moss);background:#fff;border-radius:6px;min-width:240px;max-width:360px;padding:12px 18px;animation:.2s ease-out slidein}.toast.success{border-left-color:var(--ok)}.toast.error{border-left-color:var(--danger)}.toast.warn{border-left-color:var(--warn)}@keyframes slidein{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.bar-chart{align-items:flex-end;gap:14px;height:180px;padding:12px 0;display:flex}.bar-chart .col{flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;display:flex}.bar-chart .bar{background:var(--moss);border-radius:4px 4px 0 0;width:100%;max-width:56px;min-height:4px;transition:opacity .2s}.bar-chart .col:hover .bar{background:var(--moss-light)}.bar-chart .num{color:var(--bark);font-size:11px;font-weight:600}.bar-chart .lbl{color:var(--gray);font-size:11px}.hbar{flex-direction:column;gap:8px;display:flex}.hbar .row{grid-template-columns:110px 1fr 40px;align-items:center;gap:10px;font-size:12px;display:grid}.hbar .row .bar{background:var(--gold);border-radius:2px;min-width:2px;height:14px}.hbar .row .name{color:var(--ink)}.hbar .row .num{color:var(--gray);text-align:right}.empty,.loading{text-align:center;color:var(--gray);padding:40px}.muted{color:var(--gray);font-size:12px}.right{text-align:right}@media (width<=900px){.sidebar{width:60px}.sidebar-brand h1,.sidebar-brand p,.sidebar-item .label{display:none}.stat-cards{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}}
