:root{--primary:#2563eb;--primary-dark:#1e40af;--primary-light:#3b82f6;--primary-ghost:#2563eb14;--secondary:#10b981;--secondary-dark:#059669;--accent:#f59e0b;--danger:#ef4444;--danger-dark:#dc2626;--warning:#f59e0b;--warning-dark:#d97706;--success:#10b981;--info:#3b82f6;--bg-primary:#f0f4f8;--bg-secondary:#e8edf3;--card-bg:#fff;--card-bg-hover:#fafbff;--sidebar-bg:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--border:#e2e8f0;--border-light:#f1f5f9;--border-focus:var(--primary);--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000d;--shadow:0 4px 6px -1px #00000014,0 2px 4px -1px #0000000d;--shadow-md:0 8px 16px -4px #0000001a,0 4px 6px -2px #0000000d;--shadow-lg:0 16px 32px -8px #0000001f,0 8px 16px -4px #0000000f;--shadow-xl:0 24px 48px -12px #0000002e;--shadow-inset:inset 0 2px 4px #0000000f;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.25rem;--radius:0.5rem;--radius-md:0.625rem;--radius-lg:0.875rem;--radius-xl:1.25rem;--radius-full:9999px;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Inter","Roboto",sans-serif;--font-mono:"Fira Code","Cascadia Code",Consolas,monospace;--transition:all 0.18s ease;--transition-fast:all 0.12s ease;--transition-slow:all 0.3s cubic-bezier(0.4,0,0.2,1);--header-height:64px;--sidebar-width:256px;--sidebar-collapsed-width:0px}@media (prefers-color-scheme:dark){:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--card-bg:#1e293b;--card-bg-hover:#263449;--sidebar-bg:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border:#334155;--border-light:#1e293b;--shadow-sm:0 1px 3px #0006;--shadow:0 4px 6px -1px #0006;--shadow-md:0 8px 16px -4px #00000080;--shadow-lg:0 16px 32px -8px #0009;--shadow-xl:0 24px 48px -12px #000000b3}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f4f8;background-color:var(--bg-primary);color:#0f172a;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--text-muted)}:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary);outline-offset:2px}.top-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#1d4ed8,#1e40af 50%,#1a3a9f);box-shadow:0 2px 12px #2563eb66;height:64px;height:var(--header-height);justify-content:space-between;left:0;padding:0 20px;position:fixed;right:0;top:0;z-index:1000}.sidebar-toggle,.top-header{align-items:center;color:#fff;display:flex}.sidebar-toggle{background:#ffffff1f;border:1px solid #ffffff26;border-radius:.5rem;border-radius:var(--radius);cursor:pointer;flex-shrink:0;height:38px;justify-content:center;transition:all .18s ease;transition:var(--transition);width:38px}.sidebar-toggle:hover{background:#ffffff38;border-color:#ffffff4d}.header-logo{flex:1 1;gap:10px;margin-left:14px}.header-logo,.header-logo-icon{align-items:center;display:flex}.header-logo-icon{background:#ffffff2e;border-radius:.5rem;border-radius:var(--radius);flex-shrink:0;height:34px;justify-content:center;width:34px}.header-title{align-items:center;display:flex;font-size:15px;font-weight:700;gap:6px;line-height:1.2}.header-subtitle{font-size:11px;letter-spacing:.02em;opacity:.75}.header-version{background:#ffffff26;border:1px solid #fff3;border-radius:9999px;border-radius:var(--radius-full);font-size:10px;font-weight:600;letter-spacing:.02em;padding:1px 7px}.header-actions{align-items:center;display:flex;gap:8px}.user-info{border-right:1px solid #fff3;margin-right:6px;padding-right:10px;text-align:right}.user-name{font-size:13px;font-weight:600;line-height:1.3}.user-role{font-size:10px;letter-spacing:.03em;opacity:.8}.user-avatar{background:#fff3;border:2px solid #ffffff59;border-radius:9999px;border-radius:var(--radius-full);flex-shrink:0;font-size:13px;font-weight:700;height:34px;letter-spacing:.05em;width:34px}.header-btn,.user-avatar{align-items:center;color:#fff;display:flex;justify-content:center}.header-btn{background:#ffffff1f;border:1px solid #ffffff26;border-radius:.5rem;border-radius:var(--radius);cursor:pointer;height:38px;position:relative;transition:all .18s ease;transition:var(--transition);width:38px}.header-btn:hover{background:#ffffff38;border-color:#ffffff4d}.header-btn.danger:hover{background:#ef44444d;border-color:#ef444480}.sidebar{background:#fff;background:var(--sidebar-bg);border-right:1px solid #e2e8f0;border-right:1px solid var(--border);bottom:0;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000d;box-shadow:var(--shadow-sm);left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:64px;top:var(--header-height);transition:transform .28s cubic-bezier(.4,0,.2,1);width:256px;width:var(--sidebar-width);z-index:999}.sidebar.closed{transform:translateX(-100%)}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:12px 8px}.sidebar-section-label{color:#94a3b8;color:var(--text-muted);font-size:10px;font-weight:700;letter-spacing:.08em;padding:12px 16px 6px;text-transform:uppercase}.sidebar-link{align-items:center;border-radius:.5rem;border-radius:var(--radius);color:#475569;color:var(--text-secondary);display:flex;font-size:13.5px;font-weight:500;gap:10px;overflow:hidden;padding:10px 14px;position:relative;text-decoration:none}.sidebar-link,.sidebar-link:before{transition:all .18s ease;transition:var(--transition)}.sidebar-link:before{background:#2563eb;background:var(--primary);border-radius:0 .25rem .25rem 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;width:3px}.sidebar-link:hover{background:#e8edf3;background:var(--bg-secondary);color:#0f172a;color:var(--text-primary)}.sidebar-link.active{background:#2563eb14;background:var(--primary-ghost);color:#2563eb;color:var(--primary);font-weight:600}.sidebar-link.active:before{opacity:1}.sidebar-link.active svg{color:#2563eb;color:var(--primary)}.sidebar-link-badge{animation:badgePulse 2s ease-in-out infinite;background:#ef4444;background:var(--danger);border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-size:10px;font-weight:700;line-height:1.4;margin-left:auto;min-width:18px;padding:2px 7px;text-align:center}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.sidebar-overlay{display:none}.container{margin:0 auto 0 256px;margin-left:var(--sidebar-width);margin-top:64px;margin-top:var(--header-height);max-width:1440px;min-height:calc(100vh - 64px);min-height:calc(100vh - var(--header-height));padding:1.5rem 2rem;padding:var(--space-6) var(--space-8);transition:margin-left .28s cubic-bezier(.4,0,.2,1)}body:has(.sidebar.closed) .container{margin-left:0}.container h2{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:1.625rem;font-weight:700;gap:.75rem;gap:var(--space-3);line-height:1.3;margin-bottom:1.5rem;margin-bottom:var(--space-6)}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.page-header-left h2{margin-bottom:4px}.page-subtitle{color:#475569;color:var(--text-secondary);font-size:14px;margin:0}.card{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.875rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000d;box-shadow:var(--shadow-sm);margin-bottom:1.5rem;margin-bottom:var(--space-6);padding:1.5rem;padding:var(--space-6);transition:box-shadow .2s ease}.card:hover{box-shadow:0 4px 6px -1px #00000014,0 2px 4px -1px #0000000d;box-shadow:var(--shadow)}.card h3{color:#0f172a;color:var(--text-primary);font-size:1.05rem;font-weight:600;gap:.5rem;gap:var(--space-2)}.card h3,.card-header{align-items:center;display:flex;margin-bottom:1rem;margin-bottom:var(--space-4)}.card-header{flex-wrap:wrap;gap:12px;justify-content:space-between}.card-title{align-items:center;color:#0f172a;color:var(--text-primary);display:flex;font-size:1.05rem;font-weight:600;gap:8px;margin:0}.stats-grid{grid-gap:1rem;grid-gap:var(--space-4);display:grid;gap:1rem;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.5rem;margin-bottom:var(--space-6)}.stat-card{background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.875rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000d;box-shadow:var(--shadow-sm);cursor:default;overflow:hidden;padding:1.25rem;padding:var(--space-5);position:relative}.stat-card,.stat-card:after{transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition-slow)}.stat-card:after{border-radius:50%;content:"";height:80px;opacity:.06;position:absolute;right:0;top:0;transform:translate(20px,-20px);width:80px}.stat-card:hover{box-shadow:0 8px 16px -4px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-header{align-items:flex-start;display:flex;gap:.75rem;gap:var(--space-3);justify-content:space-between}.stat-card-content{flex:1 1;min-width:0}.stat-card-icon{align-items:center;border-radius:.625rem;border-radius:var(--radius-md);display:flex;flex-shrink:0;font-size:1.35rem;height:46px;justify-content:center;transition:all .18s ease;transition:var(--transition);width:46px}.stat-card:hover .stat-card-icon{transform:scale(1.08)}.stat-card-value{color:#0f172a;color:var(--text-primary);font-size:2rem;font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-card-value.long-number{font-size:1.5rem;line-height:1.2;white-space:normal}.stat-card-label{color:#475569;color:var(--text-secondary);font-size:.8rem;font-weight:500;letter-spacing:.01em}.stat-card-trend{align-items:center;display:flex;font-size:11px;font-weight:600;gap:4px;margin-top:6px}.stat-card-trend.up{color:#10b981;color:var(--success)}.stat-card-trend.down{color:#ef4444;color:var(--danger)}.stat-card-trend.neutral{color:#94a3b8;color:var(--text-muted)}.btn{align-items:center;background-color:#e8edf3;background-color:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-xs);color:#0f172a;color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:6px;justify-content:center;letter-spacing:.01em;line-height:1;padding:8px 16px;text-decoration:none;transition:all .18s ease;transition:var(--transition);white-space:nowrap}.btn:hover{background-color:#e2e8f0;background-color:var(--border);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn:active{box-shadow:none;transform:translateY(0)}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.btn-primary{background:linear-gradient(135deg,#2563eb,#1e40af);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);border-color:#0000;box-shadow:0 2px 8px #2563eb40;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);border-color:#0000;box-shadow:0 4px 16px #2563eb59}.btn-success{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--secondary) 0,var(--secondary-dark) 100%);border-color:#0000;box-shadow:0 2px 8px #10b98140;color:#fff}.btn-success:hover{background:linear-gradient(135deg,#34d399,#10b981);background:linear-gradient(135deg,#34d399 0,var(--secondary) 100%);border-color:#0000;box-shadow:0 4px 16px #10b98159}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);background:linear-gradient(135deg,var(--danger) 0,var(--danger-dark) 100%);border-color:#0000;box-shadow:0 2px 8px #ef444440;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#f87171,#ef4444);background:linear-gradient(135deg,#f87171 0,var(--danger) 100%);border-color:#0000;box-shadow:0 4px 16px #ef444459}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);background:linear-gradient(135deg,var(--warning) 0,var(--warning-dark) 100%);border-color:#0000;color:#fff}.btn-warning:hover{background:linear-gradient(135deg,#fcd34d,#f59e0b);background:linear-gradient(135deg,#fcd34d 0,var(--warning) 100%);border-color:#0000}.btn-secondary{background-color:#e8edf3;background-color:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border);color:#0f172a;color:var(--text-primary)}.btn-secondary:hover{background-color:#e2e8f0;background-color:var(--border);border-color:#94a3b8;border-color:var(--text-muted)}.btn-ghost{background-color:initial;border-color:#0000;box-shadow:none;color:#475569;color:var(--text-secondary)}.btn-ghost:hover{background-color:#e8edf3;background-color:var(--bg-secondary);border-color:#0000;color:#0f172a;color:var(--text-primary)}.btn-sm{font-size:.75rem;padding:5px 10px}.btn-lg{border-radius:.625rem;border-radius:var(--radius-md);font-size:.9375rem;padding:12px 24px}.btn-icon{height:36px;padding:8px;width:36px}.btn-icon-sm{height:28px;padding:5px;width:28px}.btn-loading{color:#0000!important;pointer-events:none;position:relative}.btn-loading:after{animation:spin .65s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:15px;left:50%;margin:-7.5px 0 0 -7.5px;position:absolute;top:50%;width:15px}.form-group{margin-bottom:1.25rem;margin-bottom:var(--space-5)}.form-group label{color:#0f172a;color:var(--text-primary);display:block;font-size:.8125rem;font-weight:600;letter-spacing:.01em;margin-bottom:.5rem;margin-bottom:var(--space-2)}.form-group input,.form-group select,.form-group textarea{background-color:#fff;background-color:var(--card-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:.5rem;border-radius:var(--radius);color:#0f172a;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;font-family:var(--font-sans);font-size:.875rem;line-height:1.5;padding:9px 12px;transition:all .18s ease;transition:var(--transition);width:100%}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:#94a3b8;border-color:var(--text-muted)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background-color:#fff;background-color:var(--card-bg);border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#e8edf3;background-color:var(--bg-secondary);cursor:not-allowed;opacity:.65}.form-group input::placeholder,.form-group textarea::placeholder{color:#94a3b8;color:var(--text-muted)}.input-wrapper{position:relative}.input-wrapper input{padding-left:38px}.input-icon{left:10px;pointer-events:none}.input-icon,.input-suffix{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;position:absolute;top:50%;transform:translateY(-50%)}.input-suffix{background:none;border:none;border-radius:.25rem;border-radius:var(--radius-sm);cursor:pointer;padding:4px;right:10px;transition:all .18s ease;transition:var(--transition)}.input-suffix:hover{color:#0f172a;color:var(--text-primary)}.form-hint{color:#94a3b8;color:var(--text-muted)}.form-error,.form-hint{font-size:.75rem;margin-top:5px}.form-error{align-items:center;color:#ef4444;color:var(--danger);display:flex;gap:4px}.table-container{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.625rem;border-radius:var(--radius-md);overflow-x:auto}table{background:#fff;background:var(--card-bg);border-collapse:collapse;font-size:.875rem;width:100%}thead{background:#e8edf3;background:var(--bg-secondary);position:-webkit-sticky;position:sticky;top:0;z-index:1}th{border-bottom:1.5px solid #e2e8f0;border-bottom:1.5px solid var(--border);color:#475569;color:var(--text-secondary);font-size:.75rem;font-weight:700;letter-spacing:.06em;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}td{border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light);color:#0f172a;color:var(--text-primary);padding:12px 16px;vertical-align:middle}tbody tr{transition:background-color .12s ease}tbody tr:hover{background-color:#f0f4f8;background-color:var(--bg-primary)}tbody tr:last-child td{border-bottom:none}.table-actions{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.7rem;font-weight:700;gap:4px;letter-spacing:.06em;padding:3px 9px;text-transform:uppercase;white-space:nowrap}.badge-primary{background:#2563eb1a;color:#2563eb;color:var(--primary)}.badge-success{background:#10b9811f;color:#059669;color:var(--secondary-dark)}.badge-warning{background:#f59e0b1f;color:#d97706;color:var(--warning-dark)}.badge-danger{background:#ef44441f;color:#dc2626;color:var(--danger-dark)}.badge-info{background:#3b82f61a;color:#3b82f6;color:var(--info)}.badge-neutral{background:#e8edf3;background:var(--bg-secondary);color:#475569;color:var(--text-secondary)}.alert{align-items:flex-start;border-radius:.5rem;border-radius:var(--radius);display:flex;font-size:.875rem;font-weight:500;gap:10px;line-height:1.5;margin-bottom:1rem;margin-bottom:var(--space-4);padding:10px 16px}.alert-success{background:#10b9811a;border:1px solid #10b98140;border-left:4px solid #10b981;border-left:4px solid var(--success);color:#065f46}.alert-error{background:#ef444414;border:1px solid #ef444433;border-left:4px solid #ef4444;border-left:4px solid var(--danger);color:#991b1b}.alert-warning{background:#f59e0b14;border:1px solid #f59e0b33;border-left:4px solid #f59e0b;border-left:4px solid var(--warning);color:#92400e}.alert-info{background:#3b82f614;border:1px solid #3b82f633;border-left:4px solid #3b82f6;border-left:4px solid var(--info);color:#1e3a8a}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{animation:shimmer 1.5s linear infinite;background:linear-gradient(90deg,#f1f5f9 25%,#e8edf3 50%,#f1f5f9 75%);background:linear-gradient(90deg,var(--border-light) 25%,var(--bg-secondary) 50%,var(--border-light) 75%);background-size:600px 100%;border-radius:.5rem;border-radius:var(--radius);display:block}.skeleton-text{height:14px}.skeleton-text,.skeleton-title{border-radius:.25rem;border-radius:var(--radius-sm)}.skeleton-title{height:22px}.skeleton-card{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.875rem;border-radius:var(--radius-lg);height:120px}.skeleton-row{border-radius:.25rem;border-radius:var(--radius-sm);height:44px}.skeleton-stats{grid-gap:1rem;grid-gap:var(--space-4);display:grid;gap:1rem;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.5rem;margin-bottom:var(--space-6)}.spinner{animation:spin .75s linear infinite;border:2.5px solid #e2e8f0;border-top-color:#2563eb;border:2.5px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:36px;margin:2rem auto;margin:var(--space-8) auto;width:36px}.spinner-sm{border-width:2px;height:16px;margin:0;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container{align-items:center;display:flex;flex-direction:column;font-size:14px;gap:1rem;gap:var(--space-4);justify-content:center;padding:3rem;padding:var(--space-12)}.empty-state,.loading-container{color:#475569;color:var(--text-secondary)}.empty-state{padding:3rem 2rem;padding:var(--space-12) var(--space-8);text-align:center}.empty-state-icon{align-items:center;background:#e8edf3;background:var(--bg-secondary);border-radius:1.25rem;border-radius:var(--radius-xl);color:#94a3b8;color:var(--text-muted);display:flex;font-size:2rem;height:72px;justify-content:center;margin:0 auto 1rem;margin:0 auto var(--space-4);width:72px}.empty-state h3{color:#0f172a;color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:.5rem!important;margin-bottom:var(--space-2)!important}.empty-state p{color:#475569;color:var(--text-secondary);font-size:14px;margin-bottom:1.25rem;margin-bottom:var(--space-5)}.modal-overlay{align-items:center;animation:overlayIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1050}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal,.modal-content{animation:modalIn .22s cubic-bezier(.34,1.56,.64,1);background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:1.25rem;border-radius:var(--radius-xl);box-shadow:0 24px 48px -12px #0000002e;box-shadow:var(--shadow-xl);max-height:90vh;max-width:520px;overflow-y:auto;padding:1.5rem;padding:var(--space-6);position:relative;width:100%}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{color:#0f172a;color:var(--text-primary);font-size:1.125rem;gap:.5rem;gap:var(--space-2)}.modal h3,.modal-header{align-items:center;display:flex;margin-bottom:1.25rem;margin-bottom:var(--space-5)}.modal-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);justify-content:space-between;padding-bottom:1rem;padding-bottom:var(--space-4)}.modal-header h3{font-size:1.125rem;font-weight:700;gap:.5rem;gap:var(--space-2);margin:0}.modal-close,.modal-header h3{align-items:center;display:flex}.modal-close{background:none;border:none;border-radius:.5rem;border-radius:var(--radius);color:#94a3b8;color:var(--text-muted);cursor:pointer;flex-shrink:0;height:30px;justify-content:center;transition:all .18s ease;transition:var(--transition);width:30px}.modal-close:hover{background:#e8edf3;background:var(--bg-secondary);color:#0f172a;color:var(--text-primary)}.modal-body{margin-bottom:1.25rem;margin-bottom:var(--space-5)}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;gap:.75rem;gap:var(--space-3);justify-content:flex-end;padding-top:1rem;padding-top:var(--space-4)}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:380px;pointer-events:none;position:fixed;right:20px;top:80px;top:calc(var(--header-height) + 16px);z-index:9999}.toast{align-items:flex-start;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border-left:4px solid #2563eb;border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:.875rem;border-radius:var(--radius-lg);box-shadow:0 16px 32px -8px #0000001f,0 8px 16px -4px #0000000f;box-shadow:var(--shadow-lg);display:flex;gap:10px;min-width:300px;padding:12px 16px;pointer-events:all}@keyframes toastIn{0%{opacity:0;transform:translateX(100%) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}.toast-icon{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;flex-shrink:0;font-size:13px;height:22px;justify-content:center;margin-top:1px;width:22px}.toast-content{flex:1 1;min-width:0}.toast-title{color:#0f172a;color:var(--text-primary);font-size:.8125rem;font-weight:700;margin-bottom:2px}.toast-message{color:#475569;color:var(--text-secondary);font-size:.78rem;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:.25rem;border-radius:var(--radius-sm);color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;padding:2px;transition:all .18s ease;transition:var(--transition);width:20px}.toast-close:hover{background:#e8edf3;background:var(--bg-secondary);color:#0f172a;color:var(--text-primary)}.toast-success{border-left-color:#10b981;border-left-color:var(--success)}.toast-success .toast-icon{background:#10b9811f;color:#10b981;color:var(--success)}.toast-error{border-left-color:#ef4444;border-left-color:var(--danger)}.toast-error .toast-icon{background:#ef44441a;color:#ef4444;color:var(--danger)}.toast-warning{border-left-color:#f59e0b;border-left-color:var(--warning)}.toast-warning .toast-icon{background:#f59e0b1a;color:#f59e0b;color:var(--warning)}.toast-info{border-left-color:#3b82f6;border-left-color:var(--info)}.toast-info .toast-icon{background:#3b82f61a;color:#3b82f6;color:var(--info)}.notification-bell{align-items:center;background:#ffffff1f;border:1px solid #ffffff26;border-radius:.5rem;border-radius:var(--radius);color:#fff;cursor:pointer;display:flex;height:38px;justify-content:center;position:relative;transition:all .18s ease;transition:var(--transition);width:38px}.notification-bell:hover{background:#ffffff38;border-color:#ffffff4d}.notification-badge{align-items:center;animation:badgePulse 2s ease-in-out infinite;background:#ef4444;background:var(--danger);border:2px solid #1d4ed8;border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;font-size:9px;font-weight:800;height:16px;justify-content:center;min-width:16px;padding:0 3px;position:absolute;right:-2px;top:-2px}.notification-dropdown{animation:dropdownIn .18s ease;background:#fff;background:var(--card-bg);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:.875rem;border-radius:var(--radius-lg);box-shadow:0 24px 48px -12px #0000002e;box-shadow:var(--shadow-xl);max-height:480px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:1100}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-header{align-items:center;background:#fff;background:var(--card-bg);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#0f172a;color:var(--text-primary);display:flex;font-size:.875rem;font-weight:700;justify-content:space-between;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.notification-item{align-items:flex-start;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:all .18s ease;transition:var(--transition)}.notification-item:hover{background:#f0f4f8;background:var(--bg-primary)}.notification-item.unread{background:#2563eb14;background:var(--primary-ghost)}.notification-item.unread:hover{background:#2563eb1f}.notification-item-icon{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;flex-shrink:0;font-size:1.1rem;height:38px;justify-content:center;width:38px}.notification-item-content{flex:1 1;min-width:0}.notification-item-title{color:#0f172a;color:var(--text-primary);font-size:.8125rem;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-item-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#475569;color:var(--text-secondary);display:-webkit-box;font-size:.775rem;line-height:1.4;overflow:hidden}.notification-item-time{color:#94a3b8;color:var(--text-muted);font-size:.68rem;margin-top:3px;white-space:nowrap}.notification-empty{color:#94a3b8;color:var(--text-muted);font-size:13px;padding:40px 16px;text-align:center}.confirm-modal{max-width:420px}.confirm-modal-icon{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:flex;font-size:1.75rem;height:60px;justify-content:center;margin:0 auto 1rem;margin:0 auto var(--space-4);width:60px}.confirm-modal-icon.danger{background:#ef44441a;color:#ef4444;color:var(--danger)}.confirm-modal-icon.warning{background:#f59e0b1a;color:#f59e0b;color:var(--warning)}.confirm-modal-icon.success{background:#10b9811a;color:#10b981;color:var(--success)}.confirm-modal-title{color:#0f172a;color:var(--text-primary);font-size:1.125rem;font-weight:700;margin-bottom:.75rem;margin-bottom:var(--space-3);text-align:center}.confirm-modal-message{color:#475569;color:var(--text-secondary);font-size:.875rem;line-height:1.6;margin-bottom:1.5rem;margin-bottom:var(--space-6);text-align:center}.progress{background:#e8edf3;background:var(--bg-secondary);height:6px;overflow:hidden;width:100%}.progress,.progress-bar{border-radius:9999px;border-radius:var(--radius-full)}.progress-bar{background:linear-gradient(90deg,#2563eb,#3b82f6);background:linear-gradient(90deg,var(--primary) 0,var(--primary-light) 100%);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-bar.success{background:linear-gradient(90deg,#059669,#10b981);background:linear-gradient(90deg,var(--secondary-dark),var(--secondary))}.progress-bar.warning{background:linear-gradient(90deg,#d97706,#f59e0b);background:linear-gradient(90deg,var(--warning-dark),var(--warning))}.progress-bar.danger{background:linear-gradient(90deg,#dc2626,#ef4444);background:linear-gradient(90deg,var(--danger-dark),var(--danger))}.divider{border:none;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);margin:1rem 0;margin:var(--space-4) 0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1}.gap-1{gap:.25rem;gap:var(--space-1)}.gap-2{gap:.5rem;gap:var(--space-2)}.gap-3{gap:.75rem;gap:var(--space-3)}.gap-4{gap:1rem;gap:var(--space-4)}.gap-sm{gap:.5rem;gap:var(--space-2)}.gap-md{gap:1rem;gap:var(--space-4)}.gap-lg{gap:1.5rem;gap:var(--space-6)}.mt-sm{margin-top:.5rem;margin-top:var(--space-2)}.mt-md{margin-top:1rem;margin-top:var(--space-4)}.mt-lg{margin-top:1.5rem;margin-top:var(--space-6)}.mb-sm{margin-bottom:.5rem;margin-bottom:var(--space-2)}.mb-md{margin-bottom:1rem;margin-bottom:var(--space-4)}.mb-lg{margin-bottom:1.5rem;margin-bottom:var(--space-6)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#94a3b8;color:var(--text-muted)}.text-secondary{color:#475569;color:var(--text-secondary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input-wrapper input{background:#fff;background:var(--card-bg);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:.5rem;border-radius:var(--radius);color:#0f172a;color:var(--text-primary);font-size:.875rem;padding-bottom:8px;padding-left:38px;padding-top:8px;transition:all .18s ease;transition:var(--transition);width:100%}.search-input-wrapper input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-icon{color:#94a3b8;color:var(--text-muted);display:flex;left:11px;pointer-events:none;position:absolute}@media (max-width:1024px){.container{padding:1rem 1.25rem;padding:var(--space-4) var(--space-5)}.stats-grid{gap:.75rem;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:768px){:root{--header-height:60px;--sidebar-width:248px}.container{padding:1rem;padding:var(--space-4)}.stats-grid{gap:.75rem;gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.stat-card-value{font-size:1.625rem}.stat-card-value.long-number{font-size:1.25rem}.stat-card-icon{font-size:1.2rem;height:40px;width:40px}.card{padding:1rem;padding:var(--space-4)}table{font-size:.8125rem}td,th{padding:9px 12px}.sidebar-overlay{animation:overlayIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;display:block;inset:0;position:fixed;top:64px;top:var(--header-height);z-index:998}.toast-container{left:10px;max-width:none;right:10px}.toast{min-width:auto}.notification-dropdown{right:-12px;width:calc(100vw - 24px)}.modal,.modal-content{padding:1rem;padding:var(--space-4)}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{justify-content:center;width:100%}.user-info{display:none}.page-header{flex-direction:column;gap:12px}}@media (max-width:480px){.container{padding:.75rem;padding:var(--space-3)}.stats-grid{gap:.5rem;gap:var(--space-2);grid-template-columns:1fr 1fr}.stat-card{padding:1rem;padding:var(--space-4)}.stat-card-value{font-size:1.35rem}.stat-card-value.long-number{font-size:1.1rem}.stat-card-icon{font-size:1rem;height:36px;width:36px}.card{margin-bottom:.75rem;margin-bottom:var(--space-3);padding:.75rem;padding:var(--space-3)}td,th{font-size:.75rem;padding:8px 10px}.badge{font-size:.65rem;padding:2px 6px}.btn{font-size:.75rem}.toast-container{top:72px;top:calc(var(--header-height) + 8px)}}@media print{.btn,.modal-overlay,.sidebar,.toast-container,.top-header{display:none!important}.container{margin:0;padding:0}.card{border:1px solid #ddd;box-shadow:none;page-break-inside:avoid}table{font-size:11px}}
/*# sourceMappingURL=main.6d59fe1b.css.map*/