:root{--bg: #eef1f5;--panel: #ffffff;--panel-2: #f8fafc;--ink: #1c2430;--muted: #6b7686;--line: #e1e6ee;--line-strong: #cfd6e0;--brand: #1f7a5a;--brand-ink: #0f4533;--brand-soft: #e6f3ee;--accent: #2563eb;--accent-soft: #e8f0fe;--danger: #c0392b;--danger-soft: #fdecea;--warn: #b7791f;--warn-soft: #fcf3e3;--ok: #1f7a5a;--ok-soft: #e6f3ee;--radius: 10px;--radius-sm: 7px;--shadow: 0 1px 2px rgba(20, 30, 45, .06), 0 6px 20px rgba(20, 30, 45, .07);--shadow-sm: 0 1px 2px rgba(20, 30, 45, .08)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0 0 .4em;font-weight:600;letter-spacing:-.01em}h1{font-size:22px}h2{font-size:18px}h3{font-size:15px}a{color:var(--accent)}button{font-family:inherit}.app-shell{display:grid;grid-template-columns:248px 1fr;height:100vh;overflow:hidden}.sidebar{background:#11241c;color:#cfe3da;display:flex;flex-direction:column;padding:16px 12px;overflow-y:auto}.sidebar .brand{font-size:16px;font-weight:700;color:#fff;padding:8px 10px 4px;letter-spacing:-.02em}.sidebar .brand small{display:block;font-weight:400;font-size:11px;color:#84a99a;letter-spacing:0}.nav-group-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#6f9485;padding:14px 10px 4px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);color:#cfe3da;cursor:pointer;font-size:13.5px;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:#ffffff0f}.nav-item.active{background:var(--brand);color:#fff;font-weight:600}.nav-item .ico{width:16px;text-align:center;opacity:.9}.sidebar .spacer{flex:1}.sidebar .user-box{border-top:1px solid rgba(255,255,255,.1);padding:12px 10px 4px;font-size:12px;color:#9fc0b2}.main-area{overflow-y:auto;padding:26px 32px 60px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.page-head .subtitle{color:var(--muted);font-size:13px;margin-top:2px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card.pad{padding:18px}.card-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:8px}.card-title .step{background:var(--brand-soft);color:var(--brand-ink);border-radius:6px;font-size:11px;padding:2px 7px;font-weight:700}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.cols{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:18px;align-items:start}.stack{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field label{font-size:12px;color:var(--muted);font-weight:500}.field .hint{font-size:11px;color:var(--muted)}input[type=text],input[type=number],input[type=password],input[type=date],select,textarea{width:100%;padding:8px 10px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);font-size:13.5px;background:#fff;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}input:disabled,select:disabled{background:var(--panel-2);color:var(--muted)}.inline{display:flex;align-items:center;gap:8px}.checkbox{display:inline-flex;align-items:center;gap:6px;cursor:pointer}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:13.5px;font-weight:600;cursor:pointer;background:var(--panel-2);color:var(--ink);border-color:var(--line-strong);white-space:nowrap}.btn:hover{background:#eef1f5}.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn.primary:hover{background:#1a6b4f}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.ghost{background:transparent;border-color:transparent;color:var(--accent)}.btn.danger{background:#fff;color:var(--danger);border-color:#e7bcb6}.btn.danger:hover{background:var(--danger-soft)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.sm{padding:5px 10px;font-size:12.5px}.btn-row{display:flex;gap:8px;flex-wrap:wrap}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:2px solid var(--line);background:var(--panel-2);position:sticky;top:0}table.data td{padding:7px 10px;border-bottom:1px solid var(--line);vertical-align:middle}table.data tr:hover td{background:var(--panel-2)}table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;max-height:70vh}table.data input,table.data select{padding:5px 7px;font-size:12.5px}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.kpi{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px}.kpi .label{font-size:11px;color:var(--muted)}.kpi .value{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;margin-top:2px}.kpi.hero{background:var(--brand-soft);border-color:#bfe0d2}.kpi.hero .value{color:var(--brand-ink)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}.badge.ok{background:var(--ok-soft);color:var(--ok)}.badge.muted{background:#eceef2;color:var(--muted)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.alert{display:flex;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;border:1px solid;margin-bottom:8px}.alert.error{background:var(--danger-soft);border-color:#f0c2bb;color:#8a2c20}.alert.warn{background:var(--warn-soft);border-color:#ecd9b0;color:#7d5410}.alert.info{background:var(--accent-soft);border-color:#c5d8fb;color:#1c4ca8}.login-wrap{display:flex;align-items:center;justify-content:center;height:100vh;background:radial-gradient(1200px 600px at 50% -10%,#1f7a5a22,transparent),var(--bg)}.login-card{width:360px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:28px 26px}.login-card .logo{font-size:20px;font-weight:800;color:var(--brand-ink);letter-spacing:-.02em}.login-card .logo small{display:block;font-weight:500;font-size:12px;color:var(--muted);margin-top:2px}.toast-host{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{background:#11241c;color:#fff;padding:11px 15px;border-radius:var(--radius-sm);box-shadow:var(--shadow);font-size:13px;max-width:360px}.toast.error{background:var(--danger)}.toast.ok{background:var(--brand)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f192373;display:flex;align-items:center;justify-content:center;z-index:900;padding:24px}.modal{background:#fff;border-radius:12px;box-shadow:var(--shadow);width:100%;max-width:560px;max-height:88vh;overflow:auto}.modal .modal-head{padding:16px 20px;border-bottom:1px solid var(--line);font-weight:600;display:flex;justify-content:space-between;align-items:center}.modal .modal-body{padding:20px}.modal .modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.muted{color:var(--muted)}.right{text-align:right}.nowrap{white-space:nowrap}.section-sep{height:1px;background:var(--line);margin:14px 0}.empty{text-align:center;color:var(--muted);padding:40px;font-size:13px}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.toolbar .grow{flex:1}.statbox{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px}.statline{display:flex;flex-wrap:wrap;gap:8px}.stat{background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px 11px;min-width:96px}.stat .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.stat .v{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;margin-top:1px}.stat.hero{background:var(--brand-soft);border-color:#bfe0d2}.stat.hero .v{color:var(--brand-ink)}
