@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap";:root{font-family:Manrope,Segoe UI,Helvetica Neue,sans-serif;color:#e2e8f0;background-color:#0b1021;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:#0b1021}a{color:inherit}.alert{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-radius:var(--radius-sm, 10px);border:1px solid;box-shadow:0 10px 40px #00000040;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideIn .3s ease-out;position:relative;overflow:hidden}.alert:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 20%,currentColor,transparent 60%);opacity:.03;pointer-events:none}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-exit{animation:slideOut .3s ease-out forwards}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.alert-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.alert-content{flex:1;min-width:0}.alert-message{margin:0;font-size:14px;line-height:1.5;font-weight:500}.alert-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:2px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:currentColor;opacity:.6;transition:all .2s ease}.alert-close:hover{opacity:1;background:#ffffff1a}.alert-close:active{transform:scale(.95)}.alert-success{background:#34d39914;border-color:#34d3994d;color:#34d399}.alert-success .alert-message{color:#e2e8f0}.alert-error{background:#f8717114;border-color:#f871714d;color:#f87171}.alert-error .alert-message{color:#e2e8f0}.alert-warning{background:#fbbf2414;border-color:#fbbf244d;color:#fbbf24}.alert-warning .alert-message{color:#e2e8f0}.alert-info{background:#7dd3fc14;border-color:#7dd3fc4d;color:#7dd3fc}.alert-info .alert-message{color:#e2e8f0}.alert-mode-clear.alert-success .alert-message{color:#065f46}.alert-mode-clear.alert-error .alert-message{color:#991b1b}.alert-mode-clear.alert-warning .alert-message{color:#92400e}.alert-mode-clear.alert-info .alert-message{color:#0c4a6e}@media(max-width:640px){.alert{padding:14px 16px;gap:10px}.alert-message{font-size:13px}.alert-icon,.alert-close{width:20px;height:20px}}.navbar{position:sticky;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px clamp(14px,3vw,24px);background:#0b1021e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}.nav-brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;color:#e2e8f0}.logo-dot{width:12px;height:12px;border-radius:999px;background:linear-gradient(135deg,#22d3ee,#a855f7);box-shadow:0 0 12px #a855f780}.nav-links{display:flex;align-items:center;gap:16px;color:#cbd5e1}.nav-links a{color:inherit;font-weight:600;text-decoration:none;padding:8px 10px;border-radius:10px;transition:color .2s ease,background .2s ease}.nav-links a:hover{color:#e2e8f0;background:#ffffff0f}.nav-ctas{display:inline-flex;gap:10px;margin-left:4px}.nav-ctas .outline,.nav-ctas .primary{border-radius:12px;padding:9px 14px;font-weight:700;text-decoration:none;border:1px solid transparent}.nav-ctas .outline{border-color:#fff3;color:#e2e8f0}.nav-ctas .outline:hover{background:#ffffff0f}.nav-ctas .primary{background:linear-gradient(135deg,#22d3ee,#a855f7);color:#0b1021;box-shadow:0 10px 24px #a855f740}.nav-ctas .primary:hover{transform:translateY(-1px)}.nav-toggle{display:none;width:42px;height:42px;border-radius:12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);align-items:center;justify-content:center;flex-direction:column;gap:6px;padding:10px;cursor:pointer}.nav-toggle span{width:100%;height:2px;background:#e2e8f0;display:block}@media(max-width:900px){.nav-toggle{display:inline-flex}.nav-links{position:absolute;inset:60px 12px auto;flex-direction:column;align-items:flex-start;background:#0b1021f2;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px;box-shadow:0 18px 40px #00000073;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease}.nav-links.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-ctas{width:100%;justify-content:flex-start}}:root{--bg: #0b1021;--panel: rgba(255, 255, 255, .04);--card: #0f172a;--card-stroke: rgba(255, 255, 255, .08);--accent: #7dd3fc;--accent-2: #a78bfa;--text: #e2e8f0;--muted: #94a3b8;--error: #f87171;--success: #34d399;--shadow: 0 20px 80px rgba(0, 0, 0, .35);--radius: 14px;--radius-sm: 10px}.page{min-height:100vh;padding:48px clamp(16px,3vw,56px);background:radial-gradient(circle at 20% 20%,rgba(124,58,237,.15),transparent 30%),radial-gradient(circle at 80% 0%,rgba(56,189,248,.12),transparent 30%),radial-gradient(circle at 50% 80%,rgba(59,130,246,.12),transparent 25%),var(--bg);color:var(--text);font-family:Manrope,Segoe UI,Helvetica Neue,sans-serif}.hero{position:relative;background:linear-gradient(135deg,#7dd3fc14,#a78bfa14);border:1px solid var(--card-stroke);border-radius:calc(var(--radius) + 4px);padding:clamp(20px,3vw,36px);margin:0 auto clamp(28px,5vw,48px);max-width:1100px;box-shadow:var(--shadow);overflow:hidden}.hero-glow{position:absolute;inset:-30%;background:radial-gradient(circle,rgba(167,139,250,.12) 0%,transparent 45%);filter:blur(30px);z-index:0}.hero-copy{position:relative;z-index:1;max-width:720px}.hero h1{margin:8px 0 10px;font-size:clamp(28px,4vw,44px);letter-spacing:-.02em}.hero p{color:var(--muted);max-width:640px}.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#ffffff0f;border:1px solid var(--card-stroke);color:var(--text);font-weight:600;font-size:14px}.bullets{display:grid;gap:10px;list-style:none;padding:0;margin:18px 0 0;color:var(--text)}.bullets li{padding-left:24px;position:relative}.bullets li:before{content:"•";position:absolute;left:6px;color:var(--accent);font-size:18px;line-height:1}.registration-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--card);border:1px solid var(--card-stroke);border-radius:var(--radius);padding:clamp(16px,4vw,28px);box-shadow:var(--shadow);max-width:1100px;margin:0 auto 48px}.section-heading{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.section-heading h2{margin:4px 0;letter-spacing:-.01em}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--accent);margin:0}.muted{color:var(--muted);margin:0}.pill{padding:8px 14px;border-radius:999px;background:#7dd3fc1a;border:1px solid rgba(125,211,252,.3);color:var(--text);font-weight:600;font-size:14px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}.form-block{background:var(--panel);border:1px solid var(--card-stroke);border-radius:var(--radius-sm);padding:16px 16px 20px;display:grid;gap:12px}.form-block h3{margin:0 0 4px}.field{display:flex;flex-direction:column;gap:8px}.field-label{display:flex;gap:6px;align-items:center;color:var(--text);font-weight:600;font-size:14px}.field input,.field select{width:100%;background:#ffffff0a;border:1px solid var(--card-stroke);border-radius:10px;padding:12px;color:var(--text);font-size:15px;transition:border-color .2s ease,box-shadow .2s ease}.field select option{background:#0f172a;color:var(--text)}.field input:focus,.field select:focus{outline:none;border-color:#7dd3fc99;box-shadow:0 0 0 4px #7dd3fc1f}.field-error{color:var(--error);font-size:13px}.required{color:var(--accent)}.checkbox{display:flex;gap:10px;align-items:center;color:var(--text);font-size:14px;margin-top:6px}.checkbox input{width:18px;height:18px}.login-wrapper{display:flex;justify-content:center;padding-top:32px}.login-card{max-width:520px;width:100%}.login-block{margin-top:4px}.recaptcha-box{margin-top:8px}.recaptcha-frame{min-height:78px}button.primary{width:100%;margin-top:10px;border:none;border-radius:12px;padding:14px 16px;background:linear-gradient(135deg,#22d3ee,#a855f7);color:#0b1021;font-weight:700;font-size:16px;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease,opacity .2s ease}button.primary:hover{transform:translateY(-1px);box-shadow:0 10px 30px #a855f740}button.primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.banner{margin-top:12px;padding:12px 14px;border-radius:12px;font-weight:600;border:1px solid transparent}.banner.success{color:#0f5132;background:#34d3992e;border-color:#34d39966}.banner.error{color:#7f1d1d;background:#f8717126;border-color:#f8717166}@media(max-width:720px){.page{padding:24px 14px 32px}.section-heading{flex-direction:column;align-items:flex-start}.form-block{padding:14px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f0f2f5;padding:24px}.login-container{width:100%;max-width:480px}.login-logo{text-align:center;margin-bottom:40px}.logo-text{font-size:32px;font-weight:800;color:#1e293b;letter-spacing:-.02em}.login-form{background:#fff;border-radius:16px;padding:40px 32px;box-shadow:0 2px 8px #00000014}.login-title{font-size:24px;font-weight:600;color:#1e293b;text-align:center;margin:0 0 32px;letter-spacing:-.01em}.login-fields{display:grid;gap:20px;margin-bottom:16px}.login-field{display:flex;flex-direction:column;gap:8px}.login-label{font-size:14px;font-weight:500;color:#475569}.required-asterisk{color:#ef4444}.login-input{width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:8px;font-size:15px;color:#1e293b;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.login-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .login-input{padding-right:80px}.password-toggle{position:absolute;right:12px;background:none;border:none;color:#3b82f6;font-size:14px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s ease}.password-toggle:hover{background:#3b82f61a}.remember-field{display:flex;align-items:center;gap:8px;margin-top:8px;margin-bottom:8px;cursor:pointer}.remember-field input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1e40af}.remember-field span{font-size:14px;color:var(--muted);-webkit-user-select:none;user-select:none}.forgot-password{font-size:14px;color:#1e40af;text-decoration:none;margin-top:-8px;display:inline-block}.forgot-password:hover{text-decoration:underline}.login-button{width:100%;padding:14px;background:#1e293b;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:24px;transition:background .2s ease,transform .1s ease}.login-button:hover:not(:disabled){background:#0f172a;transform:translateY(-1px)}.login-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:720px){.login-page{padding:16px}.login-form{padding:32px 24px}}.dashboard-navbar{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001a}.dashboard-nav-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px}.dashboard-brand{display:flex;align-items:center;gap:.75rem}.brand-logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-subtitle{font-size:.875rem;color:#6b7280;font-weight:500;padding-left:.75rem;border-left:2px solid #e5e7eb}.dashboard-menu-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px}.dashboard-menu-toggle span{width:24px;height:2px;background:#374151;border-radius:2px;transition:all .3s}.dashboard-nav-menu{display:flex;align-items:center;gap:2rem}.dashboard-nav-links{display:flex;list-style:none;gap:.25rem;margin:0;padding:0}.dashboard-nav-links a{display:block;padding:.625rem 1.25rem;color:#4b5563;text-decoration:none;font-weight:500;font-size:.9375rem;border-radius:8px;transition:all .2s;position:relative}.dashboard-nav-links a:hover{background:#f3f4f6;color:#667eea}.dashboard-nav-links a.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dashboard-nav-actions{display:flex;align-items:center;gap:1rem}.logout-button{padding:.5rem 1.25rem;background:transparent;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-weight:500;font-size:.9375rem;cursor:pointer;transition:all .2s}.logout-button:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}@media(max-width:768px){.dashboard-menu-toggle{display:flex}.dashboard-nav-menu{position:fixed;top:70px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:1rem;box-shadow:0 4px 6px -1px #0000001a;max-height:0;overflow:hidden;transition:max-height .3s ease}.dashboard-nav-menu.open{max-height:500px}.dashboard-nav-links{flex-direction:column;gap:.5rem;width:100%}.dashboard-nav-links a{padding:.875rem 1rem}.dashboard-nav-actions{width:100%;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.logout-button{width:100%}.brand-subtitle{display:none}}.vacation-request-form{background:#fff;border-radius:12px;padding:24px;max-width:600px;margin:0 auto}.vacation-form-loading,.vacation-form-error{text-align:center;padding:40px 20px}.loading-spinner{width:40px;height:40px;margin:0 auto 16px;border:4px solid #edf2f7;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:3rem;margin-bottom:16px}.error-hint{color:#718096;font-size:.875rem;margin-top:8px}.form-header{margin-bottom:24px;text-align:center;border-bottom:2px solid #f7fafc;padding-bottom:16px}.form-title{font-size:1.5rem;font-weight:700;color:#2d3748;margin:0 0 8px;display:flex;align-items:center;justify-content:center;gap:8px}.form-icon{font-size:1.75rem}.form-subtitle{font-size:.875rem;color:#718096;margin:0}.balance-info-box{background:linear-gradient(135deg,#ebf8ff,#f7fafc);border:2px solid #bee3f8;border-radius:8px;padding:16px;margin-bottom:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.balance-info-item{display:flex;flex-direction:column;align-items:center;gap:4px}.info-label{font-size:.75rem;color:#4a5568;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.5rem;font-weight:700;line-height:1}.info-value.available{color:#48bb78}.info-value.requested{color:#4299e1}.info-value.remaining{color:#2d3748}.info-value.remaining.negative{color:#f56565}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.875rem;font-weight:600;color:#2d3748;margin-bottom:8px}.required{color:#f56565}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;font-size:.9375rem;border:1px solid #cbd5e0;border-radius:6px;transition:all .2s ease;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:#edf2f7;cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px}.field-hint{font-size:.75rem;color:#a0aec0;margin-top:4px;margin-bottom:0}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.checkbox-text{font-size:.9375rem;color:#2d3748;font-weight:500}.validation-error,.form-error{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:6px;font-size:.875rem;margin-bottom:16px}.validation-error{background-color:#fff5f5;border:1px solid #feb2b2;color:#c53030}.form-error{background-color:#fff5f5;border:1px solid #fc8181;color:#c53030}.validation-error .error-icon,.form-error .error-icon{font-size:1.125rem}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.btn-cancel,.btn-submit{padding:12px 24px;font-size:.9375rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-cancel{background-color:#edf2f7;color:#4a5568}.btn-cancel:hover:not(:disabled){background-color:#e2e8f0}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-width:180px}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-submit:disabled{background:#cbd5e0;cursor:not-allowed;opacity:.6}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:768px){.vacation-request-form{padding:20px}.form-row{grid-template-columns:1fr}.balance-info-box{grid-template-columns:1fr;gap:12px}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}@media(max-width:480px){.vacation-request-form{padding:16px}.form-title,.info-value{font-size:1.25rem}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #f3f4f6;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.modal-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-steps{display:flex;justify-content:space-between;padding:2rem 2rem 1rem;background:#f9fafb;position:relative}.modal-steps:before{content:"";position:absolute;top:50%;left:2rem;right:2rem;height:2px;background:#e5e7eb;transform:translateY(-50%);z-index:0}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1;flex:1}.step-number{width:40px;height:40px;border-radius:50%;background:#fff;border:2px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:700;color:#9ca3af;transition:all .3s ease}.step-label{font-size:.875rem;color:#6b7280;font-weight:500;text-align:center}.step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;transform:scale(1.1)}.step.active .step-label{color:#667eea;font-weight:600}.step.completed .step-number{background:#10b981;border-color:#10b981;color:#fff}.step.completed .step-label{color:#10b981}.modal-form,.modal-body{padding:2rem}.form-step{min-height:300px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:.25rem}.required{color:#ef4444;font-weight:700}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff;color:#374151;font-family:inherit}.form-group textarea{resize:vertical;min-height:100px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.6}.field-hint{color:#6b7280;font-size:.875rem;margin-top:.25rem}.error-message{color:#ef4444;font-size:.75rem;font-weight:500;margin-top:-.25rem}.form-group-checkboxes{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;margin-top:1rem}.checkbox-labelTransfer,.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem;color:#374151;font-weight:500}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.checkbox-label:hover{color:#667eea}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.modal-loading .spinner{width:48px;height:48px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.modal-loading p{color:#6b7280;font-size:1rem;font-weight:500}.modal-actions{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-top:2px solid #f3f4f6;margin-top:0;gap:1rem}.actions-right{display:flex;gap:1rem;margin-left:auto}.btn{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;gap:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-cancel{background:#fff;color:#6b7280;border:2px solid #e5e7eb}.btn-cancel:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #10b9814d}@media(max-width:768px){.modal-content{max-width:100%;max-height:100vh;border-radius:0}.form-row{grid-template-columns:1fr;gap:1rem}.modal-steps{padding:1rem}.step-label{font-size:.75rem}.step-number{width:32px;height:32px;font-size:.875rem}.modal-form{padding:1rem}.modal-actions{flex-direction:column;gap:.75rem}.actions-right{width:100%;flex-direction:column-reverse}.btn{width:100%;justify-content:center}}.employee-info-banner{background:linear-gradient(135deg,#667eea15,#764ba215);border-left:4px solid #667eea;padding:1rem 1.5rem;margin:0 2rem 1rem;border-radius:8px;display:flex;gap:.75rem;align-items:center}.info-label{font-weight:600;color:#667eea;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1.125rem;font-weight:600;color:#1f2937}.checkbox-group{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding:1rem;background:#f9fafb;border-radius:8px;border:2px solid #e5e7eb}.checkbox-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.checkbox-item:hover{border-color:#667eea;background:#f8f9ff;transform:translate(4px)}.checkbox-item input[type=checkbox]{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.checkbox-item input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem;color:#374151;font-weight:500}.checkbox-label strong{color:#1f2937;font-size:1rem;font-weight:600}.checkbox-description{color:#6b7280;font-size:.875rem;line-height:1.4}.selected-summary{padding:1rem;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:8px;text-align:center;color:#667eea;font-weight:600;border:2px dashed #667eea}.empty-state-inline{padding:2rem;text-align:center;color:#6b7280;background:#f9fafb;border-radius:8px;border:2px dashed #e5e7eb}.empty-state-inline p{margin:0;font-size:.9375rem}.form-section{margin-bottom:1.5rem}.section-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.info-row{display:flex;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.info-row:last-child{border-bottom:none}.info-row label{font-weight:600;color:#6b7280;min-width:200px;margin:0}.info-value{color:#1f2937;flex:1}.approvers-view-list{display:flex;flex-direction:column;gap:1rem}.approver-view-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.approver-view-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.approver-order{background:#667eea;color:#fff;font-weight:600;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem}.approver-type{color:#1f2937;font-weight:600;font-size:.9375rem}.approver-detail{color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.approver-detail:last-child{margin-bottom:0}.approver-detail strong{color:#374151;margin-right:.5rem}.approver-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:1rem}.approver-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.approver-number{background:#667eea;color:#fff;font-weight:600;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem}.btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;transition:transform .2s ease}.btn-icon:hover{transform:scale(1.1)}.btn-delete{color:#ef4444}.btn-delete:hover{color:#dc2626}.summary-section{margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.summary-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#1f2937}.summary-item{padding:.5rem 0;border-bottom:1px solid #e5e7eb}.summary-item:last-child{border-bottom:none}.summary-item strong{color:#6b7280;margin-right:.5rem}.department-badge{display:inline-block;background:#e0e7ff;color:#3730a3;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.approvers-summary{display:flex;flex-direction:column;gap:.75rem}.approver-summary-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px}.approver-summary-number{background:#667eea;color:#fff;font-weight:600;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;min-width:28px;text-align:center}.approver-summary-content{flex:1}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.dashboard-layout{min-height:100vh;background:#f9fafb}.dashboard-content{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.holiday-notification{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;padding:1.25rem 1.5rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;box-shadow:0 10px 25px #667eea4d;animation:slideDown .4s ease-out;position:relative;overflow:hidden}.holiday-notification:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shimmer 3s infinite}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.holiday-notification-icon{font-size:2.5rem;flex-shrink:0;z-index:1;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.holiday-notification-content{flex:1;z-index:1}.holiday-notification-title{font-size:1.25rem;font-weight:700;margin:0 0 .25rem;color:#fff}.holiday-notification-message{font-size:.9375rem;margin:0;color:#fffffff2;font-weight:500}.holiday-notification-close{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .2s;flex-shrink:0;z-index:1}.holiday-notification-close:hover{background:#ffffff4d;transform:scale(1.1)}.holiday-notification-close:active{transform:scale(.95)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.dashboard-title{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .5rem}.dashboard-subtitle{font-size:1rem;color:#6b7280;margin:0}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px #0000000d}.badge-icon{font-size:1.25rem}.badge-text{font-weight:600;color:#374151;font-size:.9375rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;transition:all .3s;border:1px solid #f3f4f6}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000001a}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-value{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .25rem}.stat-title{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .25rem}.stat-description{font-size:.875rem;color:#6b7280;margin:0}.dashboard-grid{display:grid;grid-template-columns:400px 1fr 400px;gap:1.5rem;margin-bottom:2rem}.dashboard-section{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #f3f4f6}.vacation-section{padding:0;background:transparent;box-shadow:none;border:none}.section-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 1.5rem}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.quick-action-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:.75rem}.quick-action-card:hover{background:#fff;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.action-icon{font-size:2rem;line-height:1}.action-content{display:flex;flex-direction:column;gap:.25rem}.action-title{font-size:.9375rem;font-weight:600;color:#111827;margin:0}.action-description{font-size:.8125rem;color:#6b7280;margin:0;line-height:1.4}.activity-list{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;gap:.75rem;padding:.875rem;background:#f9fafb;border-radius:8px;border-left:3px solid #9ca3af}.activity-item.info{border-left-color:#3b82f6;background:#eff6ff}.activity-item.success{border-left-color:#10b981;background:#f0fdf4}.activity-item.warning{border-left-color:#f59e0b;background:#fffbeb}.activity-indicator{width:8px;height:8px;border-radius:50%;background:currentColor;margin-top:.375rem;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-message{font-size:.875rem;color:#374151;margin:0 0 .25rem;font-weight:500}.activity-time{font-size:.75rem;color:#6b7280}.activity-empty{padding:1.5rem;text-align:center;color:#9ca3af;font-size:.875rem;border:2px dashed #e5e7eb;border-radius:8px}.alerts-section{margin-top:1.5rem}.alert{display:flex;gap:1rem;padding:1.25rem;border-radius:12px;border:1px solid}.alert-info{background:#eff6ff;border-color:#bfdbfe}.alert-icon{font-size:1.5rem;flex-shrink:0}.alert-content{flex:1}.alert-title{font-size:1rem;font-weight:600;color:#1e40af;margin:0 0 .5rem}.alert-message-text{font-size:.9375rem;color:#1e40af;margin:0;line-height:1.6}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr 400px}}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.dashboard-content{padding:1.5rem 1rem}.dashboard-header{flex-direction:column}.dashboard-title{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.quick-actions-grid{grid-template-columns:1fr}.stat-card{padding:1.25rem}.stat-icon{width:50px;height:50px;font-size:1.5rem}.stat-value{font-size:1.75rem}}.employees-layout{min-height:100vh;background:#f9fafb}.employees-container{display:flex;min-height:calc(100vh - 70px)}.show-items{color:#374151;font-size:.875rem;margin-right:.5rem}.employees-sidebar{width:280px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;transition:all .3s ease;position:sticky;top:70px;height:calc(100vh - 70px);overflow-y:auto}.employees-sidebar.collapsed{width:80px}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.sidebar-title{display:flex;align-items:center;gap:.75rem}.sidebar-icon{font-size:1.5rem}.sidebar-title h2{margin:0;font-size:1.125rem;font-weight:700;color:#111827}.sidebar-toggle{background:#f3f4f6;border:none;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#6b7280;transition:all .2s}.sidebar-toggle:hover{background:#e5e7eb;color:#111827}.sidebar-nav{flex:1;padding:1rem 0}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu li{margin-bottom:.25rem}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;text-decoration:none;color:#6b7280;border-left:3px solid transparent;transition:all .2s}.sidebar-link:hover{background:#f9fafb;color:#111827}.sidebar-link.active{background:#eff6ff;color:#2563eb;border-left-color:#2563eb;font-weight:600}.link-icon{font-size:1.25rem;flex-shrink:0}.link-content{display:flex;flex-direction:column;gap:.125rem}.link-name{font-size:.9375rem;font-weight:500}.link-description{font-size:.75rem;color:#9ca3af}.sidebar-footer{padding:1.25rem;border-top:1px solid #e5e7eb}.sidebar-info{background:#f9fafb;padding:1rem;border-radius:12px;display:flex;gap:.75rem}.info-icon{font-size:1.25rem;flex-shrink:0}.info-text{margin:0;font-size:.8125rem;color:#6b7280;line-height:1.5}.employees-sidebar.collapsed .sidebar-link{justify-content:center;padding:1rem}.employees-sidebar.collapsed .link-content{display:none}.submenu-toggle{width:100%;text-align:left;background:none;border:none;cursor:pointer;position:relative}.submenu-arrow{position:absolute;right:1.25rem;font-size:.75rem;color:#9ca3af;transition:transform .2s}.submenu-toggle.expanded .submenu-arrow{transform:rotate(0)}.submenu{list-style:none;padding:0;margin:0;background:#f9fafb}.submenu-link{padding-left:3.5rem!important;font-size:.875rem;border-left:3px solid transparent}.submenu-link:hover{background:#f3f4f6}.submenu-link.active{background:#dbeafe;color:#1d4ed8;border-left-color:#2563eb}.employees-sidebar.collapsed .submenu,.employees-sidebar.collapsed .submenu-arrow{display:none}.employees-main{flex:1;padding:2rem;margin-left:0;transition:margin-left .3s ease;max-width:1400px}.employees-main.sidebar-collapsed{margin-left:0}.dark-color{color:#19243d}.light-dark-color{color:#3e4147}.list-container{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:2rem}.list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.header-info{flex:1}.list-title{font-size:1.875rem;font-weight:700;color:#111827;margin:0 0 .5rem}.list-subtitle{font-size:1rem;color:#6b7280;margin:0}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:10px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn-secondary:hover{background:#e5e7eb}.btn-icon{font-size:1rem}.list-controls{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{flex:1;min-width:250px;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1rem;color:#9ca3af}.search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e5e7eb;border-radius:10px;font-size:.9375rem;transition:all .2s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-controls{display:flex;gap:.75rem}.filter-select{padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:10px;font-size:.9375rem;background:#fff;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#667eea}.table-container{overflow-x:auto;margin-bottom:1.5rem;border-radius:12px;border:1px solid #e5e7eb}.employees-table{width:100%;border-collapse:collapse}.employees-table thead{background:#f9fafb}.employees-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:#374151;border-bottom:2px solid #e5e7eb}.employees-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.employees-table th.sortable:hover{color:#667eea}.employees-table td{padding:1rem;border-bottom:1px solid #f3f4f6;font-size:.9375rem;color:#6b7280}.employees-table tbody tr:hover{background:#f9fafb}.employee-info{display:flex;align-items:center;gap:.75rem}.employee-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.employee-details{display:flex;flex-direction:column;gap:.125rem}.employee-name{font-weight:600;color:#111827}.employee-id{font-size:.8125rem;color:#9ca3af}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:999px;font-size:.8125rem;font-weight:600}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.status-badge.pending{background:#fef3c7;color:#92400e}.actions-column{width:140px}.actions-cell{text-align:center}.action-buttons{display:flex;gap:.5rem;justify-content:center}.btn-action{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s;background:#f3f4f6}.btn-action:hover{transform:translateY(-2px)}.btn-edit:hover{background:#dbeafe}.btn-transfer:hover{background:#e0e7ff}.btn-delete:hover{background:#fee2e2}.btn-approve{background:#d1fae5;color:#065f46}.btn-approve:hover{background:#a7f3d0;box-shadow:0 4px 6px #10b98133}.btn-approve:active{transform:translateY(0);background:#6ee7b7}.btn-reject{background:#fee2e2;color:#991b1b}.btn-reject:hover{background:#fecaca;box-shadow:0 4px 6px #ef444433}.btn-reject:active{transform:translateY(0);background:#fca5a5}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.pagination{display:flex;align-items:center;gap:.5rem}.pagination-btn{min-width:40px;height:40px;padding:0 .75rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-weight:500;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#667eea;color:#667eea}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;background:#f9fafb}.pagination-number{min-width:40px;height:40px;padding:0 .75rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-weight:500;font-size:.9375rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-number:hover{background:#f3f4f6;border-color:#667eea;color:#667eea}.pagination-number.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;font-weight:600}.pagination-ellipsis{padding:0 .5rem;color:#9ca3af;font-weight:500;-webkit-user-select:none;user-select:none}.pagination-info{font-size:.9375rem;color:#6b7280;font-weight:500}.loading-container,.error-container,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#374151}.loading-container p,.error-container p{color:#374151;font-size:1rem;font-weight:500;margin:.5rem 0}.spinner{width:48px;height:48px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon,.error-icon{font-size:4rem;margin-bottom:1rem;color:#9ca3af}.empty-state h3,.error-container p{margin:.5rem 0;color:#374151;font-size:1.25rem;font-weight:600}.empty-state p{color:#6b7280;margin-bottom:1.5rem}.grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .3s}.card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.card-header h3{margin:0;font-size:1.125rem;font-weight:700;color:#111827}.card-description{color:#6b7280;font-size:.9375rem;margin:0 0 1rem;line-height:1.5}.card-stats{margin-bottom:1rem;padding-top:1rem;border-top:1px solid #f3f4f6}.card-stats span{font-size:.875rem;color:#6b7280}.card-actions{display:flex;gap:.5rem;justify-content:flex-end}.alerts-container{margin-bottom:1rem}@media(max-width:1024px){.employees-sidebar{width:80px}.employees-sidebar .sidebar-title h2,.employees-sidebar .link-content,.employees-sidebar .sidebar-footer{display:none}.employees-sidebar .sidebar-link{justify-content:center;padding:1rem}}@media(max-width:768px){.employees-container{flex-direction:column}.employees-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid #e5e7eb}.employees-sidebar.collapsed{width:100%}.sidebar-nav{padding:.5rem 0}.sidebar-menu{display:flex;overflow-x:auto;gap:.5rem;padding:0 1rem}.sidebar-menu li{margin-bottom:0}.employees-main,.list-container{padding:1rem}.list-header{flex-direction:column}.table-container{overflow-x:scroll}.grid-container{grid-template-columns:1fr}}.table-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.view-controls{display:flex;align-items:center;gap:1rem}.view-toggle{display:flex;gap:.25rem;background:#f3f4f6;padding:.25rem;border-radius:8px}.view-btn{background:transparent;border:none;padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:1.25rem;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:36px}.view-btn:hover{color:#374151;background:#e5e7eb}.view-btn.active{background:#fff;color:#667eea;box-shadow:0 1px 3px #0000001a}.table-wrapper{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.data-table th.text-center{text-align:center}.data-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.data-table tbody tr:hover{background-color:#f9fafb}.data-table tbody tr:last-child{border-bottom:none}.data-table td{padding:1rem;color:#374151;font-size:.9375rem}.cell-name{font-weight:600;color:#111827}.cell-description{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-center{text-align:center}.cell-actions{display:flex;gap:.5rem;justify-content:center}@media(max-width:768px){.table-controls,.view-controls{flex-direction:column;align-items:stretch}.table-wrapper{overflow-x:auto}.data-table{min-width:600px}.pagination-container{flex-direction:column;gap:1rem;padding:1rem}.pagination-info{order:2;text-align:center;font-size:.875rem}.pagination{order:1;flex-wrap:wrap;justify-content:center}.pagination-number,.pagination-btn{min-width:36px;height:36px;font-size:.875rem}}@media(max-width:480px){.pagination-container{padding:.75rem}.pagination{gap:.25rem}.pagination-number,.pagination-btn{min-width:32px;height:32px;font-size:.8125rem;padding:0 .5rem}.pagination-info{font-size:.8125rem}}.confirm-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:confirmFadeIn .2s ease-out}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:480px;width:90%;padding:2rem;animation:confirmSlideUp .3s ease-out;position:relative}@keyframes confirmSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.warning-icon{width:64px;height:64px;color:#dc2626;background:linear-gradient(135deg,#fee2e2,#fecaca);border-radius:50%;padding:12px;animation:warningPulse 2s ease-in-out infinite}.success-icon{width:64px;height:64px;color:#16a34a;background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-radius:50%;padding:12px;animation:warningPulse 2s ease-in-out infinite}.info-icon{width:64px;height:64px;color:#2563eb;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:50%;padding:12px;animation:warningPulse 2s ease-in-out infinite}@keyframes warningPulse{0%,to{transform:scale(1);box-shadow:0 0 #dc262666}50%{transform:scale(1.05);box-shadow:0 0 0 10px #dc262600}}.confirm-modal-content{text-align:center;margin-bottom:2rem}.confirm-modal-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 1rem}.confirm-modal-message{font-size:1rem;color:#374151;margin:0 0 .75rem;line-height:1.6}.confirm-modal-warning{font-size:.875rem;color:#dc2626;font-weight:600;margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.confirm-modal-warning:before{content:"⚠️";font-size:1rem}.confirm-modal-actions{display:flex;gap:1rem;justify-content:center}.confirm-btn{flex:1;padding:.875rem 1.5rem;border:none;border-radius:10px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;max-width:180px}.confirm-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-btn-cancel{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.confirm-btn-cancel:hover:not(:disabled){background:#e5e7eb;transform:translateY(-1px)}.confirm-btn-cancel:active:not(:disabled){transform:translateY(0)}.confirm-btn-delete{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 4px 12px #dc26264d}.confirm-btn-delete:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #dc262666}.confirm-btn-delete:active:not(:disabled){transform:translateY(0)}.confirm-btn-success{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;box-shadow:0 4px 12px #16a34a4d}.confirm-btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #16a34a66}.confirm-btn-success:active:not(:disabled){transform:translateY(0)}.confirm-btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 12px #f59e0b4d}.confirm-btn-warning:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f59e0b66}.confirm-btn-warning:active:not(:disabled){transform:translateY(0)}.confirm-btn-info{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 12px #2563eb4d}.confirm-btn-info:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.confirm-btn-info:active:not(:disabled){transform:translateY(0)}.confirm-btn-icon{width:18px;height:18px}.confirm-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:confirmSpin .6s linear infinite}@keyframes confirmSpin{to{transform:rotate(360deg)}}@media(max-width:640px){.confirm-modal-container{padding:1.5rem;max-width:95%}.confirm-modal-title{font-size:1.25rem}.confirm-modal-message{font-size:.9375rem}.confirm-modal-actions{flex-direction:column}.confirm-btn{max-width:100%}.warning-icon{width:56px;height:56px}}.total-terminals{font-size:1rem;color:#6b7280;margin-bottom:1rem}#root{width:100%}
