@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#060918;--bg-surface:#0c1425;--bg-surface-2:#111d35;--glass-bg:#0f1628bf;--glass-bg-2:#141f3899;--glass-border:#94a3b81a;--glass-border-hover:#94a3b838;--primary:#6366f1;--primary-light:#818cf8;--primary-dark:#4f46e5;--secondary:#8b5cf6;--accent:#06b6d4;--gradient-primary:linear-gradient(135deg,#6366f1,#8b5cf6);--gradient-accent:linear-gradient(135deg,#06b6d4,#6366f1);--gradient-success:linear-gradient(135deg,#10b981,#059669);--gradient-danger:linear-gradient(135deg,#ef4444,#dc2626);--gradient-warning:linear-gradient(135deg,#f59e0b,#d97706);--gradient-info:linear-gradient(135deg,#3b82f6,#2563eb);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#10b981;--success-bg:#10b9811a;--success-border:#10b98140;--warning:#f59e0b;--warning-bg:#f59e0b1a;--warning-border:#f59e0b40;--error:#ef4444;--error-bg:#ef44441a;--error-border:#ef444440;--info:#3b82f6;--info-bg:#3b82f61a;--info-border:#3b82f640;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 24px #00000073;--shadow-lg:0 10px 48px #0000008c;--shadow-glow:0 0 40px #6366f140;--transition:.2s cubic-bezier(.4,0,.2,1);--sidebar-width:220px;--navbar-height:60px}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 70% at 50% -10%,#6366f12e,#0000),radial-gradient(50% 50% at 85%,#8b5cf61a,#0000),radial-gradient(40% 60% at 5% 80%,#06b6d412,#0000);position:fixed;inset:0}body>*{z-index:1;position:relative}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--glass-border-hover);border-radius:3px}::selection{background:#6366f159}h1{font-size:2rem;font-weight:700;line-height:1.2}h2{font-size:1.5rem;font-weight:600;line-height:1.3}h3{font-size:1.2rem;font-weight:600;line-height:1.4}h4{font-size:1rem;font-weight:600}.gradient-text{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:border-color var(--transition)}.glass:hover{border-color:var(--glass-border-hover)}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);max-width:var(--sidebar-width);z-index:50;box-sizing:border-box;flex-shrink:0;height:100vh;position:fixed;top:0;left:0;overflow-y:auto}.main-area{margin-left:var(--sidebar-width);min-width:0;min-height:100vh;width:calc(100% - var(--sidebar-width));flex-direction:column;flex:1;display:flex}.navbar{height:var(--navbar-height);z-index:40;position:sticky;top:0}.page-content{flex:1;padding:1.5rem 2rem;overflow-y:auto}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{width:100%;max-width:440px;padding:2.5rem}.auth-logo{justify-content:center;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.auth-logo-icon{background:var(--gradient-primary);border-radius:var(--radius-md);width:48px;height:48px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;font-size:1.5rem;display:flex}.auth-title{text-align:center;margin-bottom:.5rem}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 16px #6366f159}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #6366f180}.btn-secondary{background:var(--glass-bg-2);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface-2);border-color:var(--glass-border-hover)}.btn-danger{background:var(--gradient-danger);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #ef444466}.btn-success{background:var(--gradient-success);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #10b98166}.btn-warning{background:var(--gradient-warning);color:#fff}.btn-warning:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #f59e0b66}.btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--glass-bg);color:var(--text-primary);border-color:var(--glass-border)}.btn-sm{padding:.375rem .875rem;font-size:.8rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-sm);padding:.5rem}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.02em;font-size:.8rem;font-weight:500}.form-input{border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition);background:#0f172a99;outline:none;padding:.625rem 1rem;font-family:inherit;font-size:.9rem}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-input::-webkit-calendar-picker-indicator{filter:invert();opacity:.7;cursor:pointer}.form-input::-webkit-calendar-picker-indicator:hover{opacity:1}.form-select{border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);cursor:pointer;transition:all var(--transition);appearance:none;background:#0f172a99 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E") right .75rem center/1rem no-repeat;outline:none;padding:.625rem 2.5rem .625rem 1rem;font-family:inherit;font-size:.9rem}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-select option{color:var(--text-primary);background:#0c1425}.form-textarea{border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);resize:vertical;min-height:80px;transition:all var(--transition);background:#0f172a99;outline:none;padding:.625rem 1rem;font-family:inherit;font-size:.9rem}.form-textarea::placeholder{color:var(--text-muted)}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-error{color:var(--error);font-size:.75rem}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:1rem;display:grid}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:all var(--transition);padding:1.5rem}.card:hover{border-color:var(--glass-border-hover);box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.card-title{color:var(--text-primary);font-size:1rem;font-weight:600}.card-subtitle{color:var(--text-secondary);margin-top:.15rem;font-size:.8rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;display:grid}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);transition:all var(--transition);padding:1.25rem 1.5rem;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg)var(--radius-lg)0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.primary:before{background:var(--gradient-primary)}.stat-card.success:before{background:var(--gradient-success)}.stat-card.warning:before{background:var(--gradient-warning)}.stat-card.info:before{background:var(--gradient-info)}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--glass-border-hover);transform:translateY(-2px)}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.75rem;font-weight:500}.stat-value{color:var(--text-primary);font-size:1.75rem;font-weight:700;line-height:1}.stat-sub{color:var(--text-muted);margin-top:.35rem;font-size:.75rem}.stat-icon{opacity:.25;font-size:1.75rem;position:absolute;top:1rem;right:1rem}.table-container{border-radius:var(--radius-md);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--glass-border);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{vertical-align:middle;border-bottom:1px solid #94a3b80f;padding:.875rem 1rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#6366f10a}.table-actions{align-items:center;gap:.5rem;display:flex}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-draft{color:#94a3b8;background:#64748b33;border:1px solid #64748b4d}.badge-submitted{background:var(--info-bg);color:#60a5fa;border:1px solid var(--info-border)}.badge-approved{background:var(--success-bg);color:#34d399;border:1px solid var(--success-border)}.badge-rejected{background:var(--error-bg);color:#f87171;border:1px solid var(--error-border)}.badge-admin{color:#a78bfa;background:#8b5cf626;border:1px solid #8b5cf640}.badge-employee{color:#818cf8;background:#6366f11a;border:1px solid #6366f133}.badge-active{background:var(--success-bg);color:#34d399;border:1px solid var(--success-border)}.badge-inactive{background:var(--error-bg);color:#f87171;border:1px solid var(--error-border)}.badge-regular{color:#818cf8;background:#6366f11a;border:1px solid #6366f133}.badge-overtime{color:#fbbf24;background:#f59e0b1a;border:1px solid #f59e0b40}.badge-sick{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.badge-vacation{color:#22d3ee;background:#06b6d41a;border:1px solid #06b6d433}.badge-holiday{color:#34d399;background:#10b9811a;border:1px solid #10b98133}.badge-training{color:#a78bfa;background:#8b5cf61a;border:1px solid #8b5cf633}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#060918d9;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--glass-border-hover);border-radius:var(--radius-xl);width:100%;max-width:560px;box-shadow:var(--shadow-lg),var(--shadow-glow);background:#0d1526;max-height:90vh;padding:2rem;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-size:1.15rem;font-weight:600}.modal-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;padding:.25rem;font-size:1.25rem}.modal-close:hover{color:var(--text-primary);background:var(--glass-bg)}.modal-footer{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.sidebar-inner{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border-right:1px solid var(--glass-border);box-sizing:border-box;flex-direction:column;width:100%;height:100%;padding:1rem .75rem;display:flex}.sidebar-logo{align-items:center;gap:.75rem;padding:.5rem .75rem 1.5rem;display:flex}.sidebar-logo-icon{background:var(--gradient-primary);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex;box-shadow:0 0 20px #6366f14d}.sidebar-logo-text{color:var(--text-primary);font-size:1rem;font-weight:700}.sidebar-logo-sub{color:var(--text-secondary);font-size:.65rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.sidebar-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.75rem .75rem .25rem;font-size:.65rem;font-weight:600}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.6rem .875rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--glass-bg-2);color:var(--text-primary)}.nav-item.active{color:var(--primary-light);background:#6366f126;border:1px solid #6366f133}.nav-item.active .nav-icon{color:var(--primary-light)}.nav-icon{text-align:center;flex-shrink:0;width:1.25rem;font-size:1.1rem}.sidebar-footer{border-top:1px solid var(--glass-border);padding-top:1rem}.sidebar-user{border-radius:var(--radius-md);align-items:center;gap:.75rem;padding:.75rem;display:flex}.sidebar-avatar{background:var(--gradient-primary);border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.8rem;font-weight:700;display:flex}.sidebar-user-name{color:var(--text-primary);font-size:.82rem;font-weight:600}.sidebar-user-role{color:var(--text-secondary);font-size:.7rem}.navbar-inner{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;gap:1rem;height:100%;padding:0 1.5rem;display:flex}.navbar-title{color:var(--text-primary);font-size:1.1rem;font-weight:600}.navbar-right{align-items:center;gap:.75rem;display:flex}.lang-switcher{background:var(--glass-bg-2);border:1px solid var(--glass-border);border-radius:var(--radius-full);gap:.1rem;padding:.2rem;display:flex}.lang-btn{border-radius:var(--radius-full);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);background:0 0;border:none;padding:.25rem .75rem;font-family:inherit;font-size:.75rem;font-weight:600}.lang-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #6366f166}.page-header{margin-bottom:2rem}.page-title{margin-bottom:.25rem;font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.9rem}.loading-overlay{min-height:200px;color:var(--text-secondary);justify-content:center;align-items:center;gap:.75rem;display:flex}.skeleton{background:linear-gradient(90deg,var(--bg-surface)25%,var(--bg-surface-2)50%,var(--bg-surface)75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.alert{border-radius:var(--radius-md);align-items:center;gap:.75rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.alert-error{background:var(--error-bg);border:1px solid var(--error-border);color:#f87171}.alert-success{background:var(--success-bg);border:1px solid var(--success-border);color:#34d399}.alert-info{background:var(--info-bg);border:1px solid var(--info-border);color:#60a5fa}.alert-warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:#fbbf24}.empty-state{text-align:center;padding:3rem 2rem}.empty-icon{opacity:.4;margin-bottom:1rem;font-size:3rem}.empty-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.empty-text{color:var(--text-secondary);font-size:.875rem}.confirm-body{text-align:center;padding:.75rem 0}.confirm-icon{margin-bottom:1rem;font-size:3rem}.confirm-message{color:var(--text-secondary);font-size:.9rem}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#94a3b814}.recharts-text{fill:var(--text-secondary)!important;font-family:Inter,sans-serif!important;font-size:11px!important}.recharts-tooltip-wrapper{outline:none}.custom-tooltip{border:1px solid var(--glass-border-hover);border-radius:var(--radius-md);background:#0d1526;padding:.75rem 1rem}.custom-tooltip .label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.75rem}.custom-tooltip .value{color:var(--text-primary);font-size:1rem;font-weight:700}.loading-overlay{justify-content:center;align-items:center;width:100%;height:100%;padding:3rem;display:flex}.spinner{border:3px solid #6366f133;border-top-color:var(--primary);border-radius:50%;width:2rem;height:2rem;animation:1s linear infinite spin}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fadeIn{animation:.3s forwards fadeIn}@media (max-width:768px){:root{--sidebar-width:0px}.sidebar{width:240px;transition:transform var(--transition);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-area{margin-left:0}.page-content{padding:1rem}.form-grid,.form-grid-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}}.page-wrapper{flex-direction:column;flex:1;min-width:0;display:flex}.toast-container{z-index:9999;flex-direction:column;gap:12px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);min-width:250px;max-width:400px;box-shadow:var(--shadow-xl);color:var(--text-primary);align-items:center;gap:12px;padding:14px 20px;font-size:.95rem;font-weight:500;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp;display:flex}.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--danger)}.toast-info{border-left:4px solid var(--primary)}
