@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.auth-container{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:Inter,sans-serif;overflow:hidden;background:#f0f2f8}.auth-bg{position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse 60% 50% at 10% 20%,rgba(79,57,246,.06) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 90% 80%,rgba(124,58,237,.05) 0%,transparent 70%),#eef0f8;pointer-events:none}.auth-widget{position:absolute;background:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 2px 8px #0000000f,0 8px 24px #0000000d;border:1px solid rgba(226,232,240,.8);z-index:1;-webkit-user-select:none;user-select:none;pointer-events:none}@media(max-width:1100px){.auth-widget{display:none}}@keyframes auth-float-1{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes auth-float-2{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes auth-float-3{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes auth-float-4{0%,to{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-12px) rotate(1deg)}}@keyframes auth-float-5{0%,to{transform:translateY(0) rotate(.5deg)}50%{transform:translateY(-9px) rotate(-.5deg)}}@keyframes auth-float-6{0%,to{transform:translateY(0)}50%{transform:translateY(-11px)}}.auth-widget--attendance{top:8%;left:4%;width:220px;animation:auth-float-1 6s ease-in-out infinite}.auth-widget--leave{top:12%;right:4%;width:210px;animation:auth-float-2 7s ease-in-out infinite;animation-delay:.8s}.auth-widget--payroll{bottom:16%;left:3%;width:230px;animation:auth-float-3 8s ease-in-out infinite;animation-delay:1.2s}.auth-widget--kpi{bottom:12%;right:4%;width:215px;animation:auth-float-4 6.5s ease-in-out infinite;animation-delay:.5s}.auth-widget--team{top:48%;left:2.5%;transform:translateY(-50%);width:200px;animation:auth-float-5 7.5s ease-in-out infinite;animation-delay:2s}.auth-widget--department{top:44%;right:3%;transform:translateY(-50%);width:205px;animation:auth-float-6 6.8s ease-in-out infinite;animation-delay:1.5s}.auth-widget-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.auth-widget-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.auth-widget-icon--purple{background:#4f39f61a;color:#4f39f6}.auth-widget-icon--green{background:#22c55e1a;color:#16a34a}.auth-widget-icon--amber{background:#f59e0b1a;color:#d97706}.auth-widget-icon--blue{background:#3b82f61a;color:#2563eb}.auth-widget-icon--rose{background:#f43f5e1a;color:#e11d48}.auth-widget-icon--teal{background:#14b8a61a;color:#0d9488}.auth-widget-title{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.auth-widget-value{font-size:22px;font-weight:700;color:#0f172a;line-height:1;margin-bottom:6px}.auth-widget-sub{font-size:11px;color:#64748b;margin-top:2px}.auth-widget-row{display:flex;gap:8px;margin-top:8px}.auth-widget-pill{flex:1;background:#f8fafc;border-radius:8px;padding:6px 8px;text-align:center}.auth-widget-pill-val{font-size:14px;font-weight:700;color:#0f172a;display:block}.auth-widget-pill-label{font-size:10px;color:#94a3b8;display:block;margin-top:1px}.auth-widget-bar-wrap{background:#f1f5f9;border-radius:999px;height:6px;margin-top:8px;overflow:hidden}.auth-widget-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#4f39f6,#7c3aed)}.auth-widget-divider{height:1px;background:#f1f5f9;margin:8px 0}.auth-widget-line{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#64748b;margin-top:4px}.auth-widget-line strong{font-size:12px;color:#0f172a;font-weight:600}.auth-widget-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:4px}.auth-widget-avatars{display:flex;margin-top:8px}.auth-widget-avatar{width:26px;height:26px;border-radius:50%;border:2px solid white;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;margin-left:-6px}.auth-widget-avatar:first-child{margin-left:0}.auth-widget-avatar--a{background:linear-gradient(135deg,#4f39f6,#7c3aed)}.auth-widget-avatar--b{background:linear-gradient(135deg,#06b6d4,#0891b2)}.auth-widget-avatar--c{background:linear-gradient(135deg,#10b981,#059669)}.auth-widget-avatar--d{background:linear-gradient(135deg,#f59e0b,#d97706)}.auth-widget-avatar--more{background:#f1f5f9;color:#64748b;font-size:9px}.auth-widget-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:600}.auth-widget-badge--green{background:#22c55e1a;color:#16a34a}.auth-widget-badge--amber{background:#f59e0b1a;color:#d97706}.auth-widget-badge--blue{background:#3b82f61a;color:#2563eb}.auth-card-wrapper{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:18px;width:100%;max-width:420px;padding:24px 20px}.auth-brand{display:flex;align-items:center;gap:10px}.auth-logo{width:40px;height:40px;background:linear-gradient(135deg,#4f39f6,#7c3aed);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #4f39f64d}.auth-brand-name{font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.3px}.auth-heading-block{text-align:center;display:flex;flex-direction:column;gap:5px}.auth-heading{font-size:26px;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.4px;line-height:1.2}.auth-subheading{font-size:14px;color:#64748b;margin:0;line-height:1.5}.auth-card{width:100%;background:#fff;border:1px solid #E2E8F0;border-radius:20px;padding:32px 28px;box-shadow:0 4px 6px -2px #0000000a,0 12px 32px -4px #00000014}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:13px;font-weight:600;color:#1e293b;display:block;margin:0}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input{width:100%;height:46px;padding:0 14px;font-size:14px;font-family:Inter,sans-serif;font-weight:400;color:#0f172a;background:#f8fafc;border:1.5px solid #E2E8F0;border-radius:10px;outline:none;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.auth-input::placeholder{color:#94a3b8}.auth-input:focus{border-color:#4f39f6;background:#fff;box-shadow:0 0 0 3px #4f39f61a}.auth-input.auth-input-has-left-icon{padding-left:42px}.auth-input.auth-input-has-right-icon{padding-right:42px}.auth-input.auth-input--error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.auth-input-icon-left{position:absolute;left:13px;color:#94a3b8;pointer-events:none;z-index:1;transition:color .2s ease}.auth-input-wrap:focus-within .auth-input-icon-left{color:#4f39f6}.auth-eye-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:#94a3b8;padding:0;margin:0!important;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.auth-eye-btn:hover{color:#4f39f6}.auth-row{display:flex;justify-content:flex-end;margin-top:-6px}.auth-link-btn{background:none;border:none;font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:#4f39f6;cursor:pointer;padding:0;margin:0!important;transition:opacity .15s}.auth-link-btn:hover{opacity:.75;text-decoration:underline}.auth-error{display:flex;align-items:flex-start;gap:8px;background:#fef2f2;border:1px solid #FCA5A5;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:500;color:#dc2626;line-height:1.4}.auth-error-icon{flex-shrink:0;margin-top:1px}.auth-field-error{font-size:12px;color:#ef4444;font-weight:500}.auth-submit-btn{width:100%;height:48px;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#4f39f6,#7c3aed);color:#fff;font-family:Inter,sans-serif;font-size:15px;font-weight:600;letter-spacing:.1px;border:none;border-radius:10px;cursor:pointer;margin-top:2px;box-shadow:0 4px 14px #4f39f659;transition:opacity .2s ease,transform .15s ease,box-shadow .2s ease}.auth-submit-btn:hover:not(:disabled){opacity:.93;transform:translateY(-1px);box-shadow:0 8px 22px #4f39f666}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.65;cursor:not-allowed}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-spinner{animation:auth-spin .75s linear infinite}.auth-back-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:none;border:none;font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;padding:0;margin:0!important;transition:color .2s ease}.auth-back-btn:hover{color:#0f172a}.auth-resend-btn{background:none;border:none;font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#4f39f6;cursor:pointer;padding:0;margin:0!important;transition:opacity .15s}.auth-resend-btn:hover{opacity:.75}.auth-otp-row{display:flex;gap:10px}.auth-otp-box{flex:1;height:52px;font-size:20px;font-weight:700;font-family:Inter,sans-serif;color:#0f172a;text-align:center;background:#f8fafc;border:1.5px solid #E2E8F0;border-radius:10px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;caret-color:#4f39f6;padding:0}.auth-otp-box:focus{border-color:#4f39f6;background:#fff;box-shadow:0 0 0 3px #4f39f61a}.auth-otp-box.auth-otp-box--filled{border-color:#4f39f6;background:#f5f3ff}.auth-success-icon{display:flex;align-items:center;justify-content:center;width:68px;height:68px;background:#dcfce7;border:1px solid rgba(34,197,94,.25);border-radius:50%;color:#16a34a;margin:0 auto 8px;animation:auth-success-pop .4s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes auth-success-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.auth-footer{font-size:12px;color:#94a3b8;text-align:center;margin:0;position:relative;z-index:2}@media(max-width:480px){.auth-card{padding:24px 18px;border-radius:16px}.auth-card-wrapper{padding:20px 16px}.auth-heading{font-size:22px}.auth-otp-box{height:46px;font-size:18px}}.notification-wrapper{position:relative}.notification-btn{position:relative;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;color:#64748b;width:40px;height:40px;border-radius:10px;transition:all .2s ease}.notification-btn:hover{background:#f8fafc;color:#1e293b}.notification-badge{position:absolute;top:6px;right:6px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #ffffff;box-shadow:0 2px 4px #ef444433}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;overflow-y:auto;background:#fff;border:1px solid #E2E8F0;border-radius:12px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;z-index:999}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #E2E8F0}.notification-header-left{display:flex;align-items:center;gap:8px}.notification-body{padding:8px}.notification-empty{color:#94a3b8;text-align:center;padding:24px 0;font-size:13px}.notification-item{border:1px solid #F1F5F9;border-radius:8px;padding:12px;margin-bottom:8px;cursor:pointer;transition:.2s ease;background:transparent}.notification-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000000a;border-color:#e2e8f0}.notification-unread{background:#f8fafc;border-left:3px solid #4F39F6}.notification-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.notification-title{font-size:13px;font-weight:600;color:#334155}.notification-title-unread{color:#0f172a}.notification-new{font-size:10px;font-weight:700;color:#4f39f6;background:#eef2ff;padding:2px 6px;border-radius:4px}.notification-message{margin-top:6px;font-size:13px;line-height:1.5;color:#64748b}.notification-date{font-size:11px;color:#94a3b8;margin-top:8px}.nav-item{position:relative}.nav-badge{margin-left:auto;min-width:10px;height:20px;padding:0 6px;display:flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;font-size:11px;font-weight:600;border-radius:999px}.fc-event-custom{padding:4px 6px;display:flex;flex-direction:column;gap:2px}.fc-event-title{font-weight:600;font-size:12px;color:#fff}.fc-event-type{font-size:10px;color:#fffc}.fc-daygrid-event{border-radius:6px;border:none;overflow:hidden;margin-top:2px}.fc-theme-standard th{border-color:#e2e8f0;padding:12px 0;font-weight:600;color:#64748b;background:#f8fafc}.fc-theme-standard td,.fc-theme-standard th{border-color:#e2e8f0}.fc .fc-toolbar-title{font-size:1.25rem;font-weight:600;color:#0f172a}.fc .fc-button-primary{background-color:#fff;border-color:#e2e8f0;color:#0f172a;font-weight:500;text-transform:capitalize;border-radius:8px;box-shadow:0 1px 2px #0000000d;transition:all .2s}.fc .fc-button-primary:hover{background-color:#f8fafc;border-color:#cbd5e1;color:#0f172a}.fc .fc-button-primary:not(:disabled).fc-button-active,.fc .fc-button-primary:not(:disabled):active{background-color:#f1f5f9;border-color:#cbd5e1;color:#0f172a}.fc .fc-button-primary:disabled{background-color:#fff;border-color:#e2e8f0;color:#94a3b8}.fc .fc-today-button{background-color:#4f39f6!important;border-color:#4f39f6!important;color:#fff!important}.fc .fc-today-button:hover{background-color:#4330d3!important;border-color:#4330d3!important}.fc-day-today{background-color:#eef2ff!important}.timeline-card{display:flex;flex-direction:column;gap:16px;margin-top:16px}.timeline-item{display:flex;align-items:flex-start;gap:12px}.tl-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tl-icon.green{background:#f0fdf4;color:#16a34a}.tl-icon.red{background:#fef2f2;color:#ef4444}.tl-icon.blue{background:#eff6ff;color:#3b82f6}.tl-content{display:flex;flex-direction:column}.tl-label{font-size:13px;color:#64748b;font-weight:500}.tl-time{font-size:15px;color:#0f172a;font-weight:600}.dashboard-layout{display:flex;flex-direction:column;gap:24px}.sticky-workspace-bar{position:sticky;top:-24px;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:24px;height:50px;padding:0 24px;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--ds-border);margin:-24px -24px 24px}.workspace-bar-timeline{display:flex;align-items:center;gap:12px;flex:1;max-width:500px}.workspace-bar-label{font-size:11px;font-weight:600;color:var(--ds-text-main);white-space:nowrap}.workspace-bar-timeline-track{display:flex;align-items:center;gap:8px;flex:1;margin-left:8px}.workspace-bar-time{font-size:11px;font-weight:600;color:var(--ds-text-main);min-width:45px}.workspace-bar-progress-bg{flex:1;height:4px;background:var(--ds-border);border-radius:2px;overflow:hidden;min-width:100px}.workspace-bar-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.workspace-bar-divider{width:1px;height:20px;background:var(--ds-border);flex-shrink:0}.workspace-bar-leaves{display:flex;align-items:center;gap:16px;flex:1;justify-content:flex-end;overflow:hidden}.workspace-bar-leave-items{display:flex;align-items:center;gap:16px;overflow-x:auto;padding-right:8px}.workspace-bar-leave-item{display:flex;align-items:center;gap:8px;flex-shrink:0}.workspace-bar-leave-name{font-size:11px;color:var(--ds-text-secondary);white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis}.workspace-bar-leave-bar-bg{width:40px;height:4px;background:var(--ds-border);border-radius:2px;overflow:hidden}.workspace-bar-leave-bar-fill{height:100%;background:var(--ds-primary);border-radius:2px}.workspace-bar-leave-count{font-size:11px;font-weight:600;color:var(--ds-text-main);min-width:12px;text-align:right}.full-calendar-panel{margin-top:24px;background:#fff;border-radius:16px;padding:24px;border:1px solid var(--ds-border);box-shadow:0 4px 6px -1px #0000000d}.full-calendar-panel .panel-header{margin-bottom:24px}.db-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}@media(max-width:1200px){.db-kpi-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.db-kpi-row{grid-template-columns:1fr}}.db-kpi-card{background:#fff;border:1px solid #E2E8F0;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:16px;transition:all .3s ease;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.db-kpi-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -2px #0000000a;border-color:#cbd5e1}.db-kpi-header{display:flex;align-items:center;justify-content:space-between}.db-kpi-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.db-kpi-icon.purple{background:#eef2ff;color:#4f39f6}.db-kpi-icon.orange{background:#fff7ed;color:#ea580c}.db-kpi-icon.red{background:#fef2f2;color:#ef4444}.db-kpi-icon.green{background:#f0fdf4;color:#16a34a}.db-kpi-badge{font-size:11px;font-weight:600;padding:4px 8px;border-radius:20px;background:#f1f5f9;color:#64748b}.db-kpi-badge.warning{background:#fff7ed;color:#ea580c}.db-kpi-badge.pending{background:#f0fdf4;color:#16a34a}.db-kpi-body{display:flex;flex-direction:column;gap:4px}.db-kpi-value{font-size:28px;font-weight:700;color:#0f172a;line-height:1}.db-kpi-total{font-size:16px;font-weight:500;color:#94a3b8}.db-kpi-label{font-size:14px;font-weight:500;color:#64748b}.db-kpi-footer{font-size:13px;font-weight:500;margin-top:auto}.purple-text{color:#4f39f6}.orange-text{color:#ea580c}.green-text{color:#16a34a}.dashboard-stacked{display:flex;flex-direction:column;gap:24px}.main-panel{flex:1;background:#fff;border:1px solid #E2E8F0;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}.side-panel{width:380px;flex-shrink:0}@media(max-width:1024px){.dashboard-split{flex-direction:column}.side-panel{width:100%}}.panel-header{margin-bottom:24px}.panel-header h3{font-size:18px;font-weight:600;color:#0f172a;margin:0 0 4px}.panel-header p{font-size:14px;color:#64748b;margin:0}.table-wrapper-premium{border:1px solid #E2E8F0;border-radius:12px;overflow:hidden}.employee-text{display:flex;flex-direction:column}.employee-name{font-weight:500;color:#0f172a;font-size:14px}.employee-id{font-size:12px;color:#94a3b8}.type-badge{background:#f1f5f9;color:#475569;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.status-badge.pending{background:#fff7ed;color:#ea580c;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.my-workspace-card{background:linear-gradient(180deg,#f8fafc,#fff);border:1px solid #E2E8F0;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}.workspace-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.workspace-header h3{font-size:16px;font-weight:600;color:#0f172a;margin:0}.status-indicator{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#1e293b;background:#fff;padding:4px 10px;border-radius:20px;border:1px solid #E2E8F0}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.active,.status-dot.present{background:#10b981}.status-dot.absent{background:#ef4444}.workspace-stats{display:flex;gap:16px;margin-bottom:24px}.w-stat{flex:1;background:#fff;border:1px solid #E2E8F0;padding:16px;border-radius:12px;display:flex;flex-direction:column;gap:4px}.w-label{font-size:12px;color:#64748b;font-weight:500}.w-val{font-size:18px;font-weight:700;color:#0f172a}.workspace-leaves h4{font-size:14px;font-weight:600;color:#0f172a;margin:0 0 12px}.mini-leave-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fff;border:1px solid #E2E8F0;border-radius:10px;margin-bottom:8px}.ml-left{display:flex;flex-direction:column;gap:2px}.ml-name{font-size:13px;font-weight:500;color:#1e293b}.ml-used{font-size:11px;color:#94a3b8}.ml-right{font-size:15px;font-weight:600;color:#0f172a}.ml-right small{font-size:12px;color:#94a3b8;font-weight:500}.fc{font-family:inherit;color:var(--ds-text-main);background:#fff}.fc-theme-standard td,.fc-theme-standard th{border-color:var(--ds-border)!important}.fc-scrollgrid{border:1px solid var(--ds-border)!important;border-radius:12px!important;overflow:hidden}.fc-toolbar-title{font-size:1.35rem!important;font-weight:700!important;color:#0f172a}.fc-button-primary{background-color:#fff!important;border:1px solid #E2E8F0!important;color:#475569!important;border-radius:8px!important;font-weight:500!important;text-transform:capitalize!important;box-shadow:0 1px 2px #0000000d!important;transition:all .2s ease!important}.fc-button-primary:not(:disabled):hover{background-color:#f8fafc!important;color:#0f172a!important}.fc-button-primary:not(:disabled):active,.fc-button-primary.fc-button-active{background-color:var(--ds-primary)!important;color:#fff!important;border-color:var(--ds-primary)!important}.fc-col-header-cell-cushion{color:#64748b;font-weight:600;text-transform:uppercase;font-size:12px;padding:12px 8px!important}.fc-daygrid-day-number{color:#0f172a;font-weight:600;padding:8px!important}.fc-day-today{background-color:#4f46e508!important}.fc-event{border-radius:6px!important;padding:4px 8px!important;font-size:11px!important;font-weight:600!important;border:none!important;background-color:var(--ds-primary)!important;color:#fff!important;box-shadow:0 2px 4px #4f46e526;margin:2px 4px!important;cursor:pointer;transition:transform .2s ease}.fc-event:hover{transform:translateY(-1px);box-shadow:0 4px 6px #4f46e540}.attendance-widget-card{background:linear-gradient(135deg,#ffffffe6,#f0f4ff99);border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;box-shadow:0 4px 24px #4f39f614;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.attendance-widget-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #4f39f61f}.attendance-widget-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:8px;position:relative;z-index:2;transition:all .3s ease}.attendance-widget-icon.pulse-green{background:#22c55e1a;color:#22c55e;animation:pulse-green-anim 2s infinite cubic-bezier(.4,0,.6,1)}.attendance-widget-icon.solid-purple{background:#4f39f61a;color:var(--ds-primary)}@keyframes pulse-green-anim{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 15px #22c55e00}to{box-shadow:0 0 #22c55e00}}.attendance-widget-title{font-size:18px;font-weight:700;color:var(--ds-text-main);margin:0}.attendance-widget-subtitle{font-size:13px;color:var(--ds-text-secondary);text-align:center;margin:0;max-width:200px;line-height:1.4}.attendance-widget-timer{font-size:24px;font-weight:800;color:var(--ds-primary);font-variant-numeric:tabular-nums;letter-spacing:-.5px;margin-bottom:8px}.attendance-widget-btn{width:100%;padding:12px 24px;border-radius:100px;font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;transition:all .2s ease;z-index:2}.attendance-widget-btn.btn-checkin{background:#22c55e;color:#fff;box-shadow:0 4px 12px #22c55e4d}.attendance-widget-btn.btn-checkin:hover{background:#16a34a;transform:translateY(-1px);box-shadow:0 6px 16px #22c55e66}.attendance-widget-btn.btn-checkout{background:#ef4444;color:#fff;box-shadow:0 4px 12px #ef44444d}.attendance-widget-btn.btn-checkout:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 16px #ef444466}.attendance-widget-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.attendance-widget-bg-shape{position:absolute;top:-50px;right:-50px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,#4f39f61a,#fff0 70%);z-index:1}.empty-state-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;background-color:transparent;width:100%}.empty-state-icon-box{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background-color:#eef2ff;color:#4f39f6;margin-bottom:20px;box-shadow:0 4px 14px #4f39f626}.empty-state-icon-box svg{width:32px;height:32px;stroke-width:1.5}.empty-state-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#0f172a}.empty-state-description{margin:0;font-size:14px;color:#64748b;max-width:400px;line-height:1.5}.empty-state-action{margin-top:24px}.card-actions{display:flex!important}.attendance-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;margin-bottom:24px}.attendance-stat-card{background:var(--ds-bg-main);border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);padding:18px 20px;box-shadow:0 1px 2px #0000000a;transition:all .2s ease}.attendance-stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.stat-label{font-size:13px;color:var(--ds-text-secondary);margin-bottom:10px;font-weight:500}.stat-value{font-size:30px;line-height:1;font-weight:700;color:var(--ds-text-main)}.btn-apply-filter{background:transparent;border:1px solid var(--ds-primary);color:var(--ds-primary);transition:all .2s ease}.btn-apply-filter:hover{background:var(--ds-primary);color:#fff}.stat-value.success{color:#22c55e}.stat-value.warning{color:#f59e0b}.stat-value.danger{color:#ef4444}@media(max-width:1200px){.attendance-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.attendance-stats-grid{grid-template-columns:1fr}}.error-field{border:1px solid #ef4444!important;box-shadow:0 0 0 2px #ef444426}.error-field:focus{border-color:#ef4444!important}.split-layout{display:flex;flex:1;min-height:0;gap:16px}.left-pane{width:280px;flex-shrink:0;display:flex;flex-direction:column;min-height:0;overflow-y:auto;border-right:1px solid #e5e7eb;padding-right:10px}.pane-title{margin-bottom:10px;font-size:16px;font-weight:600}.image-viewer{width:100%}.image-viewer img{width:100%;max-height:75vh;object-fit:contain;border-radius:12px}.session-list{flex:1;overflow-y:auto;min-height:0}.session-item{padding:10px;border:1px solid #eee;border-radius:10px;cursor:pointer;background:#fff;margin-top:10px;margin-bottom:10px}.session-item.active{border-color:#3b82f6;background:#eff6ff}.session-title{font-weight:600}.session-meta{font-size:12px;color:#6b7280}.status{margin-top:6px;font-size:12px}.status.on{color:green}.status.off{color:gray}.session-details{margin-top:15px;padding:10px;background:#f9fafb;border-radius:10px}.right-pane{flex:1;min-width:0;min-height:0;overflow-y:auto;padding-left:10px}.empty-state{display:flex;height:100%;align-items:center;justify-content:center;color:#9ca3af}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;width:100%}.employee-progress-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #E2E8F0;background-color:#f8fafc}.employee-progress-modal{width:1200px!important;max-width:95vw!important;height:90vh!important;display:flex!important;flex-direction:column!important;background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden}.flex-button-icon{display:flex;flex-direction:row!important;align-items:center!important}.modal-body-reports{display:flex;flex-direction:column;flex:1;min-height:0;padding:24px}.modal-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.modal-footer-reports{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #E2E8F0;background-color:#f8fafc;padding:0 16px 16px}.thumb{width:100%;height:130px;object-fit:cover;border-radius:10px;cursor:pointer;transition:.2s}.thumb:hover{transform:scale(1.04)}.image-viewer img{width:100%;max-height:70vh;object-fit:contain;border-radius:10px}.msp-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.msp-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--ds-bg-subtle, #F8FAFC);padding:5px;border-radius:var(--ds-radius-lg, 12px);border:1px solid var(--ds-border, #E2E8F0);width:fit-content}.msp-tab-btn{display:flex;align-items:center;gap:8px;padding:9px 20px;border:none;border-radius:calc(var(--ds-radius-lg, 12px) - 3px);background:transparent;color:var(--ds-text-secondary, #64748B);font-size:14px;font-weight:500;cursor:pointer;transition:all .18s ease;white-space:nowrap}.msp-tab-btn:hover{color:var(--ds-text-main, #0F172A);background:var(--ds-bg-main, #fff);box-shadow:0 1px 4px #00000014}.msp-tab-btn.active{background:var(--ds-primary, #4F39F6);color:#fff;box-shadow:0 2px 10px #4f39f64d}.msp-tab-btn svg{flex-shrink:0;opacity:.8}.msp-tab-content{display:flex;flex-direction:column;gap:20px;animation:mspFadeIn .22s ease}@keyframes mspFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msp-kpi-highlight{border:2px solid var(--ds-primary, #4F39F6)!important;background:#4f39f60a!important}.msp-breakdown-card{background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px);padding:20px 24px;box-shadow:0 1px 3px #0000000d}.msp-breakdown-title{font-size:14px;font-weight:600;color:var(--ds-text-main, #0F172A);margin:0 0 14px}.msp-breakdown-bar-wrap{width:100%;height:10px;background:var(--ds-border, #E2E8F0);border-radius:99px;overflow:hidden;margin-bottom:12px}.msp-breakdown-bar-fill{height:100%;background:linear-gradient(90deg,var(--ds-primary, #4F39F6),var(--ds-success, #10B981));border-radius:99px;transition:width .6s ease}.msp-breakdown-legend{display:flex;gap:20px;flex-wrap:wrap}.msp-legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ds-text-secondary, #64748B)}.msp-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.msp-section-title{font-size:16px;font-weight:600;color:var(--ds-text-main, #0F172A);margin:0;display:flex;align-items:center;gap:10px}.msp-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;background:var(--ds-primary, #4F39F6);color:#fff;font-size:12px;font-weight:700;border-radius:99px}.msp-payslip-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.msp-year-filter{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ds-text-secondary, #64748B)}.msp-year-select{background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);color:var(--ds-text-main, #0F172A);padding:6px 12px;border-radius:var(--ds-radius-md, 8px);font-size:14px;cursor:pointer;outline:none;transition:border-color .18s ease}.msp-year-select:focus{border-color:var(--ds-primary, #4F39F6);box-shadow:var(--ds-focus-ring, 0 0 0 3px rgba(79, 57, 246, .15))}.msp-payslip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.msp-payslip-card{background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px);padding:20px;display:flex;flex-direction:column;gap:14px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;position:relative;overflow:hidden}.msp-payslip-card:before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,var(--ds-primary, #4F39F6),var(--ds-success, #10B981));opacity:0;transition:opacity .18s ease}.msp-payslip-card:hover{border-color:var(--ds-border-hover, #CBD5E1);box-shadow:0 4px 20px #00000014;transform:translateY(-2px)}.msp-payslip-card:hover:before{opacity:1}.msp-ps-card-top{display:flex;align-items:center;justify-content:space-between}.msp-ps-month-badge{display:flex;flex-direction:column;line-height:1.15}.msp-ps-month{font-size:18px;font-weight:700;color:var(--ds-text-main, #0F172A)}.msp-ps-year{font-size:12px;color:var(--ds-text-secondary, #64748B)}.msp-ps-net{display:flex;flex-direction:column;background:linear-gradient(135deg,#4f39f60f,#10b9810a);border:1px solid rgba(79,57,246,.15);border-radius:var(--ds-radius-md, 8px);padding:14px 16px}.msp-ps-net-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ds-text-secondary, #64748B);margin-bottom:4px}.msp-ps-net-value{font-size:22px;font-weight:700;color:var(--ds-primary, #4F39F6)}.msp-ps-rows{display:flex;flex-direction:column;gap:7px}.msp-ps-row{display:flex;justify-content:space-between;font-size:13px;color:var(--ds-text-secondary, #64748B)}.msp-ps-row span:last-child{font-weight:500;color:var(--ds-text-main, #0F172A)}.msp-ps-row-ded{border-top:1px dashed var(--ds-border, #E2E8F0);padding-top:7px;margin-top:2px}.msp-ps-green{color:var(--ds-success, #10B981)!important;font-weight:500!important}.msp-ps-red{color:var(--ds-danger, #EF4444)!important;font-weight:500!important}.msp-ps-paid-info{font-size:12px;color:var(--ds-text-secondary, #64748B);background:var(--ds-bg-subtle, #F8FAFC);border:1px solid var(--ds-border, #E2E8F0);padding:6px 10px;border-radius:var(--ds-radius-sm, 6px)}.msp-ps-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--ds-bg-subtle, #F8FAFC);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-sm, 6px);padding:8px 12px;font-size:12px;color:var(--ds-text-secondary, #64748B);cursor:pointer;transition:all .18s ease}.msp-ps-toggle:hover{border-color:var(--ds-primary, #4F39F6);color:var(--ds-primary, #4F39F6);background:#4f39f60a}.msp-ps-lines{background:var(--ds-bg-subtle, #F8FAFC);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-sm, 6px);padding:10px 12px;display:flex;flex-direction:column;gap:6px;animation:mspFadeIn .2s ease}.msp-ps-line-row{display:flex;justify-content:space-between;font-size:12px;gap:8px}.msp-ps-line-reason{color:var(--ds-text-secondary, #64748B);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msp-ps-line-amt{font-weight:600;flex-shrink:0}.msp-ps-download-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:#4f39f612;border:1px solid rgba(79,57,246,.2);border-radius:var(--ds-radius-md, 8px);color:var(--ds-primary, #4F39F6);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s ease;margin-top:2px}.msp-ps-download-btn:hover:not(:disabled){background:var(--ds-primary, #4F39F6);border-color:var(--ds-primary, #4F39F6);color:#fff;box-shadow:0 4px 14px #4f39f659}.msp-ps-download-btn:disabled{opacity:.55;cursor:not-allowed}.msp-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:mspSpin .6s linear infinite}@keyframes mspSpin{to{transform:rotate(360deg)}}.msp-ded-summary{display:flex;align-items:center;gap:8px}.msp-ded-total{font-size:14px;font-weight:700;color:var(--ds-danger, #EF4444);background:#ef444414;padding:6px 14px;border-radius:var(--ds-radius-sm, 6px);border:1px solid rgba(239,68,68,.18)}.msp-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--ds-text-secondary, #64748B);text-align:center;background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px)}.msp-empty-state p{font-size:14px;max-width:340px;line-height:1.6;margin:0}@media(max-width:640px){.msp-tabs{width:100%;justify-content:stretch}.msp-tab-btn{flex:1;justify-content:center;padding:9px 10px;font-size:13px}.msp-payslip-grid{grid-template-columns:1fr}.msp-breakdown-legend{gap:10px}.msp-payslip-header{flex-direction:column;align-items:flex-start}}.roles-page{padding:0 24px 24px;max-width:1400px;margin:0 auto}.roles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.roles-title-section h1{font-size:28px;font-weight:700;color:#1f2937;margin:0 0 6px}.roles-title-section p{font-size:14px;color:#6b7280;margin:0}.btn-add-role{display:flex;align-items:center;gap:8px;background-color:#7c3aed;color:#fff;padding:10px 18px;border-radius:8px;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:background-color .2s ease,transform .1s ease}.btn-add-role:hover{background-color:#6d28d9}.btn-add-role:active{transform:scale(.98)}.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}.role-card{box-sizing:border-box;min-width:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;display:flex;flex-direction:column;position:relative;box-shadow:0 1px 3px #0000000d;transition:transform .2s ease,box-shadow .2s ease}.role-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.role-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.role-header-left{display:flex;align-items:center;gap:12px}.role-shield-icon{color:#7c3aed;background-color:#f5f3ff;padding:8px;border-radius:8px}.role-title-info h3{font-size:16px;font-weight:700;color:#111827;margin:0 0 4px;display:flex;align-items:center}.role-member-count{font-size:11px;font-weight:600;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase;margin:0}.kebab-container{position:relative}.kebab-trigger{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.kebab-trigger:hover{background-color:#f3f4f6;color:#4b5563}.kebab-menu-dropdown{position:absolute;top:100%;right:0;background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:10;min-width:120px;padding:4px 0}.kebab-menu-dropdown button{width:100%;padding:8px 12px;font-size:13px;text-align:left;border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:8px;color:#4b5563}.kebab-menu-dropdown button:hover{background-color:#f3f4f6}.kebab-menu-dropdown button.delete{color:#ef4444}.kebab-menu-dropdown button.delete:hover{background-color:#fef2f2}.card-divider{border:0;border-top:1px solid #e5e7eb;margin:0 0 16px}.permission-rows-list{display:flex;flex-direction:column;gap:12px;flex-grow:1;max-height:380px;overflow-y:auto;padding-right:4px;margin-bottom:16px}.permission-rows-list::-webkit-scrollbar{width:4px}.permission-rows-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.permission-rows-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}.permission-rows-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.permission-row{display:flex;align-items:center;justify-content:space-between;font-size:13.5px;color:#374151;padding:2px 0}.permission-row label{cursor:pointer;-webkit-user-select:none;user-select:none;padding-right:12px}.permission-checkbox{appearance:none;width:18px;height:18px;border:1px solid #d1d5db;border-radius:4px;outline:none;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color .2s,border-color .2s}.permission-checkbox:checked{background-color:#7c3aed;border-color:#7c3aed}.permission-checkbox:checked:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);position:absolute;top:2px}.permission-checkbox:disabled{background-color:#e5e7eb;border-color:#d1d5db;cursor:not-allowed}.permission-checkbox:disabled:checked{background-color:#c084fc;border-color:#c084fc}.role-lock-banner{display:flex;align-items:flex-start;gap:10px;background-color:#f5f3ff;border-radius:8px;padding:12px;margin-top:auto;border:1px solid #e0d7ff}.role-lock-icon{color:#7c3aed;flex-shrink:0;margin-top:1px}.role-lock-banner span{font-size:12px;color:#5b21b6;line-height:1.4}.add-first-card{border:2px dashed #d1d5db;background-color:#fafafa;justify-content:center;align-items:center;cursor:pointer;min-height:250px;color:#9ca3af;transition:border-color .2s,color .2s,background-color .2s}.add-first-card:hover{border-color:#7c3aed;color:#7c3aed;background-color:#f5f3ff;transform:none;box-shadow:none}.add-first-card span{font-size:14px;font-weight:600;margin-top:12px}.rename-inline-input{border:1px solid #7c3aed;border-radius:4px;padding:4px 8px;font-size:16px;font-weight:700;width:100%;color:#111827;outline:none}.skeleton-card{pointer-events:none}.skeleton-header{height:48px;background-color:#e5e7eb;border-radius:6px;margin-bottom:16px}.skeleton-divider{height:1px;background-color:#e5e7eb;margin-bottom:16px}.skeleton-row{height:20px;background-color:#e5e7eb;border-radius:4px;margin-bottom:12px}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;inset:0;transform:translate(-100%);background-image:linear-gradient(90deg,#fff0,#fff3 20%,#ffffff80,#fff0);animation:shimmer-animation 1.5s infinite}@keyframes shimmer-animation{to{transform:translate(100%)}}.modal-permission-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start;margin-top:16px;max-height:450px;overflow-y:auto;padding-right:8px}.modal-category-group{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff}.modal-category-header{display:flex;align-items:center;justify-content:space-between;background-color:#f9fafb;padding:10px 16px;border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.modal-category-header:hover{background-color:#f3f4f6}.modal-category-header h4{font-size:14px;font-weight:700;color:#374151;margin:0}.modal-category-select-all{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#6b7280;cursor:pointer}.modal-category-select-all:hover{color:#4f39f6}.modal-category-body{padding:16px;display:grid;grid-template-columns:1fr;gap:12px}.modal-permission-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#4b5563}.modal-permission-item label{cursor:pointer;-webkit-user-select:none;user-select:none}.custom-role-modal .modal-content{padding:0!important;display:block!important;overflow:visible!important}.custom-role-modal .modal-footer{padding:0!important;border-top:none!important;background:transparent!important}.modal-section-title{font-size:16px;font-weight:600;color:var(--ds-text-main);margin:0 0 16px;display:flex;align-items:center;gap:8px}.modal-step-num{width:24px;height:24px;border-radius:50%;background:#4f39f61a;color:var(--ds-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.modal-category-group{margin-bottom:16px;border:1px solid var(--ds-border);border-radius:var(--ds-radius-md);overflow:hidden}.modal-category-header{cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--ds-bg-subtle);border-bottom:1px solid var(--ds-border)}.modal-category-header:hover{background:var(--ds-border)}.modal-category-body{padding:8px 14px;display:flex;flex-direction:column;gap:4px}.modal-caution-banner{margin-top:16px;padding:10px 14px;background:var(--ds-warning-bg);border-left:4px solid var(--ds-warning);border-radius:var(--ds-radius-sm);font-size:13px;color:var(--ds-warning-text)}.permissions-collapse-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:8px 0;margin-bottom:8px}.permissions-collapse-header span{font-size:13px;font-weight:600;color:var(--ds-text-secondary)}.live-header{display:flex;justify-content:space-between;align-items:center;width:100%}.live-header .title-section h2{margin:0;font-size:20px;color:#f8fafc}.live-header .title-section .subtitle{margin:4px 0 0;font-size:13px;color:#94a3b8}.live-screen-container{margin-top:16px;width:100%;display:flex;justify-content:center}.video-viewport{position:relative;width:100%;aspect-ratio:16 / 9;background:#090d16;border:1px solid rgba(255,255,255,.05);border-radius:12px;overflow:hidden;box-shadow:inset 0 0 30px #000c,0 10px 30px #00000080}.live-video-stream{width:100%;height:100%;object-fit:contain;display:none}.live-video-stream.active{display:block}.viewport-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#e2e8f0;padding:24px;text-align:center}.viewport-overlay p{font-size:15px;font-weight:500;margin:16px 0 0;color:#cbd5e1}.viewport-overlay .helper-text{font-size:12px;color:#64748b;margin-top:8px;max-width:400px}.viewport-overlay .error-title{font-size:16px;font-weight:700;color:#ef4444}.viewport-overlay .error-message{font-size:13px;color:#94a3b8;margin-top:6px;max-width:450px}.pulse-circle{width:40px;height:40px;background:#6366f126;border:2px solid #6366f1;border-radius:50%;box-shadow:0 0 #6366f1b3;animation:pulseBlueStream 2s infinite}@keyframes pulseBlueStream{0%{transform:scale(.95);box-shadow:0 0 #6366f180}70%{transform:scale(1.1);box-shadow:0 0 0 12px #6366f100}to{transform:scale(.95);box-shadow:0 0 #6366f100}}.spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.05);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.live-badge-overlay{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:6px;background:#ef4444d9;border:1px solid rgba(239,68,68,.3);color:#fff;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.05em;box-shadow:0 2px 8px #00000080}.live-badge-overlay .badge-dot{width:5px;height:5px;background:#fff;border-radius:50%;box-shadow:0 0 #fffc;animation:pulseWhiteDot 1.4s infinite}@keyframes pulseWhiteDot{0%{transform:scale(.9);box-shadow:0 0 #fff9}70%{transform:scale(1.2);box-shadow:0 0 0 4px #fff0}to{transform:scale(.9);box-shadow:0 0 #fff0}}.pmp-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.pmp-kpi-card{display:flex;align-items:center;gap:14px;background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px);padding:18px 20px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .18s ease}.pmp-kpi-card:hover{box-shadow:0 4px 14px #00000012}.pmp-kpi-icon{width:44px;height:44px;border-radius:var(--ds-radius-md, 8px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pmp-kpi-blue .pmp-kpi-icon{background:#4f39f61a;color:var(--ds-primary, #4F39F6)}.pmp-kpi-green .pmp-kpi-icon{background:#10b9811a;color:var(--ds-success, #10B981)}.pmp-kpi-amber .pmp-kpi-icon{background:#f59e0b1a;color:#f59e0b}.pmp-kpi-purple .pmp-kpi-icon{background:#8b5cf61a;color:#8b5cf6}.pmp-kpi-body{display:flex;flex-direction:column;min-width:0}.pmp-kpi-value{font-size:22px;font-weight:700;color:var(--ds-text-main, #0F172A);line-height:1.2}.pmp-kpi-label{font-size:12px;font-weight:500;color:var(--ds-text-secondary, #64748B);margin-top:2px}.pmp-gen-card{background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px);margin-bottom:20px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.pmp-gen-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 20px;background:none;border:none;cursor:pointer;font-size:15px;font-weight:600;color:var(--ds-text-main, #0F172A);transition:background .15s ease}.pmp-gen-header:hover{background:var(--ds-bg-subtle, #F8FAFC)}.pmp-gen-subtitle{font-size:13px;font-weight:400;color:var(--ds-text-secondary, #64748B)}.pmp-gen-body{padding:0 20px 20px;border-top:1px solid var(--ds-border, #E2E8F0);animation:pmpFadeIn .2s ease}.pmp-gen-controls{display:flex;gap:12px;align-items:flex-end;margin-top:16px;flex-wrap:wrap}.pmp-gen-field{display:flex;flex-direction:column;gap:6px;min-width:130px}.pmp-gen-btn{display:flex;align-items:center;gap:8px;white-space:nowrap;height:40px}.pmp-gen-note{margin:12px 0 0;font-size:12px;color:var(--ds-text-secondary, #64748B);background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);border-radius:var(--ds-radius-sm, 6px);padding:8px 12px}.pmp-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:600}.pmp-badge-paid{background:#10b9811a;color:var(--ds-success, #10B981)}.pmp-badge-pending{background:#f59e0b1a;color:#f59e0b}.pmp-badge-failed{background:#ef44441a;color:var(--ds-danger, #EF4444)}.pmp-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--ds-primary, #4F39F6),#8B5CF6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.pmp-icon-btn{width:32px;height:32px;border-radius:var(--ds-radius-sm, 6px);border:1px solid var(--ds-border, #E2E8F0);background:var(--ds-bg-subtle, #F8FAFC);color:var(--ds-text-secondary, #64748B);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.pmp-icon-btn:hover:not(:disabled){background:var(--ds-primary, #4F39F6);border-color:var(--ds-primary, #4F39F6);color:#fff}.pmp-icon-btn:disabled{opacity:.5;cursor:not-allowed}.pmp-spin{animation:pmpSpin .8s linear infinite}.pmp-side{background:var(--ds-bg-main, #fff);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-lg, 12px);overflow:hidden;box-shadow:0 4px 20px #0000000f;display:flex;flex-direction:column}.pmp-side-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,var(--ds-primary, #4F39F6),#8B5CF6);color:#fff}.pmp-side-month{display:flex;flex-direction:column;line-height:1.15}.pmp-side-month-name{font-size:18px;font-weight:700}.pmp-side-year{font-size:12px;opacity:.8}.pmp-side-close{width:30px;height:30px;border-radius:50%;background:#fff3;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.pmp-side-close:hover{background:#ffffff59}.pmp-side-emp{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--ds-border, #E2E8F0)}.pmp-side-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--ds-primary, #4F39F6),#8B5CF6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.pmp-side-name{font-size:15px;font-weight:600;color:var(--ds-text-main, #0F172A);line-height:1.2}.pmp-side-empid{font-size:12px;color:var(--ds-text-secondary, #64748B)}.pmp-side-net{display:flex;flex-direction:column;align-items:center;padding:20px;background:linear-gradient(135deg,#4f39f60d,#8b5cf608);border-bottom:1px solid var(--ds-border, #E2E8F0)}.pmp-side-net-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ds-text-secondary, #64748B);margin-bottom:4px}.pmp-side-net-value{font-size:26px;font-weight:700;color:var(--ds-primary, #4F39F6)}.pmp-side-section{padding:16px 20px;border-bottom:1px solid var(--ds-border, #E2E8F0);display:flex;flex-direction:column;gap:8px}.pmp-side-section:last-child{border-bottom:none}.pmp-side-section-title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ds-text-secondary, #64748B);margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}.pmp-side-row{display:flex;justify-content:space-between;font-size:13px}.pmp-side-row-label{color:var(--ds-text-secondary, #64748B)}.pmp-side-row-val{font-weight:500;color:var(--ds-text-main, #0F172A)}.pmp-green{color:var(--ds-success, #10B981)!important}.pmp-red{color:var(--ds-danger, #EF4444)!important}.pmp-count-chip{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;background:var(--ds-primary, #4F39F6);color:#fff;font-size:11px;font-weight:700;border-radius:99px}.pmp-ded-list{display:flex;flex-direction:column;gap:6px}.pmp-ded-item{display:flex;justify-content:space-between;align-items:flex-start;background:var(--ds-bg-subtle, #F8FAFC);border:1px solid var(--ds-border, #E2E8F0);border-radius:var(--ds-radius-sm, 6px);padding:8px 10px;gap:8px;transition:opacity .2s}.pmp-ded-reversed{opacity:.55}.pmp-ded-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.pmp-ded-date{font-size:11px;color:var(--ds-text-muted, #94A3B8)}.pmp-ded-reason{font-size:12px;color:var(--ds-text-secondary, #64748B);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pmp-ded-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.pmp-ded-amt{font-size:13px;font-weight:600;color:var(--ds-danger, #EF4444)}.pmp-ded-tag{font-size:10px;font-weight:700;padding:2px 6px;border-radius:99px}.pmp-ded-tag-reversed{background:#10b9811a;color:var(--ds-success, #10B981)}.pmp-ded-reverse-btn{width:26px;height:26px;border-radius:var(--ds-radius-sm, 6px);background:#f59e0b14;border:1px solid rgba(245,158,11,.25);color:#f59e0b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.pmp-ded-reverse-btn:hover:not(:disabled){background:#f59e0b;color:#fff}.pmp-ded-reverse-btn:disabled{opacity:.5;cursor:not-allowed}.pmp-side-paid-info{flex-direction:row!important;align-items:center;gap:10px;background:#10b9810d;border-color:#10b98133!important}.pmp-pdf-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px;background:#4f39f612;border:1px solid rgba(79,57,246,.2);border-radius:var(--ds-radius-md, 8px);color:var(--ds-primary, #4F39F6);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s ease}.pmp-pdf-btn:hover:not(:disabled){background:var(--ds-primary, #4F39F6);color:#fff;box-shadow:0 4px 14px #4f39f64d}.pmp-pdf-btn:disabled{opacity:.55;cursor:not-allowed}.pmp-side-meta{padding:12px 20px;font-size:11px;color:var(--ds-text-muted, #94A3B8);text-align:center;border-top:1px solid var(--ds-border, #E2E8F0)}.pmp-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:pmpSpin .6s linear infinite;flex-shrink:0}@keyframes pmpSpin{to{transform:rotate(360deg)}}@keyframes pmpFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1100px){.pmp-kpi-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.pmp-kpi-row{grid-template-columns:1fr}.pmp-gen-controls{flex-direction:column}.pmp-gen-field{min-width:unset;width:100%}}:root{--ds-primary: #4F39F6;--ds-primary-hover: #4330D3;--ds-primary-light: #EEF2FF;--ds-text-main: #0F172A;--ds-text-secondary: #64748B;--ds-text-muted: #94A3B8;--ds-text-tertiary: #94A3B8;--ds-border: #E2E8F0;--ds-border-hover: #CBD5E1;--ds-bg-main: #ffffff;--ds-bg-subtle: #F8FAFC;--ds-focus-ring: 0 0 0 3px rgba(79, 57, 246, .15);--ds-radius-sm: 6px;--ds-radius-md: 8px;--ds-radius-lg: 12px;--ds-success: #10B981;--ds-success-bg: #D1FAE5;--ds-success-text: #065F46;--ds-success-hover: #059669;--ds-danger: #EF4444;--ds-danger-bg: #FEE2E2;--ds-danger-text: #991B1B;--ds-danger-hover: #DC2626;--ds-warning: #F59E0B;--ds-warning-bg: #FEF3C7;--ds-warning-text: #92400E;--ds-warning-hover: #D97706;--ds-info: #3B82F6;--ds-info-bg: #DBEAFE;--ds-info-text: #1E40AF;--ds-space-1: 4px;--ds-space-2: 8px;--ds-space-3: 12px;--ds-space-4: 16px;--ds-space-5: 20px;--ds-space-6: 24px;--ds-space-8: 32px;--ds-space-10: 40px}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;font-size:14px;font-weight:600;border-radius:var(--ds-radius-lg);cursor:pointer;transition:all .2s ease;border:1px solid transparent;white-space:nowrap}.ds-btn:focus-visible{outline:none;box-shadow:var(--ds-focus-ring)}.ds-btn:disabled{opacity:.6;cursor:not-allowed}.ds-btn-primary{background:var(--ds-primary);color:#fff;box-shadow:0 4px 12px #4f39f640}.ds-btn-primary:hover:not(:disabled){background:var(--ds-primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #4f39f659}.ds-btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #4f39f626}.ds-btn-secondary{background:var(--ds-bg-main);color:var(--ds-text-main);border-color:var(--ds-border);box-shadow:0 1px 2px #0000000d}.ds-btn-secondary:hover:not(:disabled){background:var(--ds-bg-subtle);border-color:var(--ds-border-hover)}.ds-btn-danger{background:var(--ds-danger);color:#fff;box-shadow:0 4px 12px #ef444440}.ds-btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px);box-shadow:0 6px 16px #ef444459}.ds-btn-outline{background:transparent;color:var(--ds-text-secondary);border-color:var(--ds-border)}.ds-btn-outline:hover:not(:disabled){background:var(--ds-bg-subtle);border-color:var(--ds-border-hover);color:var(--ds-text-main)}.ds-btn-ghost{background:transparent;color:var(--ds-text-secondary);border-color:transparent;box-shadow:none}.ds-btn-ghost:hover:not(:disabled){background:var(--ds-bg-subtle);color:var(--ds-text-main)}.ds-btn-success{background:var(--ds-success);color:#fff;box-shadow:0 4px 12px #10b98140}.ds-btn-success:hover:not(:disabled){background:var(--ds-success-hover);transform:translateY(-2px);box-shadow:0 6px 16px #10b98159}.ds-input,.ds-select{box-sizing:border-box;height:40px;padding:0 12px;font-size:14px;color:var(--ds-text-main);background:#fff;border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);transition:all .2s ease;width:100%}.ds-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.ds-input::placeholder{color:var(--ds-text-muted)}.ds-input:hover,.ds-select:hover{border-color:var(--ds-border-hover);background:#fff}.ds-input:focus,.ds-select:focus{outline:none;background:#fff;border-color:var(--ds-primary);box-shadow:var(--ds-focus-ring)}.ds-form-submitted .ds-input:invalid,.ds-form-submitted .ds-select:invalid,.ds-form-submitted .form-input:invalid,.ds-form-submitted .form-select:invalid{border-color:var(--ds-danger)!important;background-color:#ef444405!important}.ds-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.ds-input-icon{position:absolute;right:12px;color:var(--ds-text-muted);pointer-events:none}.ds-input-icon-left{position:absolute;left:12px;color:var(--ds-text-muted);pointer-events:none}.ds-input.has-icon-left{padding-left:36px!important}.ds-input-icon.clickable{pointer-events:auto;cursor:pointer;background:none;border:none;padding:0;display:flex}.ds-form-label{display:block;font-size:13px;font-weight:500;color:var(--ds-text-secondary);margin-bottom:6px}.ds-filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px}.responsive-add-btn .short-text{display:none}@media(max-width:1400px){.responsive-add-btn .full-text{display:none}.responsive-add-btn .short-text{display:inline}.ds-filter-bar>select,.ds-filter-bar>.ds-input-wrapper{flex:1 1 auto;min-width:140px}}.ds-table-wrapper{background:var(--ds-bg-main);border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);box-shadow:0 1px 3px #00000005}.ds-table{width:100%;border-collapse:collapse;text-align:left}.ds-table th{background:var(--ds-bg-subtle);color:var(--ds-text-secondary);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:16px 24px;border-bottom:1px solid var(--ds-border);white-space:nowrap}.ds-table td{padding:20px 24px;font-size:15px;line-height:1.5;color:var(--ds-text-main);border-bottom:1px solid var(--ds-border);vertical-align:middle;white-space:nowrap}.ds-table tbody tr{transition:background-color .15s ease}.ds-table tbody tr:hover{background-color:var(--ds-bg-subtle)}.ds-table tbody tr:last-child td{border-bottom:none}.ds-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:24px}.ds-page-title{font-size:24px;font-weight:700;color:var(--ds-text-main);margin:0 0 8px;line-height:1.2}.ds-page-subtitle{font-size:15px;color:var(--ds-text-secondary);margin:0;line-height:1.5}.ds-page-split{display:flex;gap:24px;align-items:flex-start}.ds-page-split>.main-panel{flex:1;min-width:0}.ds-page-split>.side-panel{width:350px;flex-shrink:0;position:sticky;top:24px}@media(max-width:1024px){.ds-page-split{flex-direction:column}.ds-page-split>.side-panel{width:100%;position:static}}.ds-form-field{display:flex;flex-direction:column;gap:0;width:100%}.ds-textarea{box-sizing:border-box;padding:10px 12px;font-size:14px;font-family:inherit;color:var(--ds-text-main);background:#fff;border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);transition:all .2s ease;width:100%;resize:vertical;min-height:96px;line-height:1.6}.ds-textarea::placeholder{color:var(--ds-text-muted)}.ds-textarea:hover{border-color:var(--ds-border-hover)}.ds-textarea:focus{outline:none;border-color:var(--ds-primary);box-shadow:var(--ds-focus-ring)}.ds-form-submitted .ds-textarea:invalid{border-color:var(--ds-danger)!important;background-color:#ef444405!important}.ds-checkbox-label{display:inline-flex;align-items:flex-start;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.ds-checkbox-label:has(input:disabled){opacity:.5;cursor:not-allowed}.ds-checkbox{appearance:none;-webkit-appearance:none;flex-shrink:0;width:18px;height:18px;margin-top:1px;border:2px solid var(--ds-border-hover);border-radius:var(--ds-radius-sm);background:#fff;cursor:pointer;transition:all .15s ease;position:relative}.ds-checkbox:hover{border-color:var(--ds-primary)}.ds-checkbox:focus-visible{outline:none;box-shadow:var(--ds-focus-ring)}.ds-checkbox:checked{background:var(--ds-primary);border-color:var(--ds-primary)}.ds-checkbox:checked:after{content:"";position:absolute;left:3px;top:0;width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}.ds-checkbox-text{display:flex;flex-direction:column;gap:2px}.ds-checkbox-title{font-size:14px;font-weight:500;color:var(--ds-text-main);line-height:1.4}.ds-checkbox-desc{font-size:12px;color:var(--ds-text-secondary);line-height:1.4}.ds-toggle-label{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.ds-toggle-label:has(input:disabled){opacity:.5;cursor:not-allowed}.ds-toggle-track{position:relative;width:40px;height:22px;flex-shrink:0}.ds-toggle-input{position:absolute;opacity:0;width:0;height:0}.ds-toggle-thumb{position:absolute;inset:0;background:#cbd5e1;border-radius:999px;transition:background .2s ease}.ds-toggle-thumb:after{content:"";position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.ds-toggle-input:checked~.ds-toggle-thumb{background:var(--ds-primary)}.ds-toggle-input:checked~.ds-toggle-thumb:after{transform:translate(18px)}.ds-toggle-input:focus-visible~.ds-toggle-thumb{box-shadow:var(--ds-focus-ring)}.ds-toggle-text{display:flex;flex-direction:column;gap:2px}.ds-toggle-title{font-size:14px;font-weight:500;color:var(--ds-text-main);line-height:1.4}.ds-toggle-desc{font-size:12px;color:var(--ds-text-secondary)}.ds-tabs{display:flex;align-items:center}.ds-tabs-underline{border-bottom:1px solid var(--ds-border);gap:0;margin-bottom:24px}.ds-tabs-underline .ds-tab{padding:10px 16px;font-size:14px;font-weight:500;color:var(--ds-text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.ds-tabs-underline .ds-tab:hover{color:var(--ds-text-main)}.ds-tabs-underline .ds-tab.ds-tab-active{color:var(--ds-primary);border-bottom-color:var(--ds-primary);font-weight:600}.ds-tabs-pill{gap:4px;background:var(--ds-bg-subtle);border-radius:var(--ds-radius-lg);padding:4px}.ds-tabs-pill .ds-tab{padding:7px 14px;font-size:13px;font-weight:500;color:var(--ds-text-secondary);background:none;border:none;border-radius:var(--ds-radius-md);cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.ds-tabs-pill .ds-tab:hover{color:var(--ds-text-main);background:#0000000a}.ds-tabs-pill .ds-tab.ds-tab-active{background:#fff;color:var(--ds-primary);font-weight:600;box-shadow:0 1px 3px #0000001a}.ds-tab-icon{display:flex;align-items:center}.ds-tab-badge{font-size:11px;font-weight:700;padding:1px 6px;border-radius:999px;background:var(--ds-primary-light);color:var(--ds-primary)}@keyframes ds-spin{to{transform:rotate(360deg)}}.ds-spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--ds-border);border-top-color:var(--ds-primary);animation:ds-spin .8s linear infinite;flex-shrink:0}.ds-loader-fullpage{height:100%;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.ds-loader-inline{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 24px}.ds-loader-inline .ds-spinner{width:22px;height:22px;border-width:2px}.ds-loader-message{font-size:14px;color:var(--ds-text-secondary);margin:0}.ds-modal-sm{max-width:480px;width:100%}.ds-modal-md{max-width:640px;width:100%}.ds-modal-lg{max-width:800px;width:100%}.ds-modal-xl{max-width:960px;width:100%}.ds-modal-2xl{max-width:1120px;width:100%}.ds-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.ds-badge-success{background:var(--ds-success-bg);color:var(--ds-success-text)}.ds-badge-danger{background:var(--ds-danger-bg);color:var(--ds-danger-text)}.ds-badge-warning{background:var(--ds-warning-bg);color:var(--ds-warning-text)}.ds-badge-info{background:var(--ds-info-bg);color:var(--ds-info-text)}.ds-badge-neutral{background:var(--ds-bg-subtle);color:var(--ds-text-secondary);border:1px solid var(--ds-border)}.ds-badge-primary{background:var(--ds-primary-light);color:var(--ds-primary)}.ds-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:var(--ds-space-8);flex-wrap:wrap}.ds-page-header-left{display:flex;flex-direction:column;gap:4px}.ds-page-header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.csv-step-indicator{display:flex;align-items:center;margin-bottom:32px}.csv-step-item{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px}.csv-step-circle{width:32px;height:32px;border-radius:50%;background:var(--ds-bg-subtle);border:2px solid var(--ds-border);display:flex;align-items:center;justify-content:center;color:var(--ds-text-muted);font-weight:700;font-size:14px;transition:all .2s}.csv-step-circle.active,.csv-step-circle.done{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff}.csv-step-label{font-size:12px;color:var(--ds-text-muted);font-weight:400;text-align:center}.csv-step-label.active{color:var(--ds-primary);font-weight:600}.csv-step-line{flex:1;height:2px;background:var(--ds-border);margin:0 4px 22px;transition:background .2s}.csv-step-line.done{background:var(--ds-primary)}.csv-type-option{flex:1;padding:20px 24px;border-radius:var(--ds-radius-lg);border:2px solid var(--ds-border);background:var(--ds-bg-subtle);cursor:pointer;text-align:left;transition:all .15s}.csv-type-option:hover{border-color:var(--ds-primary)}.csv-type-option.selected{border-color:var(--ds-primary);background:var(--ds-primary-light)}.csv-type-option-title{font-weight:700;font-size:15px;color:var(--ds-text-main);text-transform:capitalize;margin-bottom:4px}.csv-type-option-desc{font-size:13px;color:var(--ds-text-secondary)}.ds-pill-filters{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.ds-pill-filter{padding:6px 16px;border-radius:99px;font-size:13px;border:1px solid var(--ds-border);background:var(--ds-bg-subtle);color:var(--ds-text-secondary);font-weight:400;cursor:pointer;transition:all .15s}.ds-pill-filter:hover{border-color:var(--ds-border-hover)}.ds-pill-filter.active{border-color:var(--ds-primary);background:var(--ds-primary-light);color:var(--ds-primary);font-weight:600}.ds-spin{animation:ds-spin .8s linear infinite}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:13px;font-weight:500;line-height:1.4}.badge-purple{background:#ede9fe;color:#6366f1}.badge-gray{background:var(--ds-bg-subtle);border:1px solid var(--ds-border);color:var(--ds-text-secondary)}.badge-green{background:var(--ds-success-bg);color:var(--ds-success-text)}.badge-red{background:var(--ds-danger-bg);color:var(--ds-danger-text)}.ds-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0;color:var(--ds-text-tertiary);text-align:center;gap:12px}.right-side-button{display:flex;gap:8px;margin-left:70px!important}.date-start-end-button{display:flex;align-items:center;gap:10px}.resume-box{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.resume-box p{margin:0;font-size:14px}.divider{display:flex;align-items:center;text-align:center;font-size:14px;color:#6a7282;font-weight:400}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.divider:before{margin-right:12px}.divider:after{margin-left:12px}.login-right h2{font-size:32px;margin-bottom:20px}.features{margin-top:20px}.features div{margin-bottom:20px}.stats{display:flex;gap:40px;margin-top:40px}.stats strong{font-size:24px;display:block}.input-group{position:relative;display:flex;align-items:center}.input-group input{width:100%;padding:12px 40px 12px 36px;border-radius:8px;border:1px solid #d1d5db}.zemowork-content-layout{background:transparent!important;border:none!important}.zemowork-content-layout .table-wrapper{background:#fff;border-top:1px solid #E2E8F0;box-shadow:0 1px 3px #0000001a}.eye-btn{position:absolute;right:0;background:none;border:none;cursor:pointer;color:#9ca3af}.layout{display:flex;min-height:100vh;overflow:hidden}.sidebar{width:240px;background:#fff;color:#0f172a;border-right:1px solid #E2E8F0;padding:16px 12px 24px!important;position:fixed;top:0;left:0;height:97vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px #0000001a;transition:width .25s ease;display:flex;flex-direction:column}.sidebar.collapsed{width:64px}.sidebar-header{display:flex;align-items:center;gap:10px;padding:12px 40px 12px 12px;overflow:hidden}.title-company{font-weight:600;font-size:14px}.subtitle-company{font-size:12px;color:#94a3b8}.sidebar-toggle{display:flex;align-items:center;justify-content:center;background:transparent;z-index:999;color:#0f172a;cursor:pointer;padding:0;margin:0;position:absolute;top:34px;right:2px;border:unset!important}.sidebar-toggle svg{display:block!important;visibility:visible!important;opacity:1!important;width:22px;height:22px}.nav{display:flex;flex-direction:column;gap:4px;margin-top:10px;overflow-y:visible}.sidebar.collapsed .nav-label,.sidebar.collapsed .menu-title{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.menu-items{margin-left:8px;margin-top:0}.main{margin-left:273px;flex:1;display:flex;flex-direction:column;overflow-x:hidden}.content{padding:20px;flex:1}.sidebar.collapsed~.main{margin-left:97px;width:calc(100% - 97px)}.title{font-size:18px;font-weight:700}.subtitle{font-size:13px;color:#94a3b8}.menu-title{font-family:Inter,sans-serif;font-weight:600;font-size:10px;line-height:16px;letter-spacing:.8px;text-align:left;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;gap:8px;color:#94a3b8;padding:8px 12px 4px;margin-top:12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease}.menu-title:hover{color:#64748b}.nav-item{position:relative;display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:#64748b;font-size:14px;font-weight:500;font-family:Inter,sans-serif;text-decoration:none;transition:background .15s ease,color .15s ease;overflow:hidden}.nav-item:hover{background:#f8fafc;color:#0f172a}.nav-item:hover svg{color:#4f39f6}.nav-item.active{background:#eef2ff;color:#4f39f6;font-weight:600}.nav-item.active svg{color:#4f39f6}.nav-item .active-bar{position:absolute;left:0;top:6px;width:3px;height:calc(100% - 12px);background:transparent;border-radius:0 4px 4px 0;transition:background .15s ease}.nav-item.active .active-bar{background:#4f39f6}.menu-group button{all:unset;cursor:pointer;width:100%;display:flex;justify-content:space-between;padding:8px 12px;color:#1e293b;font-weight:600;font-size:14px;border-radius:8px;transition:background .15s ease}.menu-group button:hover{background:#f1f5f9}.submenu{padding-left:12px;display:flex;flex-direction:column}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar-overlay{display:block;position:fixed;inset:0;background:#0000004d;z-index:98}}.dashboard{width:100%;padding:20px}.page-title{font-size:24px;font-weight:700;color:var(--ds-text-main)}.page-subtitle{color:var(--ds-text-secondary);font-size:14px;font-weight:400;margin-bottom:0;margin-top:4px}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.kpi-card{background:#fff;border-radius:16px;padding:18px;border:1px solid #e2e8f0}.kpi-top{display:flex;justify-content:space-between;margin-bottom:10px}.tag{background:#f1f5f9;padding:4px 10px;border-radius:20px;font-size:12px}.icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.green .icon{background:#dcfce7;color:var(--ds-success-text)}.orange .icon{background:#ffedd5;color:#ea580c}.red .icon{background:#fee2e2;color:var(--ds-danger-hover)}.kpi-value{font-size:28px;font-weight:700}.kpi-label{color:#64748b;margin-bottom:10px}.kpi-footer{font-size:13px;margin-top:10px}.success{color:var(--ds-success-text)}.warn{color:#ea580c}.danger{color:var(--ds-danger-hover)}.nav-divider{height:1px;width:100%;background:#e2e8f0;margin:12px 0}.dashboard-container{padding:24px;background:#f8fafc;min-height:100vh;font-family:Inter,sans-serif}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:25px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:12px}.stat-icon{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center}.green{background:#22c55e1a;color:var(--ds-success)}.orange{background:#f59e0b1a;color:var(--ds-warning)}.red{background:#ef44441a;color:#ef4444}.stat-value{font-size:32px;font-weight:700;color:#1e293b}.stat-label{font-size:14px;color:#64748b}.stat-footer{font-size:13px;margin-top:auto}.green-text{color:var(--ds-success)}.orange-text{color:var(--ds-warning)}.red-text{color:#ef4444}.table-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:20px;box-shadow:0 1px 3px #0000001a}.table-header{display:flex;justify-content:space-between;align-items:center}.table-header h3{font-size:18px;font-weight:600;color:#1e293b}.table-subtitle{font-size:14px;color:#64748b;margin-bottom:16px}.pending-badge{background:#ede9fe;color:#7c3aed;padding:6px 12px;border-radius:999px;font-size:12px}.custom-table{width:100%;border-collapse:collapse;text-transform:uppercase}.custom-table th{font-size:12px;font-weight:600;color:#64748b!important;background:#f8fafc;margin-left:0!important;padding:10px 16px 10px 10px;text-align:left;border-bottom:1px solid #000000}.custom-table td{padding:12px;font-size:14px;color:#1e293b;border-bottom:1px solid #f1f5f9}.paid-yes{background:#22c55e1a;color:var(--ds-success);padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.paid-no{background:#94a3b81a;color:#64748b;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.muted-text{color:#64748b;font-size:14px}.status-badge{background:#f59e0b1a;color:var(--ds-warning);padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.days-text{color:#1e293b;font-size:16px;font-weight:500}.date-text{color:#64748b;font-size:14px;padding:2px}.type-badge{background:#4f39f61a;color:#4f39f6;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700}.type-badge-holiday{display:inline-flex;align-items:center;justify-content:center;background:#4f39f61a;color:#4f39f6;padding:4px 12px;border-radius:999px;font-family:Inter,sans-serif;font-weight:600;font-size:12px;line-height:16px}.action-cell{display:flex;gap:8px}.employee-name{font-size:16px;font-weight:500;color:#1e293b}.table-row td{padding:16px;border-bottom:1px solid #e2e8f0}.custom-table thead{background:#f8fafc;border-bottom:1px solid #000000;height:40.5px}.admin-header{display:flex;align-items:center;justify-content:space-between;height:73px;padding:0 20px;background:#fff;border-bottom:1px solid #e2e8f0;font-family:Inter,sans-serif}.header-left{display:flex;align-items:left;flex-direction:column}.welcome-text{font-family:Inter,sans-serif;font-weight:600;font-size:18px;line-height:28px;color:#1e293b;margin:0}.wave-emoji{display:inline-block;animation:wave 2.5s infinite;transform-origin:70% 70%}@keyframes wave{0%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%{transform:rotate(0)}to{transform:rotate(0)}}.header-right{display:flex;align-items:center;gap:20px}.header-divider{width:1px;height:32px;background-color:#e2e8f0;margin:0 -4px}.user-info{display:flex;align-items:center;gap:10px}.user-group{display:flex;align-items:center;gap:16px}.user-text{text-align:right}.user-name{font-size:14px;font-weight:500;color:#1e293b;line-height:20px}.divider-as-border-left{width:1px;height:36px;background-color:#e2e8f0;margin:0 12px}.user-role{font-size:12px;font-weight:400;color:#64748b;line-height:16px}.avatar{width:40px;height:40px;border-radius:9999px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600;background:linear-gradient(135deg,#4f39f6,#523df7,#5440f8,#5743f9,#5946f9,#5c49fa,#5f4cfb,#624ffc,#6452fd,#6755fd,#6a57fe 90%,#6d5aff);box-shadow:0 4px 6px #0000001a,0 10px 15px #0000001a}.logout-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#64748b;cursor:pointer;transition:all .2s ease;padding:0;margin:0}.logout-btn:hover{background:#fef2f2;color:#ef4444}@media(max-width:768px){.header-left,.user-text,.header-divider{display:none}.header-right{width:100%;justify-content:flex-end;gap:16px}}.header-actions button.btn-primary{margin:0}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}.header-actions button.btn-primary{height:36px;padding:0 16px;border-radius:10px;border:none;background:linear-gradient(135deg,#6366f1,#4f39f6);color:#fff;font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px;cursor:pointer;box-shadow:0 8px 20px #4f39f640}.header-actions .select-field{outline:none;padding:0 0 0 34px;height:42px;cursor:pointer}.list-class-action button{padding:0}.logout-btn:hover{color:#1e293b}.notification-btn{position:relative;margin-right:-10px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#64748b;cursor:pointer;transition:color .2s ease}.notification-btn:hover{color:#1e293b}.notification-badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;border-radius:999px;padding:2px 6px;font-size:11px;min-width:auto;text-align:center}.subtitle-company{font-family:Inter,sans-serif;font-weight:400;font-size:12px;line-height:16px;letter-spacing:0px;color:#64748b;margin:0}.title-company{font-family:Inter,sans-serif;font-weight:700;font-size:20px;line-height:28px;letter-spacing:0px;color:#0f172a;margin:0}.avatar-company{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:16px;color:#fff;font-size:14px;font-weight:600;background:linear-gradient(135deg,#4f39f6,#523df7,#5440f8,#5743f9,#5946f9,#5c49fa,#5f4cfb,#624ffc,#6452fd,#6755fd,#6a57fe,#6d5aff);box-shadow:0 4px 6px -4px #4f39f633,0 10px 15px -3px #4f39f633}.layout{display:flex;min-height:100vh}.header-actions{display:flex;gap:12px;align-items:center}.table{border-radius:16px;overflow:hidden}.table thead{background:#f1f5f9}.table th{color:#64748b;font-size:13px;text-align:left;padding:14px}.table td{padding:16px;border-bottom:1px solid #e2e8f0}.emp-id{color:#64748b;font-weight:500}.email{color:#64748b}.tick-btn,.cross-btn{all:unset;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;transition:.2s ease}.status-absent{color:#ef4444;font-weight:600}.status-late{color:var(--ds-warning);font-weight:600}.status-on-time{color:var(--ds-success);font-weight:600}.tick-btn.success{background:#e7f8ee;color:var(--ds-success-text);box-shadow:0 2px 6px #00000014}.tick-btn.success:hover{background:var(--ds-success-text);color:#fff;transform:scale(1.08)}.cross-btn.danger{background:#fdecec;color:var(--ds-danger-hover);box-shadow:0 2px 6px #00000014}.cross-btn.danger:hover{background:var(--ds-danger-hover);color:#fff;transform:scale(1.08)}.actions{display:flex;gap:10px}.table-actions .edit{color:#6366f1;cursor:pointer;margin-top:20px!important}.table-actions .delete{color:#ef4444;cursor:pointer;margin-top:19px!important;padding:0;margin-left:20px}.actions .edit{color:#6366f1;cursor:pointer}.actions .delete{color:#ef4444;cursor:pointer}.actions .view{color:#64748b;cursor:pointer}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;margin-bottom:16px;padding-right:30px;padding-left:10px}.pagination-text{color:#64748b}.page-btn{padding:6px 14px;border-radius:10px;border:1px solid #E2E8F0;color:#64748b;font-size:14px;cursor:pointer;font-weight:400}.page-btn.active{background:#4f39f6;border-color:#4f39f6}.page-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-controls{display:flex;gap:8px}.pagination-controls button{border:1px solid #e2e8f0;background:#fff;padding:6px 12px;border-radius:10px}.pagination-controls .active{background:#6366f1;color:#fff}.icon-btn{width:36px;height:36px;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer}.icon-btn.edit{color:#4f39f6}.icon-btn.delete{color:#ef4444}.icon-btn.progress{color:#64748b}.page-header{display:flex;flex-direction:column;gap:4px}.filter-btn{width:36px;height:36px;border-radius:8px;border:1px solid #E2E8F0;background:#f8fafc;display:flex;align-items:center;justify-content:center;cursor:pointer}.filter-btn svg{color:#64748b}.select-wrapper select{height:36px;padding:0 12px;border-radius:8px;border:1px solid #E2E8F0;background:#fff;font-size:14px;color:#0f172a}.btn-primary{height:42px!important;padding:0 16px;border-radius:10px;border:none;background:linear-gradient(135deg,#6366f1,#4f39f6);color:#fff;font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px;cursor:pointer;box-shadow:0 8px 20px #4f39f640}.btn-primary-refresh{background:transparent!important;color:#4f39f6!important;border:2px solid #4F39F6!important}.btn-primary-refresh svg{color:#4f39f6!important}.refresh-text{background:#4f39f6;color:#fff;width:59px;height:24px;display:flex;align-items:center;justify-content:center!important;margin-bottom:10px!important;border-radius:999px}.btn-primary-refresh svg{color:#fff;width:16px;height:16px}.filter-btn:hover{background:#f1f5f9}.btn-primary:hover{opacity:.95}.select-wrapper{position:relative;display:inline-block}.select-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.select-field{height:42px;padding:0 36px;border-radius:8px;border:1px solid #E2E8F0;background:#fff;font-size:14px;color:#0f172a;appearance:none}.select-wrapper:after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.table-wrapper{width:100%;height:auto;border-radius:var(--ds-radius-lg);border:1px solid var(--ds-border);box-shadow:0 1px 2px -1px #0000001a,0 1px 3px #0000001a;overflow-x:auto;background:var(--ds-bg-main)}.employee-modal{width:896px!important;max-width:90vw;border-radius:16px;background:#fff;box-shadow:0 25px 50px -12px #00000040}.leave-allocate-modal{width:672px!important;max-width:90vw;border-radius:16px 16px 0 0!important;background:#fff;box-shadow:0 25px 50px -12px #00000040}.add-leave-type{width:576px!important;max-width:90vw;height:auto!important;border-radius:16px 16px 0 0!important;background:#fff;box-shadow:0 25px 50px -12px #00000040}.name-cell{font-family:Inter,sans-serif;font-weight:500;font-size:16px;line-height:24px;color:#1e293b;margin:0}.shift-modal{width:768px!important;height:592px!important;max-width:90vw;border-radius:16px 16px 0 0!important;background:#fff;box-shadow:0 25px 50px -12px #00000040}.department-modal{width:672px!important;height:490px!important;border-radius:16px 16px 0 0!important;background:#fff;box-shadow:0 25px 50px -12px #00000040}.modal-body{flex:1;overflow-y:auto!important;padding:24px;scroll-behavior:smooth!important;flex:1 1 auto;min-height:0}.modal-header-custom h2{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.modal-header-custom p{font-size:14px;color:#64748b}.section{margin-top:28px;margin-bottom:16px}.section h3{font-size:18px;font-weight:600;color:#1e293b}.section-divider{height:2px;background:#4f39f6;margin-top:10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:20px;row-gap:18px}.form-grid-departments{display:grid;grid-template-columns:1fr;gap:16px}.textarea{width:608px;height:118px;padding:10px 16px;background:#f8fafc;border:1px solid #E2E8F0;border-top:1px solid #E2E8F0;border-radius:12px;opacity:1;resize:none;outline:none;box-sizing:border-box;font-size:14px}.form-label-teave-types{font-family:Inter,sans-serif;font-weight:600;font-size:14px;line-height:20px;letter-spacing:0px;margin-bottom:10px;color:#1e293b}.form-input{background:#f8fafc;border:1px solid #E2E8F0;border-top:1px solid #E2E8F0;padding:10px 16px;height:46px;border-radius:12px;font-size:14px;color:#0f172a;width:100%;box-sizing:border-box}.modal-footer{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #E2E8F0;background-color:#f8fafc}.modal-footer-btn{display:flex;gap:12px;justify-content:flex-end;padding:0 20px 16px 0;margin-top:4px}.btn-secondary{background:transparent!important;color:#334155!important;border:1px solid #E2E8F0!important;border-radius:12px!important;padding:10px 18px;width:97px;height:46px;font-family:Inter,sans-serif!important;font-weight:500!important;font-size:16px!important;line-height:24px!important;letter-spacing:0!important;text-align:center!important}.btn-primary{background:#4f39f6!important;color:#fff;border-radius:12px!important;padding:10px 20px;box-shadow:0 10px 15px -3px #4f39f633!important;width:auto;height:46px;font-family:Inter,sans-serif!important;font-weight:500!important;font-size:16px!important;line-height:24px!important;letter-spacing:0!important}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px;z-index:2000}.modal-container{background:var(--panel);border:1px solid var(--border);border-radius:16px;width:896px;max-width:100%;height:auto;max-height:90vh;overflow:hidden!important;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:600;color:#0f172a}.modal-header-custom{display:flex;align-items:flex-start;justify-content:space-between}.modal-header-text h2{margin:0;font-size:18px;font-weight:600;color:#0f172a}.modal-header-text p{margin:4px 0 0;font-size:13px;color:#64748b}.modal-content{flex:1;min-height:0;display:flex;padding:16px 16px 0}.modal-close{background:transparent;border:1px solid var(--border);color:var(--muted);padding:6px 10px;border-radius:6px;cursor:pointer}.modal-header-custom{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.modal-header-text h2{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.modal-header-text p{font-size:14px;color:#64748b}.modal-close-icon{background:transparent;border:none;font-size:20px;color:#64748b;cursor:pointer;padding:4px;line-height:1;transition:.2s}.modal-close-icon:hover{color:#1e293b;transform:scale(1.1)}.form-field{display:grid;gap:6px}.form-label{font-family:Inter,sans-serif;font-weight:600;font-size:14px;line-height:20px;letter-spacing:0px;color:#1e293b}.form-select{background:#f8fafc;border:1px solid #E2E8F0;border-top:1px solid #E2E8F0;padding:10px 16px;height:46px;border-radius:12px;font-size:14px;color:#0f172a;width:100%;box-sizing:border-box}.input-wrapper{position:relative;width:auto}.input-wrapper .form-input{width:100%;padding-right:40px}.input-icon{position:absolute;right:12px;background:transparent;border:none;cursor:pointer;align-items:center;justify-content:center;color:#64748b;margin-top:0!important}.input-icon:hover{color:#0f172a}.rd3t-link{stroke:#000!important;stroke-width:2px;fill:none}svg .custom-link{stroke:#cbd5e1!important;stroke-width:2px;fill:none}.user-count svg circle{stroke:#059669!important}.view-toggle{display:flex;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:4px;gap:4px}.view-toggle-btn{width:32px;height:32px;border-radius:10px;border:none;background:transparent;cursor:pointer;margin-top:0!important}.view-toggle-btn.active{background:#fff;border:none;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px #0000001a}.icon-normal{color:#64748b;transition:color .2s ease;padding:0;margin-top:0!important}.icon-normal-active{color:#4f39f6;padding:0;margin-top:0!important}.btn{border-radius:14px;font-weight:500;border:1px solid transparent;cursor:pointer;margin-top:0}.attendance-filters{display:flex;align-items:center;justify-content:space-between;gap:16px!important;padding:17px!important;border-radius:16px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 3px #0000000f;margin-top:20px;margin-bottom:20px}.attendance-page{padding:20px}.attendance-header{margin-bottom:16px}.attendance-title{font-size:24px;font-weight:700;color:#1e293b}.attendance-subtitle{font-size:14px;color:#64748b}.filters-left,.filters-right{display:flex;align-items:center;gap:10px}.checkbox-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#1e293b}.attendance-flags{display:flex;align-items:center;gap:20px;margin-top:auto}.attendance-date{flex:1}.attendance-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.full-width{grid-column:1 / -1}.date-field{width:100%}.checkbox-item{display:flex;align-items:center;gap:6px}.flags-row{display:flex;gap:20px;align-items:center}.flags-label{font-size:14px;font-weight:500;color:#1e293b}.attendance-flags{display:flex;flex-direction:column;gap:6px}.modal-divider{width:100%;height:1px;background:var(--border);margin:12px 0 16px}.loader-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:12px}.loader-spinner{width:34px;height:34px;border-radius:50%;border:3px solid rgba(79,57,246,.15);border-top:3px solid #4F39F6;animation:spin .8s linear infinite}.loader-text{font-size:13px;color:#64748b;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.loader-spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(79,57,246,.1);border-top:3px solid #4F39F6;box-shadow:0 0 10px #4f39f633;animation:spin .8s linear infinite}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:20px}.attendance-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 2px 6px #0000000a}.attendance-card.status-on-time{border:2px solid #E2E8F0}.attendance-card.status-late,.attendance-card.status-missing-out{border:2px solid #F59E0B33}.attendance-card.status-absent{border:2px solid #EF444433}.card-header-increment{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;margin-top:-18px;border-bottom:2px solid #4F39F6}.card-user{display:flex;gap:10px;align-items:center}.avatar-lg{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#4f39f6,#6d5aff);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.name{font-weight:600;color:#1e293b}.emp-id{font-size:12px;color:#64748b}.status-badge{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600}.time-box{background:#f8fafc;border-radius:12px;padding:12px;margin-bottom:10px}.footer-label{font-size:12px;color:#64748b;font-weight:400;line-height:16px}.footer-value{font-weight:600;color:#1e293b}.card-footer{display:flex;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid #E2E8F0}.hours{font-weight:600}.date{color:#64748b}.attendance-card{background:#fff;border-radius:16px;padding:22px;border-top:2px solid #E2E8F0;box-shadow:0 1px 2px -1px #0000001a,0 1px 3px #0000001a;display:flex;flex-direction:column;gap:16px}.time-left{display:flex;gap:10px;align-items:center}.time-box{background:#f8fafc;border-radius:12px;padding:12px;display:flex;justify-content:space-between}.icon-wrap{width:28px;height:28px;border-radius:12px;display:flex;align-items:center;justify-content:center}.icon-wrap.green{background:#22c55e1a;border:1.33px solid #22C55E;color:#22c55e}.icon-wrap.red{background:#ef44441a;border:1.33px solid #EF4444;color:#ef4444}.label{font-size:12px;color:#64748b}.value{font-weight:600;color:#1e293b}.shift-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.rule-title{padding:0!important;margin:0!important}.rule-card{background:#fff;border-radius:16px;padding:16px;border:2px solid #4F39F633;margin-top:16px;box-shadow:0 1px 3px #0000000f}.rule-card-title{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:12px}.rule-card-title .dot{width:10px;height:10px;border-radius:50%;background:#4f46e5}.status-pill{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.status-pill.active{background:#22c55e1a;color:#22c55e}.status-pill.inactive{background:#ef44441a;color:#ef4444}.row-actions{display:flex;gap:10px}.icon-btn{background:transparent;border:none;cursor:pointer;color:#4f46e5;padding:unset!important}.icon-btn.danger{color:#ef4444}.form-section{display:flex;flex-direction:column;gap:12px}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:14px;color:#1e293b}.employee-select-box{width:auto;border-radius:12px;overflow:hidden}.employee-select-label{background:#fff;padding:0 0 6px;font-weight:600;font-size:14px;color:#1e293b}.employee-select-body{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:12px;margin-bottom:20px}.employee-select-body select{width:100%;min-height:140px}.employee-list{display:flex;flex-direction:column;gap:8px;max-height:178px;overflow-y:auto;padding-top:10px;clip-path:inset(0 round 12px)}.employee-item{width:auto;height:36px;display:flex;align-items:center;gap:12px;padding-left:10px;border-radius:12px;cursor:pointer;transition:.2s}.employee-item:hover{background:#eef2ff}.employee-item.active{background:#e0e7ff}.employee-item input{pointer-events:none}.employee-info{display:flex;flex-direction:column}.employee-name{font-size:14px;font-weight:500;color:#1e293b}.employee-id{font-size:12px;color:#64748b}.leave-types-label{width:608px;height:20px;font-family:Inter,sans-serif;font-weight:600;font-size:14px;line-height:20px;letter-spacing:0px;color:#1e293b;margin-top:12px;margin-bottom:6px}.emp-cell{display:flex;flex-direction:column;gap:2px}.emp-name{color:#1e293b;font-weight:500;font-size:16px;line-height:24px}.emp-id{color:#64748b;font-size:12px;line-height:16px}.year-cell{color:#1e293b;font-size:14px;font-weight:400}.leave-type-pill{display:inline-flex;padding:4px 12px;border-radius:999px;background:#4f39f61a;color:#4f39f6;font-size:12px;font-weight:600}.total-days{color:#1e293b;font-weight:600;font-size:14px}.used-days{color:#f59e0b;font-weight:500;font-size:14px}.remaining-days{color:#22c55e;font-weight:600;font-size:14px;margin-left:30px}.table-actions{display:flex;gap:8px}.btn-icon{padding:6px 10px;border-radius:8px;background:#f1f5f9;border:none;cursor:pointer}.btn-icon.danger{background:#fee2e2;color:#dc2626}.leave-note{background:#eff6ff;border:1px solid #BEDBFF;border-radius:16px;padding:17px;display:flex;align-items:center;margin-bottom:12px;color:#193cb8}.form-group{display:flex;flex-direction:column;gap:6px}.toggle-label{font-size:14px;color:#64748b}.toggle{width:56px;height:28px;border-radius:999px;background:#e2e8f0;position:relative;cursor:pointer;transition:background .2s ease}.toggle.active{background:#4f39f6}.toggle-knob{width:23px;height:22px;background:#fff;border-radius:999px;position:absolute;top:3px;left:3px;transition:all .2s ease}.toggle.active .toggle-knob{left:30px}.emp-id-text{color:#64748b;font-family:Inter,sans-serif;font-weight:500;font-size:14px;line-height:20px}.avatar-gradient{width:40px;height:40px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;background:linear-gradient(135deg,#4f39f6,#523df7,#5440f8,#5743f9,#5946f9,#5c49fa,#5f4cfb,#624ffc,#6452fd,#6755fd,#6a57fe,#6d5aff)}.employee-name{color:#1e293b;font-weight:500;font-size:16px;line-height:24px}.text-regular{color:#1e293b;font-size:14px;line-height:20px}.text-green{color:#22c55e;font-size:14px}.text-red{color:#ef4444;font-size:14px}.net-salary{color:#4f39f6;font-weight:700;font-size:18px;line-height:28px}.date-text-holiday{font-family:Inter,sans-serif;font-weight:400;font-size:14px;line-height:20px;color:#1e293b}.cell-date{display:flex;align-items:center;gap:8px}.icon-calendar{width:14px;height:14px;color:#4f39f6;stroke-width:1.5}.name-text{font-family:Inter,sans-serif;font-weight:500;font-size:16px;line-height:24px;color:#1e293b}.section-title{font-size:20px;font-weight:600;margin-bottom:12px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.form-field label{font-size:13px;font-weight:500;color:#334155;margin-bottom:6px;display:block}.form-field input{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:8px}.kpi-header,.kpi-row{display:grid;grid-template-columns:1fr 120px 40px;gap:10px;align-items:center}.kpi-header{font-size:12px;color:#64748b;margin-bottom:6px}.kpi-row input{padding:8px;border:1px solid #e2e8f0;border-radius:6px}.rule-title-increment{font-family:Inter,sans-serif;font-weight:700;font-size:18px;line-height:28px;color:#1e293b;padding:unset!important;margin:unset!important}.rule-badge{display:inline-flex;align-items:center;padding:8px 16px;border-radius:12px;background:#22c55e1a;border:2px solid #22C55E33}.rule-badge span{font-family:Inter,sans-serif;font-weight:700;font-size:14px;line-height:20px;color:#22c55e}.rule-right{display:flex;align-items:center;gap:24px}.rule-row{display:flex;justify-content:space-between;align-items:center;width:100%;gap:30px}.rule-date-block{display:flex;align-items:flex-end;text-align:right}.rule-date-block .label{font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:#64748b}.rule-date-block .date{font-family:Inter,sans-serif;font-weight:500;font-size:14px;color:#1e293b}.rule-btn{width:176px;height:44px;background:#4f39f6;color:#fff;border-radius:12px;border:none;font-family:Inter,sans-serif;font-weight:600;font-size:14px;box-shadow:0 4px 6px -4px #4f39f633,0 10px 15px -3px #4f39f633;cursor:pointer}.rule-card{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-radius:16px;background:#fff}.rule-left{width:auto;display:flex;flex-direction:column;gap:8px}.rule-meta{display:flex;gap:10px;font-size:12px;margin:8px 0}.increment-rule{align-items:center;justify-content:space-between;gap:16px!important;border-radius:16px;margin-top:20px;margin-bottom:20px}.increment-create-card{background:#fff;padding:24px;border-radius:16px;border:1px solid #e5e7eb}.card-header h2{font-size:18px;font-weight:600;margin-bottom:12px;line-height:28px}.form-label-increment{font-weight:600!important;font-size:14px!important;font-family:Inter,sans-serif;line-height:20px!important;letter-spacing:0px!important;width:386.328125!important;height:20!important;opacity:1!important;color:#1e293b!important}.header-line{height:3px;background:#4f46e5;border-radius:2px;margin-bottom:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-field{display:flex;flex-direction:column}.form-field label{font-size:14px;margin-bottom:6px;font-weight:500}.form-field span{color:#1e293b}.form-field input{height:44px;border-radius:12px!important;border:1px solid #e5e7eb;padding:0 12px;font-size:14px;background:#fff;width:auto}.kpi-section{margin-top:28px}.kpi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.kpi-header h3{font-size:16px;font-weight:600}.add-kpi-btn{background:#4f46e5;color:#fff;border:none;padding:8px 14px;border-radius:20px;cursor:pointer}.kpi-row{display:grid;grid-template-columns:1fr 120px 40px;gap:12px;align-items:center;margin-bottom:15px}.kpi-row input{height:44px;border-radius:10px;border:1px solid #e5e7eb;padding:0 12px}.form-footer{display:flex;justify-content:flex-end;margin-top:24px}.create-btn{background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;padding:12px 22px;border-radius:12px;font-weight:500;cursor:pointer;box-shadow:0 6px 14px #4f46e540;margin-top:0}.rule-card-shift{padding:14px;border-radius:10px;border:1px solid #e2e8f0;margin-bottom:10px;box-shadow:0 1px 2px -1px #0000001a;background-color:#fff;box-shadow:0 1px 3px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.file-upload{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:180px;height:auto;padding:10px 16px;border:2px solid #4F39F6;border-radius:12px;cursor:pointer;background:transparent;transition:all .2s ease}.file-text{font-family:Inter;font-weight:500;font-size:14px;line-height:20px;color:#4f39f6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.file-upload:hover{background:#4f39f60d}.file-upload.has-file{background:#4f39f61a}.employee-cell-docs{display:flex;flex-direction:column;gap:2px}.employee-cell{display:flex;align-items:center;gap:12px}.employee-cell span{width:calc(100% - 52px)!important}.title-cell{display:flex;align-items:center;gap:8px}.title-icon{width:16px;height:16px;color:#4f39f6;stroke-width:1.5}.title-text{font-family:Inter;font-weight:500;font-size:16px;line-height:24px;color:#1e293b}.date-text-docs{font-family:Inter;font-weight:400;font-size:14px;line-height:20px;color:#64748b}.company-feedbacks{width:100%;background:#fff;border-top:1px solid #e2e8f0}.company-feedbacks-header{background:#1e293b;color:#fff;font-size:18px;font-weight:600;padding:10px 16px}.company-table{width:100%;border-collapse:collapse}.company-table thead th{text-align:left;font-size:12px;color:#64748b;font-weight:600;padding:12px 16px;border-bottom:1px solid #e2e8f0}.company-table tbody tr{border-bottom:1px solid #e2e8f0;height:72px}.company-table tbody td{padding:12px 16px}.employee-avatar{width:40px;height:40px;border-radius:9999px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;background:linear-gradient(135deg,#4f39f6,#6d5aff)}.employee-name{color:#1e293b;font-size:16px;font-weight:500}.reviewer-text{color:#64748b;font-size:14px}.badge-period{background:#4f39f6;color:#fff;padding:4px 12px;border-radius:9999px;font-size:12px;font-weight:600}.rating{display:flex;align-items:center;gap:6px}.rating-star{color:var(--ds-warning)}.rating-text{color:#1e293b;font-weight:600;font-size:16px}.date-text{color:#64748b;font-size:14px}.status-badge-review{padding:4px 12px;border-radius:9999px;font-size:12px;font-weight:600}.status-success-review{background:#22c55e1a;color:var(--ds-success)}.status-pending-review{background:#f59e0b1a;color:var(--ds-warning)}.status-info-review{background:#3b82f61a;color:#3b82f6}.feedback-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;margin-top:25px}.feedback-card-header{padding:16px 20px;border-bottom:1px solid #e2e8f0;background:#fff}.feedback-title{font-size:18px;font-weight:600;color:#1e293b}.feedback-empty{padding:20px;font-size:14px;color:#64748b}.feedback-table table{width:100%;border-collapse:collapse}.feedback-table thead th{background:#f8fafc;color:#64748b;font-size:12px;font-weight:600;text-align:left;padding:12px 16px;border-bottom:1px solid #e2e8f0}.feedback-table tbody tr{border-bottom:1px solid #e2e8f0;height:72px}.feedback-table td{padding:12px 16px}.feedback-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;flex-direction:row;align-items:center}.feedback-header-content{display:flex;align-items:center;gap:8px}.feedback-icon{color:#64748b;transition:transform .2s ease}.employee-requests-container{display:flex;flex-direction:column;gap:16px;padding:20px}.employee-request-card{display:flex;justify-content:space-between;align-items:flex-start;padding:20px;border-radius:16px;border:1px solid #e5e7eb;background:#f9fafb}.request-left{flex:1;min-width:0;display:flex;gap:16px;margin-right:unset;padding-right:unset}.request-content{display:flex;flex-direction:column;flex:1;min-width:0}.employee-name{font-weight:600;font-size:16px;padding:unset;margin:unset}.request-to{font-size:13px;color:#6b7280;padding:unset;margin:unset}.request-title{font-size:16px;font-weight:600;margin-top:6px;margin-left:-50px;margin-bottom:unset}.request-description{font-size:14px;color:#6b7280;margin-top:4px;margin-left:-50px;max-width:500px;margin-bottom:unset}.request-actions{margin-top:0;display:flex;gap:10px;margin-left:-50px}.btn-view{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-radius:10px;padding:8px 16px}.request-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.request-date{font-size:13px;color:#6b7280}.status-badge{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:500}.status-badge.pending{background:#fef3c7;color:#d97706}.status-badge.responded{background:#dcfce7;color:var(--ds-success-text)}.status-badge.info{background:#dbeafe;color:#2563eb}.modal-overlay-feedback{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-container-feedback{width:100%;max-width:520px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 10px 30px #0000001a;display:flex;flex-direction:column;gap:16px}.modal-header-feedback{display:flex;flex-direction:column;gap:4px}.modal-title-feedback{font-size:20px;font-weight:600}.modal-subtitle-feedback{font-size:14px;color:#6b7280}.employee-list-feedback{max-height:250px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.employee-item-feedback{display:flex;align-items:center;gap:10px;padding:3px;border-radius:10px;transition:background .2s}.employee-item-feedback:hover{background:#f9fafb}.select-all-feedback{border-bottom:1px solid #e5e7eb;padding-bottom:8px;margin-bottom:4px}.employee-info-feedback{display:flex;align-items:center;gap:10px}.avatar-sm-feedback{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#7c3aed);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center}.modal-textarea-feedback{width:100%;min-height:100px;border:1px solid #e5e7eb;border-radius:10px;padding:10px;resize:none;outline:none}.modal-textarea-feedback:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.modal-actions-feedback{display:flex;justify-content:flex-end;gap:10px}.feedback-form-card{margin-top:16px;padding:20px;border-radius:16px;background:#f9fafb;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:16px}.feedback-form-header{display:flex;align-items:center;gap:12px}.form-title{font-size:18px;font-weight:600}.form-subtitle{font-size:13px;color:#6b7280}.ratings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.rating-item{display:flex;flex-direction:column;gap:4px}.rating-item label{font-size:13px;color:#6b7280;text-transform:capitalize}.form-actions-feedback{display:flex;justify-content:flex-end}.dashboard-section{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.public-holiday-section{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;margin-top:24px}.dashboard-section-header{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.section-header h3{font-size:16px;font-weight:600;margin:unset}.section-header p{font-size:13px;color:#6b7280;margin-bottom:12px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.info-item{background:#f9fafb;padding:12px;border-radius:10px;display:flex;flex-direction:column}.info-item span{font-size:12px;color:#6b7280}.info-item strong{font-size:16px}.leave-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.leave-card{background:#f3f4f6;padding:12px;border-radius:10px;text-align:center}.leave-card strong{font-size:18px;display:block}.calendar-wrapper{margin-top:10px}.attendance-actions{display:flex;justify-content:flex-end;margin-bottom:12px}.attendance-table-wrapper{background:#f9fafb;border-radius:16px;padding:16px;border:1px solid #e5e7eb;margin-bottom:24px}.section-header{margin-bottom:12px}.attendance-history-description,.attendance-history-title{margin:unset;padding:unset}.dashboard-main-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-items:stretch}.table-card-employee{background:#fff;border:1px solid #E2E8F0;border-radius:16px;overflow-x:auto}.table-card-employee-header{padding:16px 20px;background:#fff;border-bottom:1px solid #E2E8F0}.attendance-history-title{font-size:16px;font-weight:600;color:#1e293b}.attendance-history-description{font-size:14px;color:#64748b;margin-top:4px}.table-wrapper-employee table{width:100%;border-collapse:collapse}.table-wrapper-employee{background:transparent}.salary-container{margin-top:20px;display:flex;flex-direction:column;gap:20px}.salary-highlight-card{display:flex;justify-content:space-between;align-items:center;background:#fff;color:#000;border:2px solid #4f39f6;padding:24px;border-radius:16px;box-shadow:0 10px 25px #0000001a}.salary-label{font-size:14px;opacity:.8}.salary-amount{font-size:32px;font-weight:700;margin-top:6px}.salary-badge{background:#fff3;padding:6px 14px;border-radius:999px;font-size:12px;border:1px solid #22c55e;color:var(--ds-success)}.salary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.salary-card{background:#fff;border-radius:14px;padding:18px;box-shadow:0 4px 12px #0000000d;border:1px solid #e5e7eb}.salary-card.green{border-left:4px solid #22c55e}.salary-card.blue{border-left:4px solid #4f39f6}.salary-card.red{border-left:4px solid #ef4444}.salary-card-title{font-size:13px;color:#64748b;margin-bottom:6px}.salary-card-value{font-size:18px;font-weight:600;color:#1e293b}.empty-state{padding:40px;text-align:center;color:var(--ds-text-secondary)}.feedback-actions-bar{display:flex;gap:12px;margin-top:16px}.feedback-view-card{background:#fff;border-radius:14px;margin:12px;padding:16px;border:1px solid #e5e7eb;box-shadow:0 4px 12px #0000000d}.feedback-view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.feedback-details{display:flex;flex-direction:column;gap:12px}.feedback-text-block{background:#f8fafc;padding:10px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.empty-text{color:#94a3b8;font-style:italic}.screenshot-strip{display:flex;gap:6px;overflow-x:auto;max-width:120px;padding:4px 0}.screenshot-img{width:60px;height:40px;object-fit:cover;border-radius:6px;border:1px solid #e2e8f0;cursor:pointer}.fc-daygrid-event-dot{display:none}.fc-event-title{white-space:normal;font-size:20px;color:#1e293b!important;font-weight:700!important;align-items:center!important;margin-top:25px!important}.fc-event{background-color:var(--ds-warning)!important;border:none!important;color:#fff!important;font-weight:500}.fc-event-type{font-size:13px;color:#000;font-weight:700;font-style:italic;margin-top:2px;padding:1px 4px;border-radius:4px;width:fit-content}.fc-daygrid-event{padding:6px 8px!important;font-size:13px;border-radius:6px}.fc-daygrid-block-event{min-height:28px;display:flex;align-items:center}.fc-daygrid-event-harness{margin-bottom:4px}.fc-bg-event{background-color:#f59e0b40!important;opacity:1!important}.dashboard-main-grid-remote{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-items:stretch}.active-filter{background:#98b3eb!important;color:#fff!important;border-color:#2563eb!important;box-shadow:0 0 0 3px #2563eb33;transform:scale(1.05);font-weight:600}.leave-breakdown-wrapper{display:flex;flex-direction:column;gap:12px;min-width:420px}.leave-breakdown-card{border:1px solid #E2E8F0;border-radius:14px;padding:14px;background:#fff}.leave-breakdown-card.not-allocated{opacity:.55;background:#f8fafc}.leave-breakdown-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.leave-name{font-size:14px;font-weight:600;color:#0f172a}.leave-status{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px}.leave-status.active{background:#dcfce7;color:#166534}.leave-status.inactive{background:#e2e8f0;color:#475569}.leave-stats{display:flex;gap:12px}.leave-stat{flex:1;background:#f8fafc;border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:4px}.leave-stat span{font-size:12px;color:#64748b}.leave-stat strong{font-size:16px;color:#0f172a}.leave-breakdown-compact{display:flex;flex-wrap:wrap;gap:8px;max-width:500px}.leave-chip{background:#f8fafc;border:1px solid #E2E8F0;border-radius:10px;padding:8px 10px;min-width:120px}.leave-chip-name{font-size:12px;font-weight:600;color:#0f172a;margin-bottom:2px}.leave-chip-stats{font-size:11px;color:#64748b;display:flex;align-items:center;gap:5px}.separator{opacity:.5}.leave-more-chip{display:flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:10px;background:#eef2ff;color:#4338ca;font-size:12px;font-weight:600}.edit-leave-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:20px}.edit-leave-card{border:1px solid #E2E8F0;border-radius:14px;padding:16px;background:#fff}.edit-leave-card.disabled{opacity:.6;background:#f8fafc}.edit-leave-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;font-weight:600;color:#0f172a}.leave-status{font-size:11px;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#4338ca}.leave-meta-row{display:flex;justify-content:space-between;margin-top:12px;font-size:13px;color:#475569}.leave-meta-row strong{margin-left:4px;color:#0f172a}.not-allocated-text{font-size:13px;color:#94a3b8}.search-wrapper{position:relative;display:flex;align-items:center;gap:8px;height:42px;min-width:260px;padding:0 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s ease}.search-icon{position:absolute;left:12px}.search-wrapper:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.search-wrapper svg{flex-shrink:0;color:#64748b}.search-clear-btn{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:#6b7280;padding:0;margin:unset!important}.search-clear-btn:hover{color:#111827}.search-field{flex:1;padding-left:36px;padding-right:36px;border:none;outline:none;background:transparent;font-size:14px;font-weight:500;color:#1e293b}.search-field::placeholder{color:#94a3b8;font-weight:400}.employee-search-feedback{margin-bottom:14px}.employee-search-feedback input{width:100%}.employee-empty-feedback{padding:16px;text-align:center;color:#64748b;font-size:14px}@media(max-width:768px){.sidebar{width:240px;position:fixed;left:-240px;z-index:1000;height:97vh;transform:none!important;transition:left .3s ease}.sidebar:not(.collapsed){left:0!important;transform:none!important}.sidebar.collapsed{width:0!important;padding:0!important;border-right:none!important;left:-240px!important;transform:none!important}.sidebar-toggle{position:fixed!important;left:16px!important;top:18px!important;right:auto!important;z-index:1001!important;background:#fff!important;border:1px solid #E2E8F0!important;border-radius:8px!important;padding:8px!important;box-shadow:0 1px 3px #0000001a!important}.sidebar:not(.collapsed) .sidebar-toggle{position:absolute!important;right:12px!important;left:auto!important;top:18px!important;z-index:1001!important;background:#fff!important;border:1px solid #E2E8F0!important;border-radius:8px!important;padding:8px!important;box-shadow:none!important}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.admin-header{padding-left:64px!important}.main{margin-left:0!important;width:100%!important}.sidebar.collapsed~.main{margin-left:0!important;width:100%!important}.stats-grid,.kpi-grid,.dashboard-main-grid,.dashboard-main-grid-remote,.info-grid,.form-grid,.ratings-grid{grid-template-columns:1fr!important}.leave-grid{grid-template-columns:1fr!important;gap:8px!important}.textarea{width:100%!important;max-width:100%!important}.leave-breakdown-wrapper{min-width:unset!important;max-width:100%!important}.content{padding:12px!important}}.request-actions .form-field{flex:1}.request-actions .input-wrapper,.request-actions .form-input{width:100%}.form-grid-twoCols{display:grid;grid-template-columns:1fr 1fr;column-gap:20px;row-gap:18px}.vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:20px}.vault-folder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:180px;padding:24px 16px;border:1px solid #E2E8F0;border-radius:16px;background:#fff;box-shadow:0 1px 3px #0000000f;cursor:pointer;transition:all .2s ease;text-align:center}.vault-folder:hover,.vault-folder:focus-visible{border-color:#4f39f6;background:#4f39f60a;box-shadow:0 4px 12px #4f39f61f;outline:none}.folder-icon{display:flex;align-items:center;justify-content:center;color:#4f39f6;margin-bottom:4px}.folder-name{font-family:Inter,sans-serif;font-weight:600;font-size:16px;line-height:24px;color:#0f172a;word-break:break-word}.folder-meta{font-family:Inter,sans-serif;font-weight:400;font-size:14px;line-height:20px;color:#64748b}.folder-count{font-family:Inter,sans-serif;font-weight:500;font-size:13px;line-height:18px;color:#4f39f6;margin-top:4px}.docs-back-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 0;margin-bottom:12px;border:none;background:transparent;font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#4f39f6;cursor:pointer}.docs-back-btn:hover{color:#6366f1}.docs-folder-header{margin-bottom:8px}.docs-folder-title{font-family:Inter,sans-serif;font-weight:600;font-size:20px;line-height:28px;color:#0f172a;margin:0}.docs-folder-meta{font-family:Inter,sans-serif;font-size:14px;color:#64748b;margin:4px 0 0}.docs-empty-state{padding:40px 20px;text-align:center;font-family:Inter,sans-serif;font-size:14px;color:#64748b}.doc-type{display:inline-block;padding:4px 10px;border-radius:6px;font-family:Inter,sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;background:#f1f5f9;color:#475569}.doc-type.pdf{background:#fee2e2;color:#b91c1c}.doc-type.image{background:#dbeafe;color:#1d4ed8}.doc-type.doc{background:#e0e7ff;color:#4338ca}.doc-type.xls{background:#d1fae5;color:#047857}.increment-modal .kpi-table{margin-top:12px;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.increment-modal .kpi-table-header{display:grid;grid-template-columns:1fr 180px 70px;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border-bottom:1px solid #e5e7eb;font-size:13px;font-weight:600;color:#475467}.increment-modal .kpi-table-row{display:grid;grid-template-columns:1fr 180px 70px;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #f1f5f9}.increment-modal .kpi-table-row:last-child{border-bottom:none}.increment-modal .kpi-table-row input{width:auto;margin:0}.increment-modal .kpi-table-row .icon-btn{justify-self:center}.error-field input,.error-field select,.error-field{border:1px solid #ef4444!important;box-shadow:0 0 0 2px #ef444426}
