@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box}body{font-family:Inter,sans-serif;background:#fff;color:#0f172a;margin:0}a{text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;border-right:1px solid #e5e7eb;background:#fff;position:fixed;left:0;top:0;bottom:0;padding:14px 12px;z-index:10}.brand-box{display:flex;align-items:center;gap:10px;min-height:60px;margin:0 -18px 14px;padding:0 18px 14px;border-bottom:1px solid #e5e7eb!important}.brand-icon{width:28px;height:28px;background:linear-gradient(135deg,#475569,#ef5b3e);color:#fff;display:grid;place-items:center;font-weight:800;border-radius:7px}.brand-box h4{margin:0;line-height:1;font-size:21px;font-weight:800}.brand-box h4 span{color:#e85539}.brand-box small{color:#9ca3af;font-size:11px}.menu-title{color:#111827;font-size:14px;margin:18px 10px 10px;font-weight:500}.side-menu{display:flex;flex-direction:column;gap:4px}.menu-link{display:flex;align-items:center;gap:13px;height:40px;padding:0 12px;border-radius:8px;color:#111827;text-decoration:none;font-size:15px;transition:.2s}.menu-link span{color:#0f172a;font-size:17px;min-width:17px}.menu-link b{font-weight:500}.menu-link:hover,.menu-link.active{background:#fff0ec;color:#e85539}.menu-link:hover span,.menu-link.active span{color:#e85539}.main-area{margin-left:240px;width:calc(100% - 240px);min-height:100vh;display:flex;flex-direction:column}.topbar{height:74px;border-bottom:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:9}.sidebar-toggle{width:42px;height:38px;border:0;border-radius:7px;background:#f8fafc;color:#111827}.topbar-right{display:flex;align-items:center;gap:18px}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}.topbar-user-info strong{font-size:14px;color:#111827}.topbar-user-info small{font-size:12px;color:#e85539;font-weight:600}.notification-wrap{position:relative}.notification-btn{border:0;background:transparent;font-size:18px;position:relative}.notification-btn em{position:absolute;top:-6px;right:-7px;background:#ef4444;color:#fff;font-style:normal;font-size:10px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center}.notification-dropdown{position:absolute;right:0;top:42px;width:360px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 15px 35px #0f172a14;display:none}.notification-dropdown.show{display:block}.notification-item{display:flex;gap:12px;padding:15px;border-bottom:1px solid #e5e7eb}.notification-item h6{margin:0 0 3px;font-size:14px}.notification-item p{margin:0;font-size:13px}.notification-item small{color:#6b7280}.notification-footer{text-align:center;color:#e85539;padding:14px;font-size:14px}.avatar-sm,.profile-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#0ea5e9,#14b8a6);font-weight:700}.avatar-sm.green{background:linear-gradient(135deg,#22c55e,#16a34a)}.profile-avatar{width:36px;height:36px}.content-area{flex:1;padding:38px 22px 20px}.page-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:26px}.page-head h1{font-size:26px;font-weight:500;margin:0 0 5px;letter-spacing:-.5px;display:inline-flex;align-items:center;gap:8px}.page-head h1 i{color:#e85539;font-size:28px}.page-head p{font-size:15px;color:#111827;margin:0}.action-btn{background:#e85539!important;border-color:#e85539!important;border-radius:6px;padding:9px 20px;font-weight:500;display:inline-flex;align-items:center;gap:8px}.action-btn:hover{background:#d7462b!important;border-color:#d7462b!important;color:#fff!important;transform:translateY(-2px)}.action-btn:focus,.action-btn:active{background:#c93d24!important;border-color:#c93d24!important;color:#fff!important}.tool-row{display:flex;justify-content:space-between;gap:12px;margin-bottom:16px}.search-box{position:relative;width:100%;max-width:360px}.search-box i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#667085;font-size:15px;pointer-events:none}.search-input{width:260px;height:40px;border-radius:5px;border-color:#d7dbe1;font-size:14px}.search-box .search-input{padding-left:42px}.tool-actions{display:flex;gap:8px}.tool-actions .btn{height:40px;min-width:78px;border-radius:5px;font-size:14px;display:inline-flex;align-items:center;gap:8px}.data-card{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;background:#fff}.custom-table{margin:0}.custom-table thead th{background:#f2f2f2;font-weight:500;color:#111827;font-size:14px;border-bottom:1px solid #e5e7eb;padding:11px 12px;white-space:nowrap;vertical-align:middle}.custom-table th i{margin-right:6px;color:#667085;font-size:14px}.custom-table tbody td{padding:10px 12px;vertical-align:middle;font-size:14px;color:#111827;border-bottom:1px solid #e5e7eb}.table-user{display:flex;align-items:center;gap:12px}.product-img{width:40px;height:40px;border-radius:5px;background:#f1f5f9;color:#e85539;display:grid;place-items:center;font-weight:800}.table-user .emp-name{display:block;font-weight:600;color:#111827}.table-user small{display:block;color:#64748b;font-size:12px;margin-top:2px}.icon-btn{border:0;background:transparent;color:#334155;font-size:14px;margin-right:10px}.icon-btn.danger{color:#ef4444}.badge-soft{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-soft.success{background:#eafaf1;color:#16a34a}.badge-soft.danger{background:#fff1f2;color:#e11d48}.badge-soft.warning{background:#fff7ed;color:#ea580c}.badge-soft.info{background:#eff6ff;color:#2563eb}.table-footer{min-height:48px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center}.table-footer span{display:inline-flex;align-items:center;gap:8px}.table-footer span i{color:#e85539}.pagination-box{display:flex;align-items:center}.page-btn{min-width:34px;height:34px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-size:14px;padding:0 12px}.page-btn:first-child{border-radius:6px 0 0 6px}.page-btn:last-child{border-radius:0 6px 6px 0}.page-btn.active{background:#e85539;color:#fff;border-color:#e85539}.page-btn:disabled{background:#eee;color:#6b7280}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px}.mini-card{min-height:132px;border:1px solid;border-radius:6px;padding:24px;display:flex;gap:18px;align-items:center}.mini-card.red{background:#fff3ef;border-color:#fecaca}.mini-card.green{background:#edfff4;border-color:#bbf7d0}.mini-card.blue{background:#ecfeff;border-color:#a5f3fc}.mini-card.yellow{background:#fffbeb;border-color:#fde68a}.card-icon{width:40px;height:40px;border-radius:7px;background:#e85539;color:#fff;display:grid;place-items:center}.mini-card.green .card-icon{background:#22c55e}.mini-card.blue .card-icon{background:#06b6d4}.mini-card.yellow .card-icon{background:#eab308}.mini-card p{margin:0 0 8px;font-size:14px}.mini-card h2{margin:0;font-weight:800;font-size:28px}.mini-card small{color:#22c55e;font-size:13px}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.summary-card{border:1px solid #e5e7eb;border-radius:6px;min-height:170px;padding:24px;position:relative}.summary-card h2{font-size:25px;font-weight:800}.summary-card p{margin:0}.summary-card span{position:absolute;top:28px;right:28px;color:#e85539;font-size:24px}.summary-card a{float:right;color:#e85539;font-size:13px}.dashboard-panel{border:1px solid #e5e7eb;border-radius:6px;min-height:340px}.panel-head{padding:18px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between}.panel-head h5{margin:0}.panel-head select{width:130px}.chart-placeholder{height:260px;padding:35px 45px 20px;display:flex;align-items:flex-end;gap:28px}.bar{width:34px;background:#e85539;border-radius:4px 4px 0 0}.bar.h1{height:90px;opacity:.6}.bar.h2{height:140px}.bar.h3{height:110px;opacity:.6}.bar.h4{height:170px}.bar.h5{height:120px;opacity:.6}.bar.h6{height:190px}.bar.h7{height:150px}.footer-text{text-align:center;color:#4b5563;padding:25px;font-size:14px}.footer-text span{color:#e85539}.auth-bg{background:#f8fafc;min-height:100vh;display:grid;place-items:center}.install-card,.login-card{width:480px;background:#fff;border-radius:14px;padding:34px;box-shadow:0 20px 45px #0f172a14}.login-card{width:420px}.install-logo{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#475569,#ef5b3e);color:#fff;display:grid;place-items:center;font-size:25px;font-weight:800;margin:0 auto 15px}.install-card h3,.login-card h3{font-weight:800;margin-bottom:5px}.install-card p,.login-card p{color:#6b7280;margin:0}.install-btn{height:44px;background:#e85539!important;border-color:#e85539!important}.form-control,.form-select{border-color:#d7dbe1;min-height:40px;font-size:14px}.form-control:focus,.form-select:focus{border-color:#e85539;box-shadow:0 0 0 .2rem #e855391f}.modal-title,.form-label{display:inline-flex;align-items:center;gap:8px}.modal-title i{color:#e85539}.form-label{font-weight:600;color:#344054}.form-label i{color:#667085;font-size:14px}.modal-footer .btn{display:inline-flex;align-items:center;gap:7px}.employee-modal-header{background:linear-gradient(135deg,#fff7f4,#fff);border-bottom:1px solid #f1d7d0}.employee-modal-header h5{color:#111827;font-weight:700}.employee-modal-header small{color:#6b7280;font-size:13px}.form-section-title{display:flex;align-items:center;gap:8px;background:#fff3ef;color:#e85539;border:1px solid #ffd7ce;border-left:4px solid #e85539;border-radius:8px;padding:10px 14px;margin-bottom:16px;font-weight:700;font-size:15px}.default-password-check{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;padding:12px 14px 12px 38px}.default-password-check label{font-weight:600;color:#111827}.default-password-check label span{display:block;color:#64748b;font-size:12px;font-weight:400;margin-top:3px}.input-icon-box{position:relative}.input-icon-box .form-control{padding-left:42px;height:48px}.input-icon{position:absolute;top:50%;left:14px;transform:translateY(-50%);color:#7b7b7b;font-size:16px;z-index:2}.password-box .form-control{padding-right:48px}.password-eye-btn{position:absolute;top:50%;right:12px;transform:translateY(-50%);border:none;background:transparent;color:#666;font-size:18px;cursor:pointer;z-index:3}.password-eye-btn:hover{color:#0d6efd}.form-check-label{cursor:pointer;font-size:14px}@media(max-width:992px){.sidebar{width:70px}.brand-box div:not(.brand-icon),.menu-title,.menu-link b{display:none}.main-area{margin-left:70px;width:calc(100% - 70px)}.stats-grid,.summary-grid{grid-template-columns:1fr}.tool-row{flex-direction:column}.search-input{width:100%}.attendance-action-grid{grid-template-columns:1fr}.topbar-user-info{display:none}}.attendance-action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.attendance-clock-btn{border:1px solid #e5e7eb;border-radius:12px;min-height:115px;background:#fff;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:22px;transition:.2s ease}.attendance-clock-btn i{font-size:26px;margin-bottom:8px}.attendance-clock-btn span{font-size:18px;font-weight:700}.attendance-clock-btn small{font-size:13px;color:#64748b}.attendance-clock-btn.clock-in{background:#ecfdf5;border-color:#bbf7d0;color:#16a34a}.attendance-clock-btn.break{background:#fffbeb;border-color:#fde68a;color:#ca8a04}.attendance-clock-btn.clock-out{background:#fff1f2;border-color:#fecdd3;color:#e11d48}.attendance-clock-btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px #0f172a14}.break-duration-box{line-height:1.5;font-size:13px;min-width:130px}.break-duration-box span{display:block;color:#334155;white-space:nowrap}.break-duration-box strong{display:block;margin-top:4px;color:#e85539;white-space:nowrap}@media(max-width:768px){.attendance-action-grid{grid-template-columns:1fr}}.badge-soft.secondary{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#eef2f7;color:#475569;font-size:12px;font-weight:600}.badge-soft.success{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#dcfce7;color:#15803d;font-size:12px;font-weight:600}.badge-soft.warning{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#fef3c7;color:#b45309;font-size:12px;font-weight:600}.badge-soft.danger{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#fee2e2;color:#b91c1c;font-size:12px;font-weight:600}.leave-modal-dialog{max-width:620px}.leave-request-modal{border-radius:18px;overflow:hidden}.leave-date-box{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;border:1px solid #e5e7eb;border-radius:14px;padding:16px;background:#fff}.leave-date-item span{display:block;color:#6b7280;font-size:13px;margin-bottom:4px}.leave-date-input{border:0;padding:0;font-weight:700;box-shadow:none!important}.leave-days-pill{padding:10px 18px;border:1px solid #e5e7eb;border-radius:10px;font-weight:700;background:#f9fafb}.leave-type-dropdown{position:relative}.leave-type-selected{width:100%;border:1px solid #d1d5db;background:#fff;border-radius:12px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;font-weight:600}.leave-type-menu{display:none;position:absolute;z-index:1056;width:100%;background:#fff;border:1px solid #d1d5db;border-radius:12px;overflow:hidden;max-height:310px;overflow-y:auto;box-shadow:0 20px 40px #0f172a26}.leave-type-menu.show{display:block}.leave-type-option{display:flex;justify-content:space-between;align-items:center;gap:15px;padding:14px 16px;cursor:pointer;border-bottom:1px solid #f1f5f9}.leave-type-option:hover,.leave-type-option.active{background:#edf7e8}.leave-option-title{font-weight:700}.leave-type-option small{color:#6b7280}.leave-mode-box{display:flex;gap:10px}.leave-mode{border:1px solid #e5e7eb;background:#f3f4f6;border-radius:8px;padding:9px 18px;cursor:pointer;font-weight:600}.leave-mode input{display:none}.leave-mode.active{background:#fff;border-color:#9ca3af;box-shadow:0 2px 8px #0f172a1f}.leave-info-line{display:flex;align-items:center;gap:8px;color:#4b5563;font-size:14px}.credit-preview-box{display:grid;grid-template-columns:1fr 1fr;gap:12px}.credit-preview-box div{border:1px solid #e5e7eb;background:#f9fafb;border-radius:12px;padding:14px}.credit-preview-box span{display:block;color:#6b7280;font-size:13px}.credit-preview-box strong{font-size:24px;color:#111827}.action-wrap{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}.icon-btn.success{color:#16a34a;background:#16a34a1f}.icon-btn.success:hover{color:#fff;background:#16a34a}.icon-btn.danger{color:#dc2626;background:#dc26261f}.icon-btn.danger:hover{color:#fff;background:#dc2626}.badge-soft.secondary{background:#eef2f7;color:#475569}.badge-soft.success{background:#dcfce7;color:#15803d}.badge-soft.warning{background:#fef3c7;color:#b45309}.badge-soft.danger{background:#fee2e2;color:#b91c1c}.notify-multi-select{position:relative;width:100%}.notify-selected-box{min-height:48px;border:1px solid #d8dee9;border-radius:12px;background:#fff;padding:7px 10px;display:flex;align-items:center;flex-wrap:wrap;gap:6px;cursor:pointer}.notify-placeholder{color:#8b95a7;font-size:14px}.notify-chip{display:inline-flex;align-items:center;gap:6px;background:#eef4ff;color:#1d4ed8;border:1px solid #bfdbfe;padding:5px 8px;border-radius:999px;font-size:13px;font-weight:600}.notify-chip button{border:0;background:transparent;color:#1d4ed8;padding:0;display:inline-flex;align-items:center;cursor:pointer}.notify-dropdown{position:relative;left:0;right:0;top:calc(100% + 6px);z-index:9999;display:none;background:#fff;border:1px solid #d8dee9;border-radius:14px;box-shadow:0 16px 40px #0f172a29;padding:10px}.notify-dropdown.show{display:block}.notify-search{margin-bottom:8px;border-radius:10px}.notify-options{max-height:230px;overflow-y:auto}.notify-option{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:10px;cursor:pointer;transition:.2s ease}.notify-option:hover{background:#f3f6fb}.notify-option input{width:16px;height:16px}.notify-option span{display:flex;flex-direction:column;line-height:1.2}.notify-option strong{font-size:14px;color:#111827}.notify-option small{font-size:12px;color:#6b7280}.notify-no-data{padding:14px;text-align:center;color:#6b7280;font-size:14px}.notify-table-list{min-width:160px;max-width:230px;white-space:normal;color:#334155;font-size:13px}.dashboard-notify-card{background:#fff;border-radius:18px;padding:18px;border:1px solid #edf0f7;box-shadow:0 10px 30px #0f172a14}.dashboard-notify-head{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:15px}.dashboard-notify-head h4{margin:0;font-size:18px;font-weight:800;color:#111827}.dashboard-notify-head p{margin:3px 0 0;color:#6b7280;font-size:13px}.dashboard-notify-head span{min-width:34px;height:34px;padding:0 10px;border-radius:999px;background:#2563eb;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800}.leave-notify-list{display:flex;flex-direction:column;gap:12px}.leave-notify-item{display:flex;gap:12px;padding:14px;border-radius:14px;background:#f8fafc;border:1px solid #edf0f7}.leave-notify-icon{width:42px;height:42px;flex:0 0 42px;border-radius:12px;background:#e0f2fe;color:#0369a1;display:flex;align-items:center;justify-content:center;font-size:18px}.leave-notify-body h5{margin:0 0 4px;font-size:15px;font-weight:800;color:#111827}.leave-notify-body p{margin:0 0 4px;font-size:13px;color:#334155}.leave-notify-body small{color:#64748b;font-size:12px}.leave-notify-reason{margin-top:8px;padding:8px 10px;border-radius:10px;background:#fff;color:#334155;font-size:13px}.empty-notify{padding:22px;border-radius:14px;background:#f8fafc;color:#64748b;text-align:center;font-size:14px}.pagination-box{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}.page-btn{min-width:34px;height:34px;border:1px solid #e2e8f0;background:#fff;color:#334155;border-radius:8px;font-size:13px;font-weight:700;padding:0 10px;transition:.2s ease}.page-btn:hover:not(:disabled){background:#fff3ef;border-color:#ff5a3c;color:#e85539}.page-btn.active{background:#e85539;border-color:#e85539;color:#fff}.page-btn:disabled{opacity:.45;cursor:not-allowed}.page-dots{min-width:38px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:#64748b;font-size:13px;font-weight:700}.holiday-top-actions{display:flex;align-items:center;gap:10px}.holiday-top-actions .btn{display:inline-flex;align-items:center;gap:7px}.holiday-year-card{border:1px solid #e5e7eb;background:#fff;border-radius:10px;padding:12px 14px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.holiday-year-title{display:inline-flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:#111827}.holiday-year-title i{color:#e85539}.holiday-title-cell{display:inline-flex;align-items:center;gap:8px;font-weight:600}.holiday-title-cell i{color:#e85539}@media(max-width:768px){.holiday-top-actions{flex-direction:column;align-items:stretch}.holiday-year-card{flex-direction:column;gap:10px}.holiday-year-title{font-size:20px}}
