@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:1000px}.hero h1{margin:8px 0 10px;font-size:clamp(28px,4vw,44px);letter-spacing:-.02em}.hero p{color:var(--muted);max-width:1000px}.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}.logo-image{width:40%;height:auto;display:block;margin:0 auto}.logo-image-navbar{width:12%;height:auto;display:block;margin:0}.logo-image-registerPage{width:25%;height:auto;display:block;margin:0}.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}}.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}}.dash-section{margin-bottom:1.75rem}.dash-error-banner{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:10px;padding:.875rem 1.25rem;font-size:.9rem;margin-bottom:1.25rem}.dash-status-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:.75rem 1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f;flex-wrap:wrap}.dash-status-bar--holiday{background:linear-gradient(135deg,#fef3c7,#fffbeb);border-color:#fbbf24}.dash-status-bar__left{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.dash-status-bar__date{font-size:.9rem;font-weight:600;color:#374151;text-transform:capitalize}.dash-status-bar__holiday-tag{background:#fef3c7;color:#92400e;border:1px solid #fbbf24;font-size:.78rem;font-weight:700;padding:.2rem .65rem;border-radius:999px}.dash-status-bar__right{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.dash-status-bar__cache-tag{background:#ede9fe;color:#5b21b6;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;border:1px solid #c4b5fd}.dash-status-bar__updated{font-size:.8rem;color:#6b7280}.dash-status-bar__refresh{display:flex;align-items:center;gap:.35rem;background:#6366f1;color:#fff;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s;min-width:110px;justify-content:center}.dash-status-bar__refresh:hover:not(:disabled){background:#4f46e5}.dash-status-bar__refresh:active:not(:disabled){transform:scale(.96)}.dash-status-bar__refresh:disabled{opacity:.7;cursor:not-allowed}.dash-status-bar__spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin .7s linear infinite}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem}.kpi-card{background:#fff;border-radius:14px;padding:1.25rem 1rem;box-shadow:0 1px 4px #00000012;border:1px solid #f1f5f9;display:flex;flex-direction:column;gap:.75rem;transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.kpi-card__icon{width:44px;height:44px;border-radius:10px;background:var(--kpi-bg);color:var(--kpi-color);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.kpi-card__body{display:flex;flex-direction:column;gap:.15rem}.kpi-card__value{font-size:2rem;font-weight:800;color:#111827;line-height:1.1;min-height:2.5rem;display:flex;align-items:center}.kpi-card__label{font-size:.875rem;font-weight:700;color:var(--kpi-color)}.kpi-card__desc{font-size:.75rem;color:#9ca3af;line-height:1.4}.kpi-card__skeleton{display:inline-block;width:60px;height:2rem;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:6px;animation:skeleton-pulse 1.4s ease infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.dash-charts-row{display:grid;grid-template-columns:1fr 360px;gap:1.25rem;align-items:start}.dash-charts-row__donut,.dash-charts-row__vacation{min-width:0}.chart-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 4px #00000012;border:1px solid #f1f5f9}.chart-card--full{width:100%}.chart-card__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.chart-card__title{font-size:1rem;font-weight:700;color:#111827;margin:0 0 .5rem}.chart-card__rates{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.chart-card__skeleton{height:260px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;border-radius:10px;animation:skeleton-pulse 1.4s ease infinite}.chart-empty{height:200px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.9rem}.rate-badge{font-size:.78rem;font-weight:700;padding:.2rem .65rem;border-radius:999px}.rate-badge--green{background:#ecfdf5;color:#065f46;border:1px solid #6ee7b7}.rate-badge--red{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5}.donut-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.5rem .75rem;font-size:.85rem;color:#374151;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:.5rem}.donut-tooltip__dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.donut-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem}.donut-header .chart-card__title{margin-bottom:0}.donut-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f1f5f9}.donut-legend__item{display:flex;align-items:center;gap:.35rem;font-size:.76rem;color:#374151;white-space:nowrap}.donut-legend__dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.donut-legend__label{color:#6b7280}.donut-legend__val{font-weight:700;color:#111827}.chart-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:2px;gap:2px}.chart-toggle__btn{background:transparent;border:none;border-radius:6px;padding:.3rem .75rem;font-size:.8rem;font-weight:600;color:#64748b;cursor:pointer;transition:background .15s,color .15s}.chart-toggle__btn--active{background:#fff;color:#6366f1;box-shadow:0 1px 3px #0000001f}.bar-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:.75rem 1rem;font-size:.82rem;color:#374151;box-shadow:0 4px 12px #0000001a;min-width:160px}.bar-tooltip__title{font-weight:700;color:#111827;margin:0 0 .5rem;font-size:.85rem}.bar-tooltip__row{display:flex;align-items:center;gap:.45rem;padding:.15rem 0}.bar-tooltip__dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}.realtime-feed{background:#fff;border-radius:16px;box-shadow:0 1px 4px #00000012;border:1px solid #f1f5f9;overflow:hidden}.realtime-feed__header{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #f1f5f9}.realtime-feed__title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.4rem}.realtime-feed__title{font-size:1rem;font-weight:700;color:#111827;margin:0}.feed-new-badge{background:#ecfdf5;color:#065f46;border:1px solid #6ee7b7;font-size:.75rem;font-weight:700;padding:.2rem .6rem;border-radius:999px;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.realtime-feed__meta{display:flex;align-items:center;gap:1rem;font-size:.8rem;color:#6b7280;flex-wrap:wrap}.realtime-feed__count{font-weight:600;color:#374151}.realtime-feed__updated{color:#9ca3af}.realtime-feed__pulse{width:8px;height:8px;border-radius:50%;background:#10b981;display:inline-block;position:relative}.realtime-feed__pulse:after{content:"";position:absolute;inset:-3px;border-radius:50%;background:#10b981;opacity:.35;animation:pulse-ring 1.8s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.6}to{transform:scale(2.2);opacity:0}}.realtime-feed__table-wrapper{overflow-x:auto}.realtime-feed__loading{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.feed-skeleton-row{height:42px;background:linear-gradient(90deg,#f8fafc 25%,#f1f5f9,#f8fafc 75%);background-size:200% 100%;border-radius:8px;animation:skeleton-pulse 1.4s ease infinite}.realtime-feed__empty{padding:3rem;text-align:center;color:#9ca3af;font-size:.9rem}.feed-table{width:100%;border-collapse:collapse;font-size:.85rem}.feed-table thead tr{background:#f8fafc}.feed-table th{padding:.7rem 1rem;text-align:left;font-weight:700;color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-bottom:1px solid #f1f5f9}.feed-table td{padding:.7rem 1rem;vertical-align:middle;border-bottom:1px solid #f8fafc;color:#374151}.feed-table tbody tr:last-child td{border-bottom:none}.feed-table tbody tr:hover td{background:#f8fafc}.feed-table__row--new td{animation:rowFlash 2.5s ease}@keyframes rowFlash{0%{background:#ecfdf5}60%{background:#ecfdf5}to{background:transparent}}.feed-table__time{font-variant-numeric:tabular-nums;font-weight:600;color:#111827;white-space:nowrap}.feed-table__hide-sm,.feed-table__hide-md{display:table-cell}.feed-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;font-size:.78rem;font-weight:700;white-space:nowrap}.feed-badge__icon{font-style:normal;font-size:.85rem}.feed-late-badge{background:#fef2f2;color:#b91c1c;border:1px solid #fca5a5;font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:999px}.feed-employee{display:flex;flex-direction:column;gap:.1rem}.feed-employee__name{font-weight:600;color:#111827}.feed-employee__pin{font-size:.72rem;color:#9ca3af}.feed-source{display:flex;align-items:center;gap:.4rem;font-size:.8rem}.feed-source__name{color:#6b7280}.feed-null{color:#d1d5db}@media(max-width:1100px){.dash-charts-row{grid-template-columns:1fr}}@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:640px){.dash-status-bar{flex-direction:column;align-items:flex-start}.kpi-grid{grid-template-columns:repeat(2,1fr)}.feed-table__hide-sm,.feed-table__hide-md{display:none}.realtime-feed__header{padding:1rem}.feed-table th,.feed-table td{padding:.6rem .75rem}.chart-card{padding:1rem}}.dash-app{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column}.dash-main{flex:1;max-width:1440px;width:100%;margin:0 auto;padding:1.5rem 2rem 3rem}.dash-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.dash-page-header__left{display:flex;flex-direction:column;gap:.3rem}.dash-page-header__right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.dash-page-title{font-size:1.65rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.02em}.dash-page-date{font-size:.85rem;color:#64748b;margin:0;display:flex;align-items:center;gap:.5rem;text-transform:capitalize}.dash-holiday-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;background:#fef3c7;color:#92400e;border-radius:999px;font-size:.75rem;font-weight:600;border:1px solid #fde68a}.dash-cache-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;background:#f5f3ff;color:#6d28d9;border-radius:999px;font-size:.75rem;font-weight:500;border:1px solid #ede9fe;cursor:default}.dash-updated-text{font-size:.75rem;color:#94a3b8;font-variant-numeric:tabular-nums}.dash-refresh-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;min-width:120px;justify-content:center;height:36px}.dash-refresh-btn:hover:not(:disabled){background:#4f46e5}.dash-refresh-btn:active:not(:disabled){transform:scale(.97)}.dash-refresh-btn:disabled{opacity:.65;cursor:not-allowed}.dash-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dash-user-chip{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:.3rem .75rem .3rem .3rem;box-shadow:0 1px 3px #0000000f}.dash-user-chip__avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-user-chip__name{font-size:.82rem;font-weight:600;color:#334155;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.dash-error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:10px;padding:.75rem 1rem;font-size:.85rem;margin-bottom:1rem}.kpi-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:.85rem;margin-bottom:1.25rem}.kpi-chip{display:flex;align-items:center;gap:.75rem;background:#fff;border-radius:12px;padding:.9rem 1rem;border:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000a;transition:box-shadow .2s,transform .15s;cursor:default}.kpi-chip:hover{box-shadow:0 4px 14px #00000014;transform:translateY(-2px)}.kpi-chip__icon{width:40px;height:40px;border-radius:10px;background:var(--kb);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.kpi-chip--accent .kpi-chip__icon{background:var(--kc);filter:drop-shadow(0 0 4px var(--kc))}.kpi-chip__body{display:flex;flex-direction:column;gap:.1rem;min-width:0}.kpi-chip__value{font-size:1.45rem;font-weight:800;color:var(--kc);line-height:1;letter-spacing:-.03em}.kpi-chip--accent .kpi-chip__value{color:var(--kc)}.kpi-chip__label{font-size:.73rem;color:#64748b;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi-chip__skel{display:inline-block;width:36px;height:1.35rem;border-radius:6px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:shimmer-kpi 1.3s infinite}@keyframes shimmer-kpi{0%{background-position:200% center}to{background-position:-200% center}}.dash-grid{display:grid;grid-template-columns:1fr 360px;gap:1.25rem;margin-bottom:1.25rem;align-items:start}.dash-grid__main{min-width:0}.dash-grid__side{display:flex;flex-direction:column;gap:1.25rem}.dash-section-title{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.dash-qa-section{margin-top:1.25rem}.dash-qa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.dash-qa-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:14px;cursor:pointer;transition:box-shadow .2s,transform .15s,border-color .2s;text-align:center}.dash-qa-card:hover{box-shadow:0 6px 20px #6366f11f;transform:translateY(-3px);border-color:#c7d2fe}.dash-qa-card__icon{font-size:1.75rem;line-height:1}.dash-qa-card__title{font-size:.88rem;font-weight:700;color:#1e293b}.dash-qa-card__desc{font-size:.75rem;color:#94a3b8}.dash-bottom-grid{margin-top:1.25rem}.dash-quick-actions .dash-section-title{margin-bottom:1rem}@media(max-width:1200px){.kpi-strip{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.dash-grid{grid-template-columns:1fr}.dash-grid__side{display:grid;grid-template-columns:1fr 1fr}}@media(max-width:768px){.dash-main{padding:1rem 1rem 2rem}.kpi-strip{grid-template-columns:repeat(2,1fr)}.dash-grid__side{grid-template-columns:1fr}.dash-qa-grid{grid-template-columns:repeat(2,1fr)}.dash-page-header{flex-direction:column;gap:.75rem}.dash-page-header__right{width:100%;justify-content:flex-start}}@media(max-width:480px){.kpi-strip{grid-template-columns:1fr 1fr}.kpi-chip__value{font-size:1.2rem}}.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}.advanced-filters{margin-bottom:1.5rem;padding:1.25rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px}.filters-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.filter-field{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:180px}.filter-field label{font-size:.875rem;font-weight:500;color:#374151}.filter-input{padding:.75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.9375rem;background:#fff;transition:all .2s}.filter-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-actions{display:flex;gap:.75rem;align-items:flex-end}.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:center;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;text-align:center}.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.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}}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:500;text-align:center}.badge-Punch{background:#dbeafe;color:#1e40af}.badge-Manual{background:#fef3c7;color:#92400e}.badge-check-in{background:#dcfce7;color:#166534}.badge-check-out{background:#fee2e2;color:#991b1b}.badge-break-start{background:#fef3c7;color:#92400e}.badge-break-end{background:#dbeafe;color:#1e40af}.text-small{font-size:.75rem;color:#64748b;font-family:monospace}.font-semibold{font-weight:600;color:#1e293b}@media print{@page{margin:1.5cm;size:A4 landscape}.employees-sidebar,.sidebar,nav,header,.navbar,.navigation{display:none!important}.list-container>*:not(.print-header):not(.table-container){display:none!important}.print-header{display:block!important}.list-container{padding:0!important;margin:0!important;background:#fff!important}.table-container{max-height:none!important;overflow:visible!important;border:none!important;box-shadow:none!important}.employees-table{width:100%;border-collapse:collapse;page-break-inside:auto;font-size:9pt}.employees-table thead{display:table-header-group;background:#f5f5f5!important}.employees-table th{padding:8px 6px;font-size:9pt;font-weight:700;border:1px solid #333;background:#e0e0e0!important;color:#000!important;text-align:center;-webkit-print-color-adjust:exact;print-color-adjust:exact}.employees-table td{padding:6px 4px;font-size:8pt;border:1px solid #666;color:#000!important;text-align:center;background:#fff!important}.employees-table tbody tr{page-break-inside:avoid;page-break-after:auto}.employees-table tbody tr:nth-child(2n){background:#f9f9f9!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.badge{padding:2px 6px;font-size:8pt;font-weight:400;border-radius:3px;color:#000!important;background:#e0e0e0!important;border:1px solid #999;display:inline-block}.employees-table th.sortable,.employees-table tbody tr:hover{cursor:default;background:inherit!important}body,.employees-table,.employees-table th,.employees-table td{font-family:Arial,Helvetica,sans-serif!important;color:#000!important}.font-semibold{font-weight:700;color:#000!important}.text-small{font-size:7pt;color:#000!important}.list-container:before{display:none!important}}.employee-checkbox-container{scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.employee-checkbox-container::-webkit-scrollbar{width:8px}.employee-checkbox-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.employee-checkbox-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.employee-checkbox-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.badge-consumption-fully_consumed{background-color:#28a745;color:#fff}.badge-consumption-partially_consumed{background-color:#ffc107;color:#333}.badge-consumption-not_consumed{background-color:#dc3545;color:#fff}.badge-consumption-exceeded{background-color:#fd7e14;color:#fff}.badge-consumption-no_attendance_data{background-color:#6c757d;color:#fff}.badge-consumption-pending{background-color:#17a2b8;color:#fff}.warnings-list{display:flex;flex-direction:column;gap:3px;font-size:.85em}.warning-item{white-space:nowrap}.warning-more{color:#6c757d;font-style:italic;margin-top:2px;font-size:.9em}.no-warnings{color:#6c757d;font-style:italic;font-size:.9em}.modal-section.consumption-section{background-color:#f0f8ff;border-left:4px solid #17a2b8;padding:20px;margin:15px 0;border-radius:8px}.consumption-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.consumption-status-large{text-align:center;margin-bottom:20px}.consumption-status-large .badge{font-size:1.2em;padding:10px 20px}.consumption-metrics{display:flex;justify-content:space-around;margin:20px 0;flex-wrap:wrap;gap:20px}.metric{text-align:center;min-width:120px}.metric-value{display:block;font-size:2em;font-weight:700;color:#333;margin-bottom:5px}.metric-label{display:block;font-size:.9em;color:#6c757d}.metric-warning .metric-value{color:#fd7e14}.attendance-times{margin-top:15px;padding-top:15px;border-top:1px solid #dee2e6;display:flex;justify-content:space-around;flex-wrap:wrap;gap:10px}.no-attendance-warning{margin-top:15px;padding:10px;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;text-align:center;color:#856404}.modal-section.warnings-section{background-color:#fff3cd;border-left:4px solid #ffc107;padding:20px;margin:15px 0;border-radius:8px}.warnings-list-modal{display:flex;flex-direction:column;gap:10px}.warning-item-modal{padding:12px;border-radius:4px;border-left:4px solid;display:flex;flex-direction:column;gap:5px}.warning-item-modal strong{font-weight:600}.warning-item-modal.warning-error{background-color:#f8d7da;border-left-color:#dc3545;color:#721c24}.warning-item-modal.warning-success{background-color:#d4edda;border-left-color:#28a745;color:#155724}.approval-table{width:100%;font-size:.9em;border-collapse:collapse}.approval-table th{background-color:#f8f9fa;padding:10px;text-align:left;border-bottom:2px solid #dee2e6}.approval-table td{padding:8px;border-bottom:1px solid #dee2e6}.approval-row.approval-approved{background-color:#d4edda}.approval-row.approval-rejected{background-color:#f8d7da}.approval-row.approval-pending{background-color:#fff3cd}.approval-row.approval-waiting{background-color:#f8f9fa}.no-approvals{text-align:center;color:#6c757d;font-style:italic;padding:20px}.actions-container{display:flex;gap:10px;margin-bottom:15px}.btn-export,.btn-print{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .2s;font-weight:500}.btn-export{background-color:#28a745;color:#fff}.btn-export:hover{background-color:#218838}.btn-print{background-color:#17a2b8;color:#fff}.btn-print:hover{background-color:#138496}.modal-large{max-width:900px;max-height:90vh;overflow-y:auto}@media print{.print-header{display:block!important;text-align:center;margin-bottom:30px;page-break-after:avoid;border-bottom:2px solid #333;padding-bottom:15px}.print-company-info h1{margin:0;font-size:24pt;color:#000}.print-company-info p{margin:5px 0;font-size:10pt}.print-report-info h2{margin:15px 0 5px;font-size:18pt;color:#333}.print-report-info p{margin:3px 0;font-size:10pt}.employees-table{font-size:8pt}.employees-table th,.employees-table td{padding:4px}.badge{border:1px solid #333;padding:2px 4px}.warnings-list{font-size:7pt}}@media screen{.print-header{display:none}}.ci-profile{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f0f4ff,#faf5ff);border:1px solid #e5e7eb;border-radius:14px;margin-bottom:1.75rem}.ci-avatar{width:80px;height:80px;border-radius:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;overflow:hidden;box-shadow:0 4px 12px #667eea4d}.ci-avatar-img{width:100%;height:100%;object-fit:contain;border-radius:14px}.ci-profile-info{display:flex;flex-direction:column;gap:.625rem}.ci-company-name{font-size:1.5rem;font-weight:700;color:#111827;margin:0}.ci-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ci-code-badge{display:inline-block;padding:.3rem .75rem;border-radius:999px;font-size:.8125rem;font-weight:600;background:#e0e7ff;color:#3730a3}.ci-code-badge--secondary{background:#f3f4f6;color:#374151}.ci-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.ci-section{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.ci-section-header{display:flex;align-items:center;gap:.625rem;padding:.875rem 1.25rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.ci-section-header span{font-size:1.1rem}.ci-section-header h3{margin:0;font-size:.9375rem;font-weight:600;color:#374151}.ci-logo-body{display:flex;gap:1.25rem;padding:1.25rem;flex-wrap:wrap}.ci-logo-preview{width:130px;height:130px;flex-shrink:0;border:1.5px dashed #d1d5db;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#f9fafb;overflow:hidden}.ci-logo-img{width:100%;height:100%;object-fit:contain;border-radius:12px}.ci-logo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.375rem;color:#9ca3af}.ci-logo-placeholder span{font-size:1.75rem}.ci-logo-placeholder p{margin:0;font-size:.75rem;text-align:center}.ci-logo-form{flex:1;min-width:180px;display:flex;flex-direction:column;gap:.25rem}.ci-logo-label{font-size:.875rem;font-weight:600;color:#374151}.ci-logo-input{width:100%;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:10px;font-size:.9375rem;box-sizing:border-box;transition:all .2s;color:#111827}.ci-logo-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.ci-logo-actions{display:flex;gap:.75rem;margin-top:.75rem;flex-wrap:wrap}.ci-footer{display:flex;align-items:center;gap:.5rem;padding-top:1rem;border-top:1px solid #f3f4f6;margin-top:.25rem}.ci-footer-label{color:#9ca3af;font-size:.8125rem}.ci-footer-code{font-family:Courier New,monospace;font-size:.8125rem;background:#f3f4f6;padding:.25rem .625rem;border-radius:6px;color:#374151}@media(max-width:768px){.ci-grid{grid-template-columns:1fr}.ci-profile{flex-direction:column;align-items:flex-start}}.ci-edit-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9375rem;color:#111827;background:#fff;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.ci-edit-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.ci-toggle{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.ci-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#667eea;cursor:pointer}.ci-toggle-label{font-size:.9rem;color:#374151;font-weight:500}.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}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.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%}
