*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f6fa;--bg-card: #ffffff;--bg-sidebar: #1e293b;--bg-subtle: #f1f5f9;--surface: #ffffff;--surface-alt: #f5f6fa;--text: #1e293b;--text-muted: #64748b;--text-sidebar: #cbd5e1;--text-sidebar-active: #ffffff;--accent: #2563eb;--accent-hover: #1d4ed8;--border: #e2e8f0;--danger: #dc2626;--danger-bg: #fef2f2;--danger-fg: #991b1b;--success: #16a34a;--success-bg: #f0fdf4;--success-fg: #166534;--warning: #d97706;--warning-bg: #fffbeb;--warning-fg: #92400e;--info-bg: #eff6ff;--info-fg: #1e40af;--sidebar-border: #e2e8f0;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08)}[data-theme=dark]{--bg: #0f172a;--bg-card: #1e293b;--bg-sidebar: #0c1222;--bg-subtle: #1a2436;--surface: #1e293b;--surface-alt: #27334a;--text: #e2e8f0;--text-muted: #94a3b8;--border: #334155;--sidebar-border: #1e293b;--shadow: 0 1px 3px rgba(0,0,0,.3);--danger-bg: rgba(220,38,38,.15);--danger-fg: #fca5a5;--success-bg: rgba(34,197,94,.15);--success-fg: #86efac;--warning-bg: rgba(217,119,6,.15);--warning-fg: #fcd34d;--info-bg: rgba(37,99,235,.15);--info-fg: #93c5fd}.toggle{display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.8rem}.toggle>input[type=checkbox]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.toggle-track{position:relative;display:inline-block;width:34px;height:18px;background:var(--border);border-radius:999px;transition:background .15s ease}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #00000040;transition:transform .15s ease}.toggle>input:checked~.toggle-track{background:var(--accent)}.toggle>input:checked~.toggle-track:after{transform:translate(16px)}.toggle>input:focus-visible~.toggle-track{outline:2px solid var(--accent);outline-offset:2px}thead th{position:sticky;top:0;z-index:2;background:var(--bg-subtle);box-shadow:inset 0 -1px 0 var(--border)}table.no-sticky-head thead th{position:static;box-shadow:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--bg-sidebar);color:var(--text-sidebar);padding:1rem 0;display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid var(--sidebar-border)}.sidebar-brand{padding:.5rem 1.25rem 1.5rem;font-size:1.25rem;font-weight:700;color:var(--text-sidebar-active);letter-spacing:-.02em}.sidebar nav{flex:1}.sidebar a{display:block;padding:.5rem 1.25rem;color:var(--text-sidebar);text-decoration:none;font-size:.875rem;border-left:3px solid transparent;transition:all .15s}.sidebar a:hover{color:var(--text-sidebar-active);background:#ffffff0d}.sidebar a.active{color:var(--text-sidebar-active);background:#ffffff1a;border-left-color:var(--accent);font-weight:600}.sidebar-section{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:1rem 1.25rem .25rem;margin-top:.25rem;border-top:1px solid rgba(255,255,255,.06)}.sidebar-footer{padding:.75rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem}.main-content{flex:1;padding:1.5rem 2rem;overflow-y:auto}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid transparent;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px);box-shadow:inset 0 1px 3px #0003}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-hover)}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{background:#1d4ed8}.btn-danger{background:var(--danger);color:#fff;border-color:#b91c1c}.btn-danger:active{background:#b91c1c}.btn-outline{background:var(--bg-card);border:1px solid var(--border);color:var(--text);box-shadow:0 1px 2px #0000000d}.btn-outline:hover{background:var(--bg);border-color:var(--text-muted)}.btn-outline:active{background:var(--bg);box-shadow:inset 0 1px 3px #00000026}input,select,textarea{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--bg-card);color:var(--text);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #2563eb26}label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.25rem;color:var(--text-muted)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-box{width:360px;padding:2rem}.login-box h1{font-size:1.5rem;margin-bottom:.25rem}.login-box p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.875rem}.login-box .field{margin-bottom:1rem}.login-box .btn{width:100%;justify-content:center;padding:.65rem}.login-error{background:#dc26261a;color:var(--danger);padding:.5rem .75rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:1rem}[data-theme=dark] .login-error{background:#dc262633}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700}.page-header p{color:var(--text-muted);font-size:.875rem}.placeholder-page{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--text-muted);font-size:1rem}table{border-collapse:collapse;width:100%}th{text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:.55rem .6rem;border-bottom:2px solid var(--border);position:sticky;top:0;background:var(--bg-card);white-space:nowrap}td{padding:.5rem .6rem;font-size:.82rem;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:nth-child(2n){background:#00000005}[data-theme=dark] tbody tr:nth-child(2n){background:#ffffff05}tbody tr[style*="cursor: pointer"]:hover,tbody tr[style*="cursor:pointer"]:hover{background:#2563eb0f!important}[data-theme=dark] tbody tr[style*="cursor: pointer"]:hover,[data-theme=dark] tbody tr[style*="cursor:pointer"]:hover{background:#2563eb1f!important}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:.55rem .6rem;border-bottom:2px solid var(--border);white-space:nowrap}.data-table td{padding:.5rem .6rem;font-size:.82rem;border-bottom:1px solid var(--border)}.data-table tbody tr:nth-child(2n){background:#00000005}[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#ffffff05}tfoot td,tfoot th{font-weight:600;border-top:2px solid var(--border);border-bottom:none;padding:.6rem}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border)}.tab{background:none;border:none;border-bottom:2px solid transparent;padding:.5rem 1rem;font-size:.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.btn-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:.15rem .35rem;border-radius:4px}.btn-link:hover{color:var(--danger);background:#dc262614}.toast-host{position:fixed;bottom:1.25rem;right:1.25rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:auto;max-width:min(420px,calc(100vw - 2rem))}.toast{display:flex;align-items:flex-start;gap:.6rem;padding:.7rem .9rem;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);box-shadow:0 6px 20px #00000026;cursor:pointer;font-size:.9rem;color:var(--text);animation:toast-in .18s ease-out;border-left:4px solid var(--border)}.toast-success{border-left-color:var(--success);background:var(--success-bg);color:var(--success-fg)}.toast-error{border-left-color:var(--danger);background:var(--danger-bg);color:var(--danger-fg)}.toast-info{border-left-color:var(--accent);background:var(--info-bg);color:var(--info-fg)}.toast-icon{font-weight:700;font-size:1rem;line-height:1.2;flex-shrink:0}.toast-message{flex:1;line-height:1.35}.toast-close{background:none;border:none;color:inherit;opacity:.6;cursor:pointer;font-size:1.1rem;line-height:1;padding:0 .1rem;margin-left:.25rem}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@media(prefers-reduced-motion:reduce){.toast{animation:none}}.empty-state{padding:3rem 1.5rem;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:.75rem}.empty-state-compact{padding:1.25rem .75rem;gap:.5rem}.empty-state-icon{font-size:2.5rem;opacity:.45;line-height:1}.empty-state-compact .empty-state-icon{font-size:1.75rem}.empty-state-title{color:var(--text);font-size:1.05rem;font-weight:600}.empty-state-message{font-size:.9rem;max-width:30rem;line-height:1.5}.empty-state-action{margin-top:.5rem}.skeleton{background:linear-gradient(90deg,var(--bg-subtle) 0%,rgba(255,255,255,.14) 50%,var(--bg-subtle) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.2s ease-in-out infinite}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff0a,#ffffff1a,#ffffff0a);background-size:200% 100%}@keyframes skeleton-shimmer{0%{background-position:-150% 0}to{background-position:150% 0}}@media(prefers-reduced-motion:reduce){.skeleton{animation:none}}.field-error{color:var(--danger);font-size:.72rem;margin-top:.2rem;line-height:1.3}.field input[aria-invalid=true],.field select[aria-invalid=true]{border-color:var(--danger);box-shadow:0 0 0 2px #dc26261f}
