:root{--bg: #f5f7f6;--panel: #ffffff;--panel-2: #f0f3f2;--border: #d9e0dd;--text: #16241f;--text-muted: #5b6b65;--accent: #0f766e;--accent-2: #0d9488;--accent-weak: #cceae6;--danger: #c0392b;--warn: #d97706;--ok: #15803d;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--radius: 12px;--radius-sm: 8px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px}:root[data-theme=dark]{--bg: #0e1513;--panel: #16201d;--panel-2: #1d2a26;--border: #2a3a35;--text: #e7efec;--text-muted: #9fb0aa;--accent: #2dd4bf;--accent-2: #14b8a6;--accent-weak: #1f3b37;--shadow: 0 1px 3px rgba(0, 0, 0, .4)}@media (prefers-color-scheme: dark){:root[data-theme=system]{--bg: #0e1513;--panel: #16201d;--panel-2: #1d2a26;--border: #2a3a35;--text: #e7efec;--text-muted: #9fb0aa;--accent: #2dd4bf;--accent-2: #14b8a6;--accent-weak: #1f3b37;--shadow: 0 1px 3px rgba(0,0,0,.4)}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Noto Sans KR,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:var(--accent)}.app-shell{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--panel);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.topbar .brand{font-weight:700;font-size:16px;color:var(--accent);white-space:nowrap}.topbar .spacer{flex:1}.topbar .meta{color:var(--text-muted);font-size:12px}.tabs{display:flex;gap:var(--space-1);overflow-x:auto;background:var(--panel);border-bottom:1px solid var(--border);padding:0 var(--space-3)}.tabs a{padding:var(--space-3) var(--space-4);text-decoration:none;color:var(--text-muted);border-bottom:2px solid transparent;white-space:nowrap;font-weight:600}.tabs a.active{color:var(--accent);border-bottom-color:var(--accent)}.content{padding:var(--space-5);max-width:1280px;width:100%;margin:0 auto}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--space-5);margin-bottom:var(--space-5)}.card h2{margin:0 0 var(--space-4);font-size:16px}.card h3{margin:0 0 var(--space-3);font-size:14px;color:var(--text-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-4)}.kpi{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-4)}.kpi .label{color:var(--text-muted);font-size:12px}.kpi .value{font-size:24px;font-weight:700;margin-top:var(--space-1)}.kpi .sub{color:var(--text-muted);font-size:11px}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:var(--space-3);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}th{background:var(--panel-2);color:var(--text-muted);font-weight:600;position:sticky;top:0}tr:hover td{background:var(--panel-2)}input,select,textarea{font:inherit;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel);color:var(--text);width:100%}label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:var(--space-1)}.field{margin-bottom:var(--space-3)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}.actions{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-3)}button{font:inherit;font-weight:600;cursor:pointer;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--panel-2);color:var(--text)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.danger{background:var(--danger);border-color:var(--danger);color:#fff}button.ghost{background:transparent}button:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-weak);color:var(--accent)}.badge.warn{background:#fde9c8;color:var(--warn)}.badge.danger{background:#f8d7d2;color:var(--danger)}.badge.ok{background:#d4edda;color:var(--ok)}.muted{color:var(--text-muted)}.small{font-size:.85em}.err{color:var(--danger);font-size:13px}.row{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4)}.login-card{width:100%;max-width:380px}.toast-host{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100}.toast{background:var(--text);color:var(--bg);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-width:320px}.toast.err{background:var(--danger);color:#fff}.toast.ok{background:var(--ok);color:#fff}.subtabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap}.subtabs button.active{background:var(--accent);border-color:var(--accent);color:#fff}.spinner{color:var(--text-muted);padding:var(--space-5);text-align:center}
