body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--primary-light:#dbeafe;--success-color:#10b981;--success-hover:#059669;--warning-color:#f59e0b;--warning-hover:#d97706;--danger-color:#ef4444;--danger-hover:#dc2626;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--border-radius:0.75rem;--border-radius-sm:0.5rem;--border-radius-lg:1rem}.btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);border:none;border-radius:.5rem;border-radius:var(--border-radius-sm);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--primary-hover) 0,#1d4ed8 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:disabled{background:#9ca3af;background:var(--gray-400);box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{align-items:center;background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--border-radius-sm);color:#374151;color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.btn-secondary:hover{background:#f9fafb;background:var(--gray-50);border-color:#9ca3af;border-color:var(--gray-400);transform:translateY(-1px)}.btn-secondary:hover,.btn-success{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.btn-success{align-items:center;background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%);border:none;border-radius:.5rem;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);background:linear-gradient(135deg,var(--success-hover) 0,#047857 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);background:linear-gradient(135deg,var(--danger-color) 0,var(--danger-hover) 100%);border:none;border-radius:.5rem;border-radius:var(--border-radius-sm);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);background:linear-gradient(135deg,var(--danger-hover) 0,#b91c1c 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--border-radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:2rem;transition:all .3s ease-in-out}.card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-2px)}.card-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);margin-bottom:1.5rem;padding-bottom:1rem}.card-title{color:#111827;color:var(--gray-900);font-size:1.5rem;font-weight:700;margin:0}.card-subtitle{color:#4b5563;color:var(--gray-600);font-size:.875rem;margin-top:.25rem}.input-field{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:.5rem;border-radius:var(--border-radius-sm);color:#111827;color:var(--gray-900);font-size:.875rem;padding:.75rem 1rem;transition:all .2s ease-in-out;width:100%}.input-field:focus{border-color:#3b82f6;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a;outline:none;transform:translateY(-1px)}.input-field:disabled{background:#f9fafb;background:var(--gray-50);color:#6b7280;color:var(--gray-500);cursor:not-allowed}.form-label{color:#374151;color:var(--gray-700);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-error{color:#ef4444;color:var(--danger-color)}.form-error,.form-help{font-size:.75rem;margin-top:.25rem}.form-help{color:#6b7280;color:var(--gray-500)}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.login-card{background:#fff;border-radius:1rem;border-radius:var(--border-radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-width:450px;padding:3rem 2rem;text-align:center;width:100%}.login-logo{align-items:center;border-radius:50%;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;height:80px;justify-content:center;margin:0 auto 2rem;width:80px}.login-logo,.login-title{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%)}.login-title{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;color:#111827;color:var(--gray-900);font-size:2rem;font-weight:800;margin:0 0 .5rem}.login-subtitle{color:#4b5563;color:var(--gray-600);font-size:1rem;margin:0 0 2rem}.login-form{margin-top:2rem}.password-container{position:relative}.password-toggle{background:none;border:none;border-radius:.25rem;color:#6b7280;color:var(--gray-500);cursor:pointer;padding:.25rem;position:absolute;right:1rem;top:50%;transform:translateY(-50%);transition:all .2s ease-in-out}.password-toggle:hover{background:#f3f4f6;background:var(--gray-100);color:#374151;color:var(--gray-700)}.layout-container{background:#f9fafb;background:var(--gray-50);min-height:100vh}.sidebar{background:#fff;border-right:1px solid #e5e7eb;border-right:1px solid var(--gray-200);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);height:100vh;left:0;position:fixed;top:0;transition:all .3s ease-in-out;width:280px;z-index:40}.sidebar-header{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#fff;padding:1.5rem}.sidebar-title{font-size:1.5rem;font-weight:800;margin:0}.nav-link{align-items:center;border-radius:.5rem;border-radius:var(--border-radius-sm);color:#4b5563;color:var(--gray-600);display:flex;font-weight:500;margin:.25rem 1rem;overflow:hidden;padding:1rem 1.5rem;position:relative;text-decoration:none;transition:all .2s ease-in-out}.nav-link:before{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);content:"";height:100%;left:0;position:absolute;top:0;transition:width .3s ease-in-out;width:0;z-index:-1}.nav-link:hover{background:#dbeafe;background:var(--primary-light);color:#3b82f6;color:var(--primary-color);transform:translateX(4px)}.nav-link:hover:before{width:100%}.nav-link.active{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff}.nav-link.active:before{width:100%}.header{background:#fff;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:30}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.header-title{color:#111827;color:var(--gray-900);font-size:1.25rem;font-weight:700;margin:0}.header-actions{align-items:center;display:flex;gap:1rem}.main-content{margin:0 auto;max-width:1400px;padding:5rem 2rem 2rem}.dashboard-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--border-radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden;padding:2rem;position:relative;transition:all .3s ease-in-out}.stat-card:before{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);border-radius:.75rem;border-radius:var(--border-radius);color:#fff;display:flex;font-size:1.5rem;height:4rem;justify-content:center;margin-bottom:1.5rem;width:4rem}.stat-value{color:#111827;color:var(--gray-900);font-size:2.5rem;font-weight:800;line-height:1;margin-bottom:.5rem}.stat-label{color:#4b5563;color:var(--gray-600);letter-spacing:.05em;text-transform:uppercase}.stat-change,.stat-label{font-size:.875rem;font-weight:600}.stat-change{margin-top:.5rem}.stat-change.positive{color:#10b981;color:var(--success-color)}.stat-change.negative{color:#ef4444;color:var(--danger-color)}.table-container{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--border-radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{background:#f9fafb;background:var(--gray-50);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);color:#4b5563;color:var(--gray-600);font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:1rem 1.5rem;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);color:#374151;color:var(--gray-700);font-size:.875rem;padding:1rem 1.5rem}.table tbody tr:hover{background:#f9fafb;background:var(--gray-50)}.table tbody tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.badge-primary{background:#dbeafe;background:var(--primary-light);color:#2563eb;color:var(--primary-hover)}.badge-success{background:#d1fae5;color:#059669;color:var(--success-hover)}.badge-warning{background:#fef3c7;color:#d97706;color:var(--warning-hover)}.badge-danger{background:#fee2e2;color:#dc2626;color:var(--danger-hover)}.badge-gray{background:#f3f4f6;background:var(--gray-100);color:#374151;color:var(--gray-700)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:50}.modal{background:#fff;border-radius:1rem;border-radius:var(--border-radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-title{color:#111827;color:var(--gray-900);font-size:1.25rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:.25rem;color:#9ca3af;color:var(--gray-400);cursor:pointer;padding:.5rem;transition:all .2s ease-in-out}.modal-close:hover{background:#f3f4f6;background:var(--gray-100);color:#4b5563;color:var(--gray-600)}.modal-body{flex:1 1;overflow-y:auto;padding:2rem}.modal-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.form-section{margin-bottom:2rem}.form-section-title{border-bottom:2px solid #dbeafe;border-bottom:2px solid var(--primary-light);color:#111827;color:var(--gray-900);font-size:1.125rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-row{align-items:end;display:flex;gap:1rem}.form-row .form-group{flex:1 1;margin-bottom:0}.action-buttons{gap:.5rem}.action-buttons,.btn-icon{align-items:center;display:flex}.btn-icon{border:none;border-radius:.5rem;border-radius:var(--border-radius-sm);cursor:pointer;font-size:.875rem;justify-content:center;padding:.5rem;transition:all .2s ease-in-out}.btn-icon:hover{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-icon-edit{background:#dbeafe;background:var(--primary-light);color:#2563eb;color:var(--primary-hover)}.btn-icon-edit:hover{background:#3b82f6;background:var(--primary-color);color:#fff}.btn-icon-delete{background:#fee2e2;color:#dc2626;color:var(--danger-hover)}.btn-icon-delete:hover{background:#ef4444;background:var(--danger-color);color:#fff}.empty-state{color:#6b7280;color:var(--gray-500);padding:3rem 2rem;text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-title{color:#374151;color:var(--gray-700);font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.empty-state-description{font-size:.875rem;margin-bottom:1.5rem}.loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;border:3px solid var(--gray-200);border-top-color:var(--primary-color);display:inline-block;height:2rem;width:2rem}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0;padding:1rem}.dashboard-stats,.form-grid{grid-template-columns:1fr}}.sidebar.closed{transform:translateX(-100%)}.main-content.sidebar-closed{margin-left:0}.main-content.sidebar-open{margin-left:280px}.sidebar{transition:transform .3s ease-in-out}.main-content{transition:margin-left .3s ease-in-out}@media (max-width:768px){.card{padding:1.5rem}.modal{margin:1rem;max-width:calc(100vw - 2rem)}.header-content,.modal-body,.modal-footer,.modal-header{padding:1rem}.btn-danger,.btn-primary,.btn-secondary,.btn-success{font-size:.8125rem;padding:.625rem 1.25rem}}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-in-out}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100);border-radius:4px}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--gray-400)}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--primary-color);outline-offset:2px}::selection{background:#dbeafe;background:var(--primary-light);color:#2563eb;color:var(--primary-hover)}
/*# sourceMappingURL=main.d77d7c08.css.map*/