.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:1100;gap:var(--space-2);pointer-events:none;flex-direction:column;max-width:380px;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);pointer-events:all;animation:.3s ease-out slideUp;display:flex}.toast--success{border-left:3px solid var(--color-success)}.toast--success .toast-icon{color:var(--color-success)}.toast--error{border-left:3px solid var(--color-danger)}.toast--error .toast-icon{color:var(--color-danger)}.toast--warning{border-left:3px solid var(--color-warning)}.toast--warning .toast-icon{color:var(--color-warning)}.toast--info{border-left:3px solid var(--color-primary)}.toast--info .toast-icon{color:var(--color-primary)}.toast-icon{flex-shrink:0;width:18px;height:18px}.toast-message{font-size:var(--text-sm);flex:1;line-height:1.4}.toast-close{cursor:pointer;color:var(--color-text-muted);opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:2px}.toast-close:hover{opacity:1}.toast-close svg{width:14px;height:14px}@media (width<=480px){.toast-container{left:var(--space-4);right:var(--space-4);bottom:var(--space-4);max-width:unset}}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:var(--z-sticky);transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:var(--space-4) var(--space-4);border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;min-height:64px;display:flex}.sidebar-logo{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-inverse);letter-spacing:-.02em;white-space:nowrap}.sidebar-collapse-btn{flex-shrink:0;color:var(--sidebar-text)!important}.sidebar-collapse-btn:hover{color:var(--sidebar-text-active)!important}.sidebar-nav{gap:var(--space-1);padding:var(--space-3) var(--space-2);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast);cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);white-space:nowrap;background:0 0;border:none;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--sidebar-text-active);background:#ffffff14}.sidebar-link--active{background:var(--sidebar-accent)!important;color:var(--sidebar-text-active)!important}.sidebar-link--danger:hover{color:var(--color-danger-light)}.sidebar-link-icon{flex-shrink:0;width:20px;height:20px}.sidebar-footer{gap:var(--space-1);padding:var(--space-3) var(--space-2);border-top:1px solid #ffffff14;flex-direction:column;display:flex}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-3);margin-top:var(--space-2);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--sidebar-accent);width:36px;height:36px;color:var(--color-text-inverse);font-weight:var(--weight-semibold);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--sidebar-text-active);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--sidebar-text);text-transform:capitalize}.sidebar-mobile-toggle{top:var(--space-3);left:var(--space-3);z-index:var(--z-sticky);color:var(--color-text);display:none;position:fixed}.sidebar-backdrop{z-index:calc(var(--z-sticky) - 1);background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{transition:transform var(--transition-slow);transform:translate(-100%)}.sidebar--mobile-open{transform:translate(0)}.sidebar-mobile-toggle{display:flex}.sidebar-backdrop{animation:fadeIn var(--transition-fast);display:block}.sidebar--collapsed{width:var(--sidebar-width)}.sidebar-collapse-btn{display:none}}:root{--color-primary:#6366f1;--color-primary-light:#818cf8;--color-primary-dark:#4f46e5;--color-primary-50:#eef2ff;--color-primary-100:#e0e7ff;--color-primary-200:#c7d2fe;--color-accent:#f59e0b;--color-accent-light:#fbbf24;--color-accent-dark:#d97706;--color-success:#10b981;--color-success-light:#34d399;--color-success-bg:#ecfdf5;--color-warning:#f59e0b;--color-warning-light:#fbbf24;--color-warning-bg:#fffbeb;--color-danger:#ef4444;--color-danger-light:#f87171;--color-danger-bg:#fef2f2;--color-info:#3b82f6;--color-info-light:#60a5fa;--color-info-bg:#eff6ff;--color-bg:#f8fafc;--color-surface:#fff;--color-surface-hover:#f1f5f9;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-inverse:#fff;--sidebar-width:260px;--sidebar-collapsed-width:72px;--sidebar-bg:#1e1b4b;--sidebar-text:#c7d2fe;--sidebar-text-active:#fff;--sidebar-accent:#6366f1;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);min-height:100dvh}#root{min-height:100dvh;display:flex}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-dark)}img{max-width:100%;display:block}.heading-1{font-size:var(--text-3xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);color:var(--color-text)}.heading-2{font-size:var(--text-2xl);font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text)}.heading-3{font-size:var(--text-xl);font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:var(--leading-normal);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{flex-shrink:0;width:1em;height:1em}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:var(--color-danger-light)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-icon{padding:var(--space-2);aspect-ratio:1}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-200)}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger)}.form-input.error:focus,.form-select.error:focus,.form-textarea.error:focus{box-shadow:0 0 0 3px #ef444426}.form-error{font-size:var(--text-xs);color:var(--color-danger)}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card-body{padding:var(--space-6)}.card-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);white-space:nowrap;display:inline-flex}.badge-primary{background:var(--color-primary-100);color:var(--color-primary-dark)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-accent-dark)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.table-container{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:var(--weight-medium);color:var(--color-text-secondary);background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.table tbody tr:hover{background:var(--color-surface-hover)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);padding:var(--space-4);animation:fadeIn var(--transition-fast);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:90vh;z-index:var(--z-modal);animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;max-width:420px;animation:slideInRight var(--transition-base);display:flex}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-warning{border-left:3px solid var(--color-warning)}.toast-info{border-left:3px solid var(--color-info)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:1.25em;height:1.25em;animation:.6s linear infinite spin;display:inline-block}.empty-state{align-items:center;gap:var(--space-4);padding:var(--space-12) var(--space-8);text-align:center;color:var(--color-text-muted);flex-direction:column;display:flex}.empty-state svg{opacity:.4;width:3rem;height:3rem}.app-shell{width:100%;min-height:100dvh;display:flex}.main-content{margin-left:var(--sidebar-width);padding:var(--space-8);transition:margin-left var(--transition-slow);flex:1;min-width:0}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-header-title{gap:var(--space-1);flex-direction:column;display:flex}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}@media (width<=768px){.main-content{padding:var(--space-4);padding-bottom:calc(var(--space-16) + var(--space-4));margin-left:0}.page-header{flex-direction:column;align-items:flex-start}.table th,.table td{padding:var(--space-2) var(--space-3)}}
