*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#09090b;--surface:#18181b;--surface-hover:#27272a;--surface-active:#3f3f46;--border:#3f3f46;--border-light:#52525b;--text:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#06b6d4;--accent-hover:#22d3ee;--accent-subtle:#155e75;--accent-text:#fff;--success:#10b981;--success-bg:#064e3b;--warning:#f59e0b;--warning-bg:#78350f;--error:#ef4444;--error-bg:#7f1d1d;--info:#3b82f6;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","SF Mono",ui-monospace,monospace;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--sidebar-w:240px;--topbar-h:56px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition:.15s ease;--transition-slow:.25s ease}.light{--bg:#f5f5f5;--surface:#fff;--surface-hover:#f0f0f0;--surface-active:#e5e5e5;--border:#e5e5e5;--border-light:#d4d4d4;--text:#171717;--text-secondary:#525252;--text-muted:#a3a3a3;--accent:#0891b2;--accent-hover:#06b6d4;--accent-subtle:#ecfeff;--accent-text:#fff;--success:#059669;--success-bg:#d1fae5;--warning:#d97706;--warning-bg:#fef3c7;--error:#dc2626;--error-bg:#fee2e2;--info:#2563eb}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}input,textarea,select,button{font-family:inherit;font-size:inherit}.layout{height:100%;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-logo{padding:var(--space-5) var(--space-4);align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border);font-size:var(--text-lg);font-weight:700;display:flex}.sidebar-logo svg{flex-shrink:0}.sidebar-group{padding:var(--space-3) var(--space-3) 0}.sidebar-group-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:0 var(--space-3) var(--space-2);font-weight:600}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition),color var(--transition);font-weight:500;display:flex}.sidebar-link:hover{background:var(--surface-hover);color:var(--text)}.sidebar-link.active{background:var(--accent-subtle);color:var(--accent)}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-spacer{flex:1}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--border)}.topbar{height:var(--topbar-h);padding:0 var(--space-6);border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.topbar-left{align-items:center;gap:var(--space-4);display:flex}.topbar-title{font-size:var(--text-base);font-weight:600}.topbar-right{align-items:center;gap:var(--space-3);display:flex}.content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.content-body{padding:var(--space-6);flex:1;overflow-y:auto}.content-wide{max-width:1400px}.content-narrow{max-width:720px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition)}.card:hover{border-color:var(--border-light)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-base);font-weight:600}.card-grid{gap:var(--space-4);display:grid}.card-grid-2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card-grid-4{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;line-height:1;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-active);border-color:var(--border-light)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-danger{background:var(--error);color:#fff;border-color:var(--error)}.btn-danger:hover:not(:disabled){opacity:.9}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-icon{padding:var(--space-2);justify-content:center;min-width:32px}.btn-group{gap:var(--space-2);flex-wrap:wrap;display:flex}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);white-space:nowrap;border-radius:999px;font-weight:600;line-height:1.4;display:inline-flex}.badge svg{width:12px;height:12px}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-error{background:var(--error-bg);color:var(--error)}.badge-info{color:var(--info);background:#1e3a5f}.badge-neutral{background:var(--surface-hover);color:var(--text-muted)}.badge-accent{background:var(--accent-subtle);color:var(--accent)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-size:var(--text-sm);vertical-align:middle}th{background:var(--surface);color:var(--text-secondary);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;position:sticky;top:0}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-hover)}td.actions{white-space:nowrap;text-align:right}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6)}.form-card h2{font-size:var(--text-lg);margin-bottom:var(--space-5);font-weight:600}.form-row{margin-bottom:var(--space-4)}.form-row:last-child{margin-bottom:0}.form-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500;display:block}.form-input{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:var(--text-sm);transition:border-color var(--transition)}.form-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #06b6d433}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{font-family:var(--font-mono);resize:vertical;min-height:80px}select.form-input{cursor:pointer}.form-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-actions{gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border);display:flex}.form-inline{gap:var(--space-3);flex-wrap:wrap;align-items:flex-end;display:flex}.form-inline .form-row{margin-bottom:0}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.page-header h1{font-size:var(--text-2xl);font-weight:700}.page-desc{color:var(--text-secondary);margin-bottom:var(--space-6);font-size:var(--text-sm);line-height:1.5}.stat-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-1);flex-direction:column;display:flex}.stat-value{font-size:var(--text-2xl);font-weight:700}.stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);line-height:1.5;display:flex}.alert-error{background:var(--error-bg);color:var(--error);border:1px solid var(--error)}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning)}.alert-info{color:var(--info);border:1px solid var(--info);background:#1e3a5f}.light .alert-info{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.alert-icon{flex-shrink:0;margin-top:1px}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:48px;height:48px;color:var(--text-muted);margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--text-base);margin-bottom:var(--space-2);font-weight:600}.empty-state p{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-5);max-width:360px;line-height:1.5}.modal-overlay{z-index:100;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);width:100%;min-width:320px;max-width:480px}.modal h3{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:600}.modal p{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-6);line-height:1.5}.modal-actions{gap:var(--space-3);justify-content:flex-end;display:flex}.section{margin-bottom:var(--space-8)}.section:last-child{margin-bottom:0}.section-title{font-size:var(--text-lg);margin-bottom:var(--space-4);font-weight:600}.login-page{background:var(--bg);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:var(--space-8)}.login-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);font-size:var(--text-xl);font-weight:700;display:flex}.login-title{font-size:var(--text-xl);margin-bottom:var(--space-1);font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-6)}.detail-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.detail-header h1{font-size:var(--text-2xl);font-weight:700}.detail-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.detail-field{margin-bottom:var(--space-3)}.detail-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.detail-value{font-size:var(--text-sm);color:var(--text);word-break:break-all}.log-view{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-xs);white-space:pre-wrap;word-break:break-all;max-height:320px;color:var(--text-secondary);line-height:1.6;overflow:auto}.badge-row{gap:var(--space-2);flex-wrap:wrap;display:flex}@media (width<=768px){.sidebar{z-index:50;transition:transform var(--transition-slow);position:fixed;inset:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:49;background:#00000080;position:fixed;inset:0}.form-grid,.detail-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.content-body{padding:var(--space-4)}.topbar{padding:0 var(--space-4)}}
