*{margin:0;padding:0;box-sizing:border-box}.app-header{position:fixed;top:0;left:0;right:0;height:calc(50px + var(--safe-top));padding-top:var(--safe-top);padding-left:16px;padding-right:16px;display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E2E8F0;z-index:9000}.header-logo-wrapper{display:flex;align-items:center}.header-logo{height:32px;width:auto}.header-right{margin-left:auto;display:flex;align-items:center;gap:14px}.header-icon{cursor:pointer;color:#1e293b}.notif-wrapper{position:relative;padding:4px;border-radius:50%}.notif-badge{position:absolute;top:-2px;right:-2px;background:#991b1b;color:#fff;font-size:10px;font-weight:700;padding:2px 5px;border-radius:999px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:calc(56px + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:flex;justify-content:space-between;align-items:center;background:#fff;border-top:1px solid #e2e8f0;z-index:9999;isolation:isolate;transform:translateZ(0);backface-visibility:hidden;will-change:transform}.nav-item{flex:1;text-decoration:none;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 0;position:relative;color:#64748b;font-size:12px}.nav-item svg{stroke:#64748b}.nav-item.active{color:#0369a1;font-weight:600}.nav-item.active svg{stroke:#0369a1;transform:scale(1.12)}.nav-active-indicator{position:absolute;bottom:-2px;width:28px;height:3px;background:#0369a1;border-radius:10px;opacity:0;transform:translateY(6px);transition:.2s ease}.nav-item.active .nav-active-indicator{opacity:1;transform:translateY(0)}.nav-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center}.nav-label{margin-top:2px}.sb-overlay{position:fixed;inset:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:900}.sb-overlay.show{opacity:1;pointer-events:auto}.sb-drawer{position:fixed;padding-top:30px!important;left:-260px;top:0;height:100%;width:250px;background:#fff;border-top-right-radius:20px;border-bottom-right-radius:20px;padding:22px 18px;transition:left .28s ease;z-index:9999;display:flex;flex-direction:column}.sb-drawer.open{left:0}.sb-profile{display:flex;align-items:center;gap:12px}.sb-avatar{width:46px;height:46px;border-radius:50%;background:#e2e8f0;object-fit:cover}.sb-user-info h3{margin:0;font-size:12px;color:#111827;font-weight:600}.sb-user-info p{margin:0;font-size:10px;color:#6b7280}.sb-divider{height:1px;background:#e5e7eb;margin:6px 0}.sb-menu{display:flex;flex-direction:column;gap:4px}.sb-item{width:100%;display:flex;align-items:center;gap:12px;background:transparent;padding:10px 2px;border:none;font-size:12px;font-weight:500;color:#1f2937;cursor:pointer;text-align:left;transition:.2s ease}.sb-item:hover{background:#f3f4f6;border-radius:8px}.sb-logout{width:100%;display:flex;align-items:center;gap:12px;padding:8px 2px;background:transparent;border:none;font-size:13px;font-weight:500;color:#dc2626;cursor:pointer}.sb-logout:hover{background:#fee2e2;border-radius:8px}.sb-profile{display:flex;justify-content:space-between;align-items:center;padding:5px 10px}.sb-user-info h3{font-size:12px;font-weight:700;margin:0}.sb-user-info p{margin:2px 0 0;font-size:10px;color:#64748b}.sb-user-icon{width:44px;height:44px;background:#e2e8f0;border-radius:50%;display:flex;justify-content:center;align-items:center;color:#1e293b}.notif-dropdown{position:fixed;top:56px;right:12px;width:280px;max-height:290px;background:#fff;border-radius:14px;box-shadow:0 12px 30px #0000001f;overflow:hidden;z-index:9999;display:flex;flex-direction:column}.notif-dropdown-header{padding:12px 14px;font-size:14px;font-weight:600;color:#111;border-bottom:1px solid #eee}.notif-list{overflow-y:auto;flex:1}.notif-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid #f1f1f1;transition:background .2s ease}.notif-item:hover{background:#f8f9fb}.notif-item.unread{background:#eef5ff}.notif-title{font-size:13px;font-weight:600;color:#111;margin-bottom:2px}.notif-msg{font-size:12px;color:#555;line-height:1.4}.notif-date{font-size:11px;color:#999;margin-top:4px;display:block}.notif-empty{padding:20px;text-align:center;font-size:13px;color:#777}.notif-footer{padding:12px;text-align:center;font-size:13px;font-weight:600;color:#1976d2;background:#fafafa;cursor:pointer;border-top:1px solid #eee}.notif-footer:hover{background:#f1f5fb}.layout-wrapper{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.layout-content{flex:1;overflow-y:auto;padding-top:calc(50px + var(--safe-top));padding-bottom:calc(56px + var(--safe-bottom));background:#f8fafc}.welcome-screen{display:flex;flex-direction:column;justify-content:space-between;align-items:center;height:100%;padding:40px;background:#fff}.welcome-logo-section{display:flex;flex-direction:column;align-items:center;margin-top:80px}.welcome-logo{width:250px;height:auto;margin-bottom:18px}.welcome-app-name{font-size:15px;font-weight:500;color:#000;text-align:center;margin-bottom:130px}.welcome-center-img{width:70%;max-width:320px;margin-top:18px;animation:fadeInUp .8s ease-in-out}.welcome-features{display:flex;justify-content:space-between;margin-top:60px;width:100%;padding:0 10px 80px}.welcome-feature-item{display:flex;flex-direction:column;align-items:center;font-size:13px;text-align:center;color:#555}.feature-icon{width:55px;height:55px;margin-bottom:6px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}:root{--bg: #F8FAFC;--card-bg: #ffffff;--glass: rgba(255,255,255,.6);--primary: #0a74ff;--primary-dark: #0b5ed7;--muted: #64748B;--text-dark: #0F1724;--border: #E2E8F0;--success: #059669;--danger: #DC2626;--radius: 14px;--radius-sm: 10px;--shadow-sm: 0 3px 12px rgba(2,6,23,.06);--shadow-md: 0 8px 28px rgba(2,6,23,.08);--space-xs: 4px;--space-s: 8px;--space-m: 12px;--space-l: 16px;--space-xl: 24px;--transition: .22s cubic-bezier(.2,.9,.2,1);--container-width: 760px}.admin-dashboard{min-height:100%;background:var(--bg);padding:10px;color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.admin-container{max-width:var(--container-width);margin:0 auto}.page-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-m);gap:6px;background-color:#fff;padding:10px;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 6px 18px #0a74ff0f}.adminpage-title{font-size:18px;font-weight:700;color:var(--text-dark);margin:0}.page-subtitle{font-size:12px;color:var(--muted);margin:0;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.tiles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:20px}.admin-tile{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:14px;transition:transform var(--transition),box-shadow var(--transition);cursor:default;min-height:86px;display:flex;align-items:center;justify-content:center}.admin-tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}.tile-inner{width:100%;display:flex;flex-direction:column;gap:6px;align-items:center}.tile-title{font-size:13px;color:var(--text-dark);margin:0;font-weight:600;text-align:center}.tile-value{font-size:20px;font-weight:600;color:var(--muted);margin:0;text-align:center}.admin-section-title{font-size:18px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 6px 18px #0a74ff0f}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-bottom:32px}.admin-action-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition);cursor:pointer;text-decoration:none;color:inherit;min-height:110px}.admin-action-card:hover,.admin-action-card:focus{transform:translateY(-6px);box-shadow:var(--shadow-md);outline:none}.admin-icon-circle{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#0ea5e914,#0a74ff0f);color:var(--primary);font-weight:700;box-shadow:0 6px 18px #0a74ff0f}.action-title{font-size:10px;color:var(--text-dark);text-align:center;margin:0}.admin-action-card:active{transform:translateY(-2px) scale(.995)}.ea-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.ea-modal{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.ea-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.ea-header h3{margin:0;font-size:16px;font-weight:700}.ea-close{background:none;border:none;cursor:pointer}.ea-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.ea-row{display:flex;justify-content:space-between;gap:12px}.ea-label{font-size:13px;font-weight:600;color:#334155}.ea-value{font-size:14px;font-weight:600;color:#0f172a;text-align:right;max-width:65%;word-break:break-word}.ea-footer{padding:12px;border-top:1px solid #e2e8f0;display:flex;gap:10px;flex-wrap:wrap}.ea-view{flex:1;padding:12px;border-radius:12px;background:#0369a1;color:#fff;border:1px solid #e6eef6;font-size:14px;font-weight:600;cursor:pointer}.ea-approve{flex:1;padding:12px;border-radius:12px;background:#059669;color:#fff;border:none;font-size:14px;font-weight:700;cursor:pointer}.ea-reject{flex:1;padding:12px;border-radius:12px;background:#dc2626;color:#fff;border:none;font-size:14px;font-weight:700;cursor:pointer}.ea-close-btn{flex:1;padding:12px;border-radius:12px;background:#fff;border:1px solid #e6eef6;font-size:14px;font-weight:600;cursor:pointer}.ea-image-overlay{position:fixed;inset:0;background:#020617a6;display:flex;align-items:center;justify-content:center;z-index:4000;padding:16px}.ea-image-modal{position:relative;background:#fff;border-radius:12px;padding:12px;max-width:92vw;max-height:85vh;box-shadow:0 24px 48px #02102b33}.ea-image-close{position:absolute;top:10px;right:10px;background:#0009;border:none;color:#fff;border-radius:50%;padding:6px;cursor:pointer}.ea-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:10px}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--text-light: #64748b;--primary: #0369a1;--success: #059669;--danger: #dc2626;--warning: #d97706;--info: #2563eb;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .05);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .2s ease}.eamp-page{padding:10px;background:var(--bg);min-height:100%}.eamp-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.eamp-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.eamp-subtitle{font-size:14px;text-align:right;color:var(--text-light);padding-bottom:8px;border-bottom:1px solid #e5e7eb}.eamp-tabs{display:grid;gap:8px;margin-bottom:16px;grid-template-columns:repeat(2,1fr)}.eamp-tab{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border);background:#f1f5f9;font-size:12px;font-weight:600;color:var(--text-light);cursor:pointer;transition:var(--transition)}.eamp-tab.active{background:#dbeafe;color:var(--primary);border-color:#bfdbfe}@media(max-width:480px){.eamp-tabs{display:grid;gap:8px}.eamp-tab:first-child{text-align:center}.eamp-tab{width:100%}}.eamp-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.eamp-list{display:flex;flex-direction:column;gap:14px}.eamp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;cursor:pointer;transition:var(--transition);display:flex;flex-direction:column;gap:10px}.eamp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.eamp-card-top{display:flex;width:100%;align-items:flex-start;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.eamp-card-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.eamp-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.eamp-card-info{display:flex;flex-direction:column;gap:4px;min-width:0}.eamp-card-title{font-size:13px;font-weight:700;color:var(--text-dark);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.eamp-card-desc{font-size:11px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.eamp-card-right{padding-left:12px;margin-left:12px;display:flex;align-items:center;white-space:nowrap}.eamp-status{padding:6px 10px;border-radius:5px;font-size:10px;font-weight:700;text-transform:capitalize}.eamp-status.pending{background:#fff7ed;color:#c2410c}.eamp-status.approved{background:#dbeafe;color:#2563eb}.eamp-status.rejected{background:#fee2e2;color:#991b1b}.eamp-status.completed{background:#dcfce7;color:#166534}.eamp-footer{text-align:center}.eamp-footer-text{font-size:12px;font-weight:600}.eamp-footer-text.pending{color:var(--warning)}.eamp-footer-text.approved{color:var(--success)}.eamp-footer-text.rejected{color:var(--danger)}.eamp-footer-text.completed{color:var(--info)}.eamp-search{margin-bottom:12px}.eamp-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;outline:none}.eamp-employee-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;background:#000;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:.2s ease}.eamp-employee-btn:hover{background:#1f2937}.adv-pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin:28px 0 10px;padding:12px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 4px 14px #0000000d}.adv-pagination span{font-size:13px;font-weight:600;color:#334155;white-space:nowrap}.adv-pagination button{min-width:80px;padding:8px 16px;font-size:13px;font-weight:600;background:#0369a1;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:.2s ease;box-shadow:0 4px 12px #0369a140}.adv-pagination button:hover:not(:disabled){background:#075985;transform:translateY(-1px)}.adv-pagination button:disabled{background:#cbd5e1;color:#64748b;cursor:not-allowed;box-shadow:none;transform:none}@media(max-width:480px){.adv-pagination{gap:10px;padding:10px}.adv-pagination button{min-width:64px;padding:7px 12px;font-size:12px}.adv-pagination span{font-size:12px}}.emp-exp-page{padding:20px}.emp-exp-header{margin-bottom:16px}.emp-exp-header h2{font-size:22px;font-weight:600}.emp-exp-header p{font-size:14px;color:#666}.emp-exp-container{display:flex;gap:16px;min-height:70vh}.emp-exp-sidebar{width:280px;background:#fff;border-radius:10px;padding:12px;box-shadow:0 2px 10px #0000000f;overflow-y:auto}.emp-exp-sidebar h3{font-size:16px;margin-bottom:10px}.emp-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;cursor:pointer;transition:background .2s ease}.emp-card:hover{background:#f5f5f5}.emp-card.active{background:#000;color:#fff}.emp-card p{font-size:12px;color:#777}.emp-card.active p{color:#ddd}.emp-exp-content{flex:1;background:#fff;border-radius:10px;padding:16px;box-shadow:0 2px 10px #0000000f}.emp-exp-content h3{font-size:18px;margin-bottom:12px}.emp-placeholder{color:#777;font-size:14px;text-align:center;margin-top:40px}.emp-exp-list{display:flex;flex-direction:column;gap:10px}.emp-exp-card{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:8px;border:1px solid #eee;cursor:pointer;transition:box-shadow .2s ease,transform .1s ease}.emp-exp-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.emp-exp-left{display:flex;align-items:center;gap:10px}.emp-exp-left strong{font-size:15px}.emp-exp-left p{font-size:13px;color:#666}.emp-exp-status{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;text-transform:capitalize}.emp-exp-status.pending{background:#fff3cd;color:#856404}.emp-exp-status.approved{background:#d4edda;color:#155724}.emp-exp-status.rejected{background:#f8d7da;color:#721c24}.emp-loading,.emp-empty{font-size:13px;color:#777;padding:10px 0}@media(max-width:900px){.emp-exp-container{flex-direction:column}.emp-exp-sidebar{width:100%;max-height:220px}}.leave-admin-page{padding:80px 16px 90px;background:#f8fafc;min-height:100%;font-family:Inter,sans-serif}.leave-page-title{text-align:center;font-size:22px;font-weight:700;color:#1e293b;margin-bottom:18px}.leave-no-data{text-align:center;color:#64748b;margin-top:20px;font-size:15px}.leave-list{display:flex;flex-direction:column;gap:16px}.leave-card{background:#fff;border:1px solid #E2E8F0;border-radius:14px;padding:16px;box-shadow:0 3px 12px #0000000f;transition:.2s ease}.leave-card:hover{transform:translateY(-3px)}.leave-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.leave-employee-name{font-size:16px;font-weight:700;color:#1e293b}.leave-status-badge{padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;text-transform:capitalize;display:inline-block}.leave-status-badge.pending{background:#fef3c7;color:#b45309}.leave-status-badge.approved{background:#dcfce7;color:#166534}.leave-status-badge.rejected{background:#fee2e2;color:#b91c1c}.leave-details p{font-size:14px;color:#475569;margin-bottom:6px}.leave-details strong{color:#1e293b}.leave-btn-row{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.leave-btn{padding:10px 14px;border:none;border-radius:10px;font-weight:600;color:#fff;cursor:pointer;font-size:14px;transition:.2s ease}.leave-btn.approve{background:#16a34a}.leave-btn.approve:hover{background:#15803d}.leave-btn.reject{background:#dc2626}.leave-btn.reject:hover{background:#b91c1c}:root{--bg: #F8FAFC;--card: #FFFFFF;--border: #E2E8F0;--text-dark: #0F172A;--muted: #64748B;--primary: #0369A1;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0,0,0,.06);--shadow-md: 0 8px 28px rgba(0,0,0,.08);--transition: .22s cubic-bezier(.2,.9,.2,1)}.admin-profile-dashboard{background:var(--bg);padding:10px;min-height:100dvh;width:100%;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.profile-header-card{background:var(--card);padding:13px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:center;margin-bottom:10px;animation:fadeUp .3s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-avatar-wrapper{width:88px;height:88px;margin:0 auto 12px}.profile-avatar-img,.profile-avatar-placeholder{width:100%;height:100%;border-radius:50%;border:3px solid var(--border);background:#e2e8f0;object-fit:cover;display:flex;justify-content:center;align-items:center;color:var(--muted)}.profile-name{font-size:20px;font-weight:700;color:var(--text-dark);margin-top:4px}.profile-role{font-size:13px;font-weight:600;color:var(--primary);letter-spacing:1px;margin-top:2px}.profile-email{font-size:13px;color:var(--muted);margin-top:4px}.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.menu-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 6px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:var(--transition)}.menu-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}.menu-icon{width:45px;height:45px;border-radius:50%;background:#0369a114;display:flex;justify-content:center;align-items:center;color:var(--primary);box-shadow:0 6px 18px #0369a10f}.menu-label{font-size:10px;color:var(--text-dark)}.loading{text-align:center;padding-top:100px;font-size:16px;color:var(--muted)}.te-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:999}.te-modal{width:92%;max-width:520px;background:#fff;border-radius:14px;box-shadow:0 12px 40px #0000002e;display:flex;flex-direction:column;animation:fadeInScale .25s ease}.te-modal.small{max-width:380px}.te-modal-header{padding:16px 18px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.te-modal-header h3,.te-modal-header h4{margin:0;font-size:16px;font-weight:600;color:#222}.te-modal-close{background:none;border:none;cursor:pointer;color:#555;padding:4px}.te-modal-close:hover{color:#000}.te-modal-body{padding:14px 18px;max-height:60vh;overflow-y:auto}.te-modal-body.center{text-align:center}.muted{color:#777;font-size:14px}.te-line{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.te-line-info{display:flex;flex-direction:column;gap:4px;max-width:70%}.te-line-type{font-size:14px;font-weight:600;color:#333}.te-line-project{font-size:12px;color:#666;word-break:break-word}.te-line-actions{display:flex;gap:8px}.te-download-btn,.te-delete-btn{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.te-download-btn{background:#111;color:#fff}.te-download-btn:hover{background:#000}.te-download-btn:disabled{background:#999;cursor:not-allowed}.te-delete-btn{background:#fff;color:#d32f2f;border:1px solid #d32f2f}.te-delete-btn:hover{background:#d32f2f;color:#fff}.te-modal-footer{padding:14px 18px;border-top:1px solid #eee;display:flex;justify-content:flex-end}.te-modal-footer.space-between{justify-content:space-between}.te-close-btn,.te-cancel-btn{padding:8px 14px;font-size:13px;border-radius:8px;border:none;cursor:pointer}.te-close-btn,.te-cancel-btn{background:#f1f1f1;color:#333}.te-close-btn:hover,.te-cancel-btn:hover{background:#e4e4e4}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.te-modal{max-width:95%}.te-line-info{max-width:65%}.te-download-btn,.te-delete-btn{padding:6px 10px}}.admin-announcements-page{padding:10px;background:var(--bg);min-height:100vh}.admin-announcements-header{justify-content:space-between;flex-direction:row;margin-bottom:18px;display:flex;align-items:center;text-align:left;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.admin-announcements-title{font-size:22px;font-weight:700;color:var(--text-dark)}.admin-announcements-add{text-align:right;display:flex;gap:6px;align-items:center;padding:10px 14px;background:var(--primary);color:#fff;border-radius:var(--radius);border-radius:10px;border:none;font-weight:700;cursor:pointer}.admin-announcements-grid{display:flex;flex-direction:column;gap:14px}.admin-announcement-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:var(--transition)}.admin-announcement-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.admin-announcement-left{display:flex;gap:12px;flex:1;min-width:0}.admin-announcement-content{display:flex;gap:4px;flex-direction:column;min-width:0}.admin-announcement-icon{width:44px;height:44px;border-radius:12px;background:#0369a11a;color:var(--primary);display:flex;align-items:center;justify-content:center}.admin-announcement-name{font-size:16px;font-weight:700}.admin-announcement-desc{font-size:13px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.admin-announcement-date{margin-left:12px;padding-left:12px;border-left:1px solid var(--border);font-size:11px;font-weight:700;color:var(--accent)}.admin-announcements-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.ap-page{background:var(--bg);padding:10px;min-height:100%}.ap-subtitle{text-align:center;font-size:14px;color:var(--muted);padding-bottom:8px;border-bottom:1px solid #e5e7eb}.ap-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ap-title{width:100%;text-align:center;font-size:22px;font-weight:700;color:var(--text-dark)}.ap-header-actions{align-items:center;width:100%;gap:10px}.ap-search{width:100%;flex:1;padding:12px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;font-size:14px;box-shadow:var(--shadow-sm)}.ap-add-btn{display:flex;align-items:center;gap:6px;padding:12px 14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-weight:600;box-shadow:var(--shadow-sm);transition:var(--transition)}.ap-add-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.ap-status-tiles{display:flex;gap:8px;padding:6px}.ap-status-tiles::-webkit-scrollbar{display:none}.ap-tile{flex:0 0 80px;height:80px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--muted);cursor:pointer;transition:var(--transition)}.ap-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.ap-tile-icon{display:flex;align-items:center;justify-content:center}.ap-tile-label{font-size:12px;font-weight:600}.ap-tile-count{font-size:11px;font-weight:600;color:inherit}.ap-list{margin-top:16px;display:flex;flex-direction:column;gap:14px}.ap-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);cursor:pointer;transition:var(--transition)}.ap-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.ap-card-left{display:flex;align-items:center;gap:12px}.ap-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.ap-card-info{display:flex;flex-direction:column;gap:4px}.ap-card-title{font-size:13px;font-weight:700;color:var(--text-dark)}.ap-card-desc{font-size:13px;color:var(--muted)}.ap-card-right{padding-left:12px;margin-left:12px;border-left:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.ap-code{font-size:12px;color:var(--muted);margin-bottom:6px}.ap-status{padding:6px 12px;border-radius:5px;font-size:11px;font-weight:600;text-transform:capitalize}.ap-empty{color:var(--muted);text-align:center;margin-top:40px}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--muted: #64748b;--primary: #0369a1;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .06);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .22s cubic-bezier(.2, .9, .2, 1)}.ap-page{background:var(--bg);padding:10px;min-height:100vh}.ap-header{text-align:center;padding:12px;background:#fff;border-radius:12px;border:1px solid var(--border);margin-bottom:12px}.ap-title{font-size:22px;font-weight:700}.ap-subtitle{font-size:14px;color:var(--muted)}.ap-controls{background:#fff;border-radius:12px;border:1px solid var(--border);padding:12px;margin-bottom:16px}.ap-add-btn{margin-top:6px;width:100%;padding:12px 16px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);cursor:pointer}.ap-status-tiles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.ap-tile{height:80px;width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:var(--transition)}.ap-tile.active{border:2px solid var(--primary);background:#edf6ff;color:var(--primary)}.ap-list{display:flex;flex-direction:column;gap:14px}.ap-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;justify-content:space-between;cursor:pointer}.ap-card-left{display:flex;gap:12px}.ap-icon{width:44px;height:44px;background:#0369a114;color:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center}.ap-card-right{border-left:1px solid var(--border);padding-left:12px;text-align:right}.ap-status.completed{background:#d1fae5;color:#059669}.ap-status.not-started{background:#e0e7ff;color:#4338ca}.ap-status.in-progress{background:#dbeafe;color:#2563eb}.ap-empty{text-align:center;color:var(--muted);margin:40px 0}.pm-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.pm-modal{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.pm-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f1f5f9}.pm-header h3{margin:0;font-size:16px;font-weight:700;color:#0f172a}.pm-close{background:none;border:none;cursor:pointer}.pm-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.pm-global-error{padding:10px;border-radius:10px;background:#fef2f2;color:#991b1b;font-size:14px}.pm-field{display:flex;flex-direction:column;gap:6px}.pm-label{font-size:13px;font-weight:600;color:#334155}.pm-input{padding:10px;border-radius:10px;border:1px solid #e6eef6;font-size:14px;color:#0f172a}.pm-input::placeholder{color:#94a3b8}.pm-textarea{min-height:90px;resize:vertical}.pm-input-error{border-color:#991b1b}.pm-error{font-size:13px;color:#991b1b}.pm-footer{display:flex;gap:8px;padding:12px;border-top:1px solid #f1f5f9}.pm-btn{flex:1;padding:12px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;border:none}.pm-cancel{background:#fff;border:1px solid #e6eef6}.pm-save{background:var(--primary);color:#fff}.message-modal{width:100%;max-width:720px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column}.message-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f1f5f9}.message-modal-title{font-size:16px;font-weight:700;color:#0f172a}.message-modal-close{cursor:pointer}.message-modal-body{padding:16px;font-size:14px;color:#0f172a}.message-modal-footer{padding:12px;border-top:1px solid #f1f5f9}.message-modal-footer .btn-primary{width:100%;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer}.pd-overlay{position:fixed;inset:0;background:#02061773;display:flex;justify-content:center;align-items:center;padding:16px;z-index:3000}.pd-modal{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column}.pd-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #f1f5f9}.pd-header h3{margin:0;font-size:16px;font-weight:700}.pd-close{border:none;background:none;cursor:pointer}.pd-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.pd-row{display:flex;flex-direction:column;gap:6px}.pd-label{font-size:13px;font-weight:600;color:#334155}.pd-value{font-size:13px;color:#0f172a}.pd-member{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;background:#fbfdff;border:1px solid #f1f5f9}.pd-avatar{width:36px;height:36px;border-radius:50%;background:#0284c7;color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center}.pd-member-name{flex:1;font-size:14px}.pd-member-remove{background:#991b1b;color:#fff;border:none;padding:6px 10px;border-radius:8px}.pd-select{padding:10px;border-radius:10px;border:1px solid #e6eef6}.pd-assign-btn{margin-top:8px;padding:10px;border-radius:10px;background:var(--primary);color:#fff;border:none}.pd-actions{display:flex;gap:8px}.pd-edit{flex:1;padding:10px;border-radius:10px;border:1px solid #e6eef6;background:#fff}.pd-delete{flex:1;padding:10px;border-radius:10px;background:#991b1b;color:#fff;border:none}.pd-footer{display:flex;gap:8px;padding:12px;border-top:1px solid #f1f5f9}.pd-save{flex:1;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none}.pd-close-btn{flex:1;padding:12px;border-radius:12px;background:#fff;border:1px solid #e6eef6}.pd-delete-confirm{display:flex;flex-direction:column;gap:10px}.pd-delete-input{padding:10px;border-radius:8px;border:1px solid #e6eef6}.pd-delete-confirm-btn{padding:10px;border-radius:10px;background:#991b1b;color:#fff;border:none}.pd-team{max-height:112px;overflow-y:auto;padding-right:6px;margin-top:6px}.pd-team::-webkit-scrollbar{width:6px}.pd-team::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.pd-team::-webkit-scrollbar-thumb:hover{background:#94a3b8}.pd-member{display:flex;align-items:center;justify-content:space-between;gap:10px}.fd-overlay{position:fixed;inset:0;background:#00000059;z-index:5000;display:flex;justify-content:center;align-items:flex-end}.fd-sheet{background:#fff;width:100%;max-height:55%;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .25s ease;padding-bottom:60px}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fd-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #e5e7eb}.fd-header h3{font-size:16px;font-weight:600}.fd-close{cursor:pointer}.fd-search{padding:10px 16px}.fd-search input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e5e7eb;outline:none}.fd-list{flex:1;overflow-y:auto}.fd-item{padding:14px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.fd-item:hover{background:#f9fafb}.fd-item.active{font-weight:600}.fd-dot{width:10px;height:10px;background:#2563eb;border-radius:50%}.fd-empty{text-align:center;padding:20px;color:#6b7280}.edit-select{width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;background-color:#fff;font-size:14px;color:#0f172a;cursor:pointer;display:flex;align-items:center;justify-content:space-between}.edit-select:empty,.edit-select:not(:has(*)){color:#9ca3af}.edit-select:hover{border-color:#cbd5e1}.edit-select:active,.edit-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}:root{--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--green: #16a34a;--red: #dc2626;--blue: #0284c7;--gray: #64748b;--radius: 14px;--shadow: 0 6px 18px rgba(0, 0, 0, .08)}.emp-page{padding:10px}.emp-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.aemp-title{font-size:22px;font-weight:700;color:var(--text-dark)}.emp-subtitle{font-size:14px;color:var(--text-light);padding-bottom:14px;border-bottom:1px solid #e5e7eb}.emp-add-btn{width:100%;justify-content:space-between;background:#0369a1;color:#fff;border:none;padding:10px 14px;border-radius:10px;font-weight:700;display:flex;align-items:center;gap:6px;cursor:pointer}.emp-search-row{width:100%;gap:12px;margin-bottom:6px}.emp-search{flex:1;display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);padding:8px 10px;border-radius:10px}.emp-search input{border:none;outline:none;flex:1}.emp-role-filter{margin-top:6px;border:1px solid var(--border);border-radius:10px;padding:8px 10px}.emp-loading,.emp-empty{text-align:center;color:var(--text-light);margin-top:40px;font-weight:600}.emp-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.emp-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;justify-content:space-between}.emp-info h3{font-size:12px}.emp-info p{font-size:11px;color:var(--text-light)}.emp-meta{display:flex;gap:8px;margin-top:6px}.emp-role{font-size:10px;font-weight:600;padding:4px 8px;border-radius:5px;background:#e0f2fe;color:#075985}.emp-role.admin{background:#fee2e2;color:#991b1b}.emp-status{font-size:11px;font-weight:600;padding:4px 8px;border-radius:5px}.emp-status.active{background:#dcfce7;color:var(--green)}.emp-status.inactive{background:#fee2e2;color:var(--red)}.emp-actions{display:flex;gap:4px}.emp-actions button{background:#f1f5f9;border:none;border-radius:8px;padding:5px;cursor:pointer;margin:auto}.emp-actions button:disabled{opacity:.5;cursor:not-allowed}.emp-deactivate{background:#fee2e2;color:var(--red)}.emp-activate{background:#dcfce7;color:var(--green)}.emp-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:4000}.emp-note{font-size:12px;color:var(--text-light);text-align:center}:root{--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--blue: #0284c7;--blue-dark: #0369a1;--red: #dc2626;--radius: 14px;--shadow: 0 8px 28px rgba(0, 0, 0, .15)}.emp-field-error{margin-top:6px;font-size:12px;font-weight:600;color:var(--red)}.emp-submit-btn:hover{background:var(--blue-dark)}:root{--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--blue: #0284c7;--red: #dc2626;--red-dark: #b91c1c;--radius: 14px;--shadow: 0 8px 28px rgba(0, 0, 0, .15)}.emp-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:4000}.emp-modal{width:100%;max-width:720px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;animation:slideUp .25s ease}.emp-modal-header h3{font-size:18px;font-weight:800}.emp-error{background:#fee2e2;color:#991b1b;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.emp-warning{background:#fef3c7;color:#92400e;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.emp-section{display:flex;flex-direction:column;gap:6px}.emp-label{font-size:13px;font-weight:600;color:var(--text-light)}.emp-input{padding:10px 12px;border-radius:10px;border:1px solid var(--border);font-size:14px;font-family:inherit}.emp-submit-btn{margin-top:6px;background:var(--blue-dark);color:#fff;border:none;padding:12px;border-radius:10px;font-size:14px;font-weight:800;cursor:pointer}.emp-submit-btn.danger{background:var(--red)}.emp-submit-btn.danger:hover{background:var(--red-dark)}.emp-submit-btn:disabled{opacity:.6;cursor:not-allowed}.admin-holidays-page{padding:10px;background:var(--bg);min-height:100vh}.admin-holidays-header{justify-content:space-between;margin-bottom:18px;display:flex;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.admin-holidays-title{font-size:22px;font-weight:700;color:var(--text-dark)}.admin-holidays-add{display:flex;gap:6px;align-items:center;padding:10px 14px;background:var(--primary);color:#fff;border-radius:10px;border:none;font-weight:700;cursor:pointer}.admin-holidays-grid{display:flex;flex-direction:column;gap:14px}.admin-holiday-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:var(--transition)}.admin-holiday-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.admin-holiday-left{display:flex;gap:12px;flex:1;min-width:0}.admin-holiday-content{display:flex;gap:4px;flex-direction:column;min-width:0}.admin-holiday-icon{width:44px;height:44px;border-radius:12px;background:#0369a11a;color:var(--primary);display:flex;align-items:center;justify-content:center}.admin-holiday-name{font-size:13px;font-weight:700}.admin-holiday-desc{font-size:13px;color:var(--text-light)}.admin-holiday-date{margin-left:12px;padding-left:12px;border-left:1px solid var(--border);font-size:11px;font-weight:700;color:var(--accent)}.admin-holidays-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.ah-input{width:100%;margin-bottom:10px;padding:12px;border-radius:var(--radius);border:1px solid var(--border);font-size:14px}.ah-footer{display:flex;gap:10px}.ah-delete{flex:1;background:#fee2e2;color:#b91c1c;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer;padding:12px;display:flex;align-items:center;justify-content:center;gap:6px}.message-modal{width:92%;max-width:720px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;animation:slideUp .25s ease}.message-modal-header{padding:14px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.message-modal-title{font-size:16px;font-weight:700;color:var(--text)}.message-modal-close{cursor:pointer;color:var(--muted)}.message-modal-body{padding:18px;font-size:14px;color:var(--muted);text-align:center}.message-modal-footer{padding:14px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.btn-primary{padding:10px 18px;background:var(--primary);color:#fff;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer}.btn-secondary{padding:10px 18px;background:#e5e7eb;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer}.btn-danger{padding:10px 18px;background:#dc2626;color:#fff;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer}.te-controls{display:flex;flex-direction:column;gap:12px}.te-month{display:flex;flex-direction:column;gap:6px}.te-month input{width:100%;padding:10px;border:1px solid var(--border);border-radius:10px}.te-load-btn{margin-top:6px;padding:10px;border-radius:10px;background:var(--primary);border:1px solid var(--border);color:#fff;font-weight:700}.te-search{display:flex;align-items:center;gap:8px;padding:10px;border-radius:10px;background:var(--card);border:1px solid var(--border)}.te-search input{border:none;flex:1;outline:none}.te-export{padding:10px;border-radius:10px;background:#0f172a;color:#fff;font-size:14px;font-weight:700;border:none;display:flex;justify-content:center;gap:6px}.te-month-total{margin-top:18px;padding:16px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);display:flex;justify-content:space-between}.te-list{margin-top:20px;display:flex;flex-direction:column;gap:10px}.te-row{padding:12px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow)}.te-breakdown-card{margin-top:28px;padding:18px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border)}.te-breakdown-grid{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.bd-box{background:#f1f5f9;padding:12px;border-radius:10px;text-align:center}.bd-box label{color:var(--muted);font-size:13px}.bd-box strong{display:block;margin-top:4px;font-size:15px;font-weight:700}.tem-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.te-project{display:flex;flex-direction:column;gap:6px}.te-project select{padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff}.te-legend{margin-top:20px;padding:16px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border)}.leg-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.center-label{display:block;text-align:center;font-weight:50;border-bottom:1px solid var(--border);padding-bottom:5px}.te-modal-header h3{font-size:17px;font-weight:700}.te-modal-close{background:none;border:none;color:#64748b;cursor:pointer}.te-line{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid #f1f5f9}.te-line-type{font-size:15px;font-weight:600}.te-line-project{font-size:13px;color:#64748b}.te-line-desc{font-size:12px;color:#64748b;margin-top:4px}.te-line-amt{font-weight:700;font-size:15px;margin-bottom:4px}.te-line-status{font-size:12px;padding:4px 10px;border-radius:5px;font-weight:700;text-transform:capitalize}.te-line-status.pending{background:#fef3c7;color:#b45309}.te-line-status.approved{background:#d1fae5;color:#059669}.te-line-status.rejected{background:#fee2e2;color:#b91c1c}.te-line-status.completed{background:#dbeafe;color:#2563eb}.te-img-btn{margin-top:6px;padding:6px 8px;border-radius:8px;background:#e2e8f0;border:none;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.te-close-btn{width:100%;padding:12px;background:#0f172a;color:#fff;border-radius:10px;border:none;font-weight:700;font-size:15px}.te-img-overlay{position:fixed;inset:0;background:#0f172a99;display:flex;justify-content:center;align-items:center;z-index:3500;padding:18px}.te-img-box{background:#fff;padding:10px;border-radius:12px;max-width:95%;max-height:90vh;position:relative}.te-img-box img{max-width:100%;max-height:80vh;object-fit:contain}.te-img-close{position:absolute;right:12px;top:12px;background:none;border:none;color:#64748b}.te-export-btn{padding:6px 10px;border-radius:8px;background:#0f172a;color:#fff;font-size:12px;font-weight:700;border:none;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.te-line-desc{text-align:left}.pes-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.te-title{font-size:22px;font-weight:700;text-align:center}.te-list{margin-top:10px;display:flex;flex-direction:column;gap:10px}.te-row{padding:12px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);cursor:pointer}.te-amount{font-size:13px;font-weight:700}.te-count{font-size:11px;color:var(--muted)}.te-subtitle{font-size:12px;color:var(--muted);margin:0;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.te-export-btn{width:100%;padding:12px 16px;border-radius:8px;background:#0f172a;color:#fff;font-size:13px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity .2s ease}.te-export-btn:disabled{opacity:.6;cursor:not-allowed}.te-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#0f172a;color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #0003;z-index:9999;animation:fadeInUp .25s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.te-modal-body{padding:16px 18px;max-height:60vh;overflow-y:auto}.te-line{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f1f5f9}.te-line-type{font-weight:600}.te-line-project{font-size:12px;color:#64748b}.te-line-right{text-align:right}.te-line-amt{font-weight:700}.te-line-status{font-size:12px;padding:4px 10px;border-radius:5px;background:#dbeafe;color:#2563eb}.te-close-btn{width:100%;padding:12px;background:#0f172a;color:#fff;border-radius:10px;border:none;font-weight:700}.te-modal-actions{display:flex;align-items:center;gap:15px}.te-export-btn{padding:10px;border-radius:8px;background:#0f172a;color:#fff;font-size:12px;font-weight:700;border:none;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.te-export-btn:disabled{opacity:.5;cursor:not-allowed}.elm-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000}.elm-modal{width:92%;max-width:720px;background:#fff;border-radius:14px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;max-height:80vh}.elm-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #eee}.elm-header h3{font-size:16px;font-weight:600;margin:0}.elm-close{background:transparent;border:none;font-size:18px;cursor:pointer;line-height:1}.elm-date-filter{padding:10px 16px;border-bottom:1px solid #eee}.elm-date-filter input{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #d1d5db;font-size:13px}.elm-body{padding:12px 16px;overflow-y:auto;flex:1}.elm-item{background:#f6f7f9;border-radius:10px;padding:10px 12px;margin-bottom:10px}.elm-address{font-size:14px;font-weight:500;color:#111827;line-height:1.4}.elm-time{margin-top:4px;font-size:12px;font-weight:500;color:#6b7280;letter-spacing:.2px;line-height:1.3}.elm-empty,.elm-loading{text-align:center;color:#6b7280;padding:30px 0;font-size:13px}.elm-footer{padding:12px 16px;border-top:1px solid #eee}.elm-btn{width:100%;padding:10px;background:#0b1736;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.elm-btn:hover{background:#111f4d}.admin-live-root{padding:14px}.al-header{background:#fff;border-radius:12px;padding:14px;margin-bottom:12px;box-shadow:0 2px 8px #0000000f}.al-header h2{font-size:16px;font-weight:600;margin:0}.al-header p{font-size:12px;color:#666;margin-top:4px}.al-search{margin-bottom:12px}.al-search input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e0e0e0;font-size:14px;outline:none}.live-grid{display:flex;flex-direction:column;gap:12px}.live-card{background:#fff;border-radius:14px;padding:14px;box-shadow:0 6px 16px #00000014}.clickable{cursor:pointer}.live-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}.live-header strong{font-size:14px}.live-dot{width:8px;height:8px;border-radius:50%}.live-dot.on{background:#28c76f}.live-dot.off{background:#ea5455}.live-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}.live{color:#28c76f;font-weight:600}.offline{color:#ea5455;font-weight:600}.live-location{font-size:12px;color:#555;margin-top:6px;line-height:1.4}.al-pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px}.al-pagination button{padding:6px 12px;border-radius:8px;border:none;background:#0b1736;color:#fff;font-size:12px;cursor:pointer}.al-pagination button:disabled{background:#ccc;cursor:not-allowed}.al-pagination span{font-size:12px;color:#333}.loading{text-align:center;padding:40px;color:#666}.aam-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:999}.aam-modal{background:#fff;width:92%;max-width:720px;border-radius:14px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;overflow:hidden}.aam-header{padding:14px 16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.aam-header h3{font-size:16px;font-weight:700}.aam-close{background:none;border:none;cursor:pointer}.aam-body{padding:16px}.aam-row{display:flex;justify-content:space-between;margin-bottom:12px}.aam-label{font-size:13px;color:#64748b;font-weight:600}.aam-value{font-size:14px;font-weight:600;color:#0f172a;text-align:right}.aam-badge{padding:4px 10px;border-radius:8px;font-size:12px;font-weight:700;text-transform:uppercase}.aam-badge.pending{background:#fef3c7;color:#92400e}.aam-badge.approved{background:#dcfce7;color:#166534}.aam-badge.rejected{background:#fee2e2;color:#991b1b}.aam-footer{padding:14px 16px;border-top:1px solid #e5e7eb;display:flex;gap:10px}.aam-approve{flex:1;background:#16a34a;color:#fff;border:none;padding:10px;border-radius:10px;font-weight:600;cursor:pointer}.aam-reject{flex:1;background:#dc2626;color:#fff;border:none;padding:10px;border-radius:10px;font-weight:600;cursor:pointer}.aam-close-btn{width:100%;background:#e5e7eb;border:none;padding:10px;border-radius:10px;font-weight:600;cursor:pointer}.aam-loading{padding:40px;text-align:center;font-weight:600}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--text-light: #64748b;--primary: #0369a1;--warning: #d97706;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .05);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .2s ease}.adv-page{padding:10px;background:var(--bg);min-height:100%}.adv-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:10px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;margin-bottom:14px}.adv-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.adv-subtitle{font-size:14px;color:var(--text-light);padding-bottom:8px;border-bottom:1px solid #e5e7eb}.adv-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.adv-list{display:flex;flex-direction:column;gap:14px}.adv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;cursor:pointer;transition:var(--transition);display:flex;flex-direction:column;gap:10px}.adv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.adv-card-top{display:flex;width:100%;align-items:flex-start;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.adv-card-left{display:flex;align-items:center;gap:12px;flex:1}.adv-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.adv-card-info{display:flex;flex-direction:column;gap:4px}.adv-card-title{font-size:13px;font-weight:700;color:var(--text-dark)}.adv-card-desc{font-size:11px;color:var(--text-light)}.adv-card-right{margin-left:12px;display:flex;align-items:center}.adv-status{padding:6px 10px;border-radius:5px;font-size:10px;font-weight:700}.adv-status.pending{background:#fff7ed;color:#c2410c}.adv-footer{text-align:center}.adv-footer-text{font-size:12px;font-weight:600}.adv-footer-text.pending{color:var(--warning)}.adv-search{margin-bottom:14px}.adv-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;outline:none;font-size:14px}.adv-search input:focus{border-color:#0369a1}.adv-total-card{display:flex;align-items:center;gap:14px;background:#fff;padding:18px;border-radius:14px;box-shadow:var(--shadow);margin-bottom:20px}.adv-total-icon{background:#fee2e2;color:#dc2626;padding:12px;border-radius:12px}.adv-total-card h3{font-size:22px;font-weight:700}.adv-total-card p{font-size:13px;color:#64748b}.adv-section-title{margin:10px 0;font-size:18px;font-weight:700}.adv-controls{background:#fff;border-radius:10px;border:1px solid var(--border);padding:10px;margin-bottom:14px}.adv-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.adv-tab{padding:10px;border-radius:10px;border:1px solid var(--border);background:#f1f5f9;font-size:12px;font-weight:600;color:var(--text-light);cursor:pointer;transition:var(--transition)}.adv-tab.active{background:#dbeafe;color:var(--primary);border-color:#bfdbfe}.aap-container{padding:10px;background:#f8fafc;min-height:100%}.aap-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.aap-header h2{font-size:20px;font-weight:700;color:var(--text-dark)}.aap-tabs{display:flex;gap:8px;margin-bottom:5px;border-bottom:1px solid #e5e7eb;padding-bottom:14px}.amh{text-align:center}.aap-tab{flex:1;text-align:center;padding:10px 30px;border-radius:10px;border:1px solid var(--border);background:#f1f5f9;font-size:10px;font-weight:600;color:var(--text-light);cursor:pointer;transition:var(--transition);text-decoration:none}.aap-tab.active{background:#dbeafe;color:var(--primary);border-color:#bfdbfe}.aap-content{margin-top:8px}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f1724;--muted: #64748b;--green: #16a34a;--red: #dc2626;--yellow: #ca8a04;--blue: #2563eb;--purple: #7c3aed;--radius: 14px;--shadow-sm: 0 3px 12px rgba(2, 6, 23, .06);--shadow-md: 0 8px 28px rgba(2, 6, 23, .08);--transition: .22s cubic-bezier(.2,.9,.2,1)}.aad-root{background:var(--bg)}.aad-container{max-width:760px;margin:0 auto}.aad-header{text-align:center;margin-bottom:18px}.aad-title{font-size:20px;font-weight:700;margin:0}.aad-subtitle{font-size:13px;color:var(--muted)}.aad-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:12px;padding-bottom:14px;border-bottom:1px solid #e5e7eb}.aad-tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);min-height:96px;display:flex;align-items:center;justify-content:center;transition:transform var(--transition),box-shadow var(--transition)}.aad-clickable{cursor:pointer}.aad-clickable:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}.aad-tile-inner{text-align:center;display:flex;flex-direction:column;gap:6px}.aad-icon svg{width:22px;height:22px}.aad-tile-title{font-size:13px;color:var(--muted);font-weight:600}.aad-tile-value{font-size:18px;font-weight:700}.aad-section-title{text-align:center;font-size:16px;font-weight:700;margin-bottom:12px}.aad-chart{display:flex;flex-direction:column;gap:12px}.aad-bar{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:8px;font-size:13px}.aad-bar-track{height:10px;background:#e5e7eb;border-radius:5px;overflow:hidden}.aad-bar-fill{height:100%;border-radius:5px}.aad-bar-fill.green{background:var(--green)}.aad-bar-fill.red{background:var(--red)}.aad-skeleton{background:linear-gradient(90deg,#f0f3f7,#e8eef6,#f0f3f7);background-size:200% 100%;animation:shimmer 1.2s infinite linear}.aad-header{width:100%;display:flex;flex-direction:column;text-align:center;margin-bottom:12px;gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.aad-controls{margin-bottom:14px}.aad-export-btn{width:100%;padding:12px 16px;border-radius:8px;background:#0f172a;color:#fff;font-size:13px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity .2s ease}.aad-export-btn:disabled{opacity:.6;cursor:not-allowed}.aad-toast-success{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#0f172a;color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #0003;z-index:9999;animation:aadFadeUp .9s ease}@keyframes aadFadeUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.aad-chart{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px}.aem-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:5000}.aem-container{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 10px 32px #0000002e;overflow:hidden;animation:slideUp .25s ease-out}.aem-header h3{font-size:18px;font-weight:700;margin:0;color:#1e293b}.aem-subtitle{font-size:13px;color:#64748b}.aem-close-btn{background:none;border:none;cursor:pointer;color:#475569}.aem-info{text-align:center;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.aem-field{margin-bottom:14px}.aem-field label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:6px}.aem-field input,.aem-field select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;font-size:14px;background:#f8fafc}.aem-error{background:#fee2e2;color:#b91c1c;padding:10px;border-radius:10px;font-size:13px;margin-bottom:12px}.aem-actions{display:flex;gap:10px;margin-top:16px}.aem-btn{flex:1;padding:12px;border-radius:12px;font-size:14px;font-weight:600;border:none;cursor:pointer}.aem-save{background:#0369a1;color:#fff}.aem-save:disabled{opacity:.7;cursor:not-allowed}.aem-cancel{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0}.ada-root{background:#f7fafc;min-height:100vh}.ada-container{margin:auto}.ada-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ada-title{font-size:22px;font-weight:700}.ada-subtitle{color:#64748b;font-size:14px}.ada-date-picker{padding:8px 10px;border-radius:8px;border:1px solid #e2e8f0}.ada-cards{display:grid;gap:14px}.ada-card{background:#fff;border-radius:12px;padding:14px;border:1px solid #e2e8f0}.ada-card-top{display:flex;justify-content:space-between;align-items:center}.ada-emp-name{font-size:16px;font-weight:700}.ada-emp-email{font-size:13px;color:#64748b}.ada-status{padding:6px 10px;font-size:12px;font-weight:700;border-radius:5px}.ada-status.present{background:#ecfdf5;color:#065f46}.ada-status.absent{background:#fef2f2;color:#991b1b}.ada-status.half-day{background:#fff7ed;color:#92400e}.ada-status.leave,.ada-status.sick,.ada-status.unpaid-leave{background:#eef2ff;color:#3730a3}.ada-time-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:10px 0}.ada-time-box{background:#f8fafc;border-radius:10px;padding:10px;text-align:center;border:1px solid #e2e8f0}.ada-time-box span{display:block;font-size:12px;color:#64748b}.ada-time-box strong{font-size:15px;font-weight:700}.ada-edit-btn{background:#0369a1;color:#fff;border:none;border-radius:10px;padding:10px;font-weight:600;cursor:pointer}.ada-edit-full{width:100%}.ada-table-wrap{margin-top:24px;overflow-x:auto}.ada-table{width:100%;border-collapse:collapse;background:#fff}.ada-table th,.ada-table td{padding:12px;border-bottom:1px solid #e2e8f0;text-align:left}.aem-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:3000}.aem-container{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 8px 28px #00000026;overflow:hidden;animation:slideUp .25s ease-out}.aem-header{padding:14px 18px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.aem-header h3{font-size:18px;font-weight:700;color:#1e293b}.aem-status-badge{width:fit-content;padding:8px 12px;border-radius:8px;font-weight:700;font-size:13px;margin-bottom:14px}.aem-absent-message{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:10px;padding:14px;margin-bottom:16px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px}.aem-absent-icon{font-size:18px}.aem-section-title{font-size:15px;font-weight:700;margin-bottom:10px}.aem-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e2e8f0}.aem-info-label{color:#64748b;font-weight:500}.aem-info-value{font-weight:600;text-align:right;max-width:60%}.aem-img{width:100%;border-radius:10px;margin-top:12px;border:1px solid #e2e8f0}.ac-container{padding:16px;background:#f6f9fc;min-height:100%}.ac-title{text-align:center;font-size:22px;font-weight:600;margin-bottom:10px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ac-month-bar{gap:14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ac-nav-btn{background:#fff;border:none;padding:8px 12px;border-radius:10px;box-shadow:0 2px 6px #0000001a;cursor:pointer}.ac-month-name{padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 2px 6px #00000014;font-size:18px;font-weight:600}.ac-day{background:#fff;border-radius:10px;padding:8px;min-height:60px;position:relative;box-shadow:0 2px 6px #00000014;cursor:pointer}.aam-root{background:#f8fafc;min-height:100vh}.aam-container{max-width:960px;margin:auto;padding:8px}.aam-loading,.aam-empty{text-align:center;padding:40px 0;font-size:14px;color:#64748b}.aam-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px;margin-bottom:16px;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.aam-header-text h2{margin:0;font-size:18px}.aam-header-text p{margin:2px 0 0;font-size:12px;color:#64748b}.aam-month-picker{padding:8px 10px;border-radius:10px;border:1px solid #e2e8f0;font-size:13px}.aam-list{display:flex;flex-direction:column;gap:12px}.aam-card{width:100%;background:#fff;padding:14px;border-radius:14px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;box-shadow:0 6px 18px #0000000d}.aam-left h4{margin:0;font-size:14px;font-weight:700}.aam-left p{margin:2px 0 0;font-size:12px;color:#64748b}.aam-center{display:flex;justify-content:space-around;gap:12px;min-width:0}.aam-stat{text-align:center;min-width:36px}.aam-stat span{font-size:11px;color:#64748b}.aam-stat strong{display:block;font-size:14px;font-weight:700}.aam-right button{padding:8px 14px;border-radius:8px;border:none;background:#0369a1;color:#fff;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.aam-right button:hover{background:#1d4ed8}@media(max-width:640px){.aam-card{grid-template-columns:1fr;gap:10px}.aam-center{justify-content:space-between}.aam-right{text-align:right}}.ac-container{padding:10px;background:#f6f9fc;min-height:100%}.ac-title{font-size:22px;font-weight:600;margin-bottom:10px}.ac-legend{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 14px;background:#fff;padding:14px 12px;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 2px 6px #0000000f;margin-bottom:14px}.ac-legend-item{display:flex;align-items:center;padding:8px 10px;border:1px solid #d1d5db;border-radius:10px;background:#f9fafb;font-size:13px;font-weight:600;color:#334155}.ac-legend-dot{width:12px;height:12px;border-radius:50%;margin-right:8px}.ac-month-bar{display:flex;justify-content:center;margin-bottom:12px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ac-month-name{padding:8px;background-color:#f9fafb;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 2px 6px #00000014;font-size:15px;font-weight:600}.ac-week-row{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:8px}.ac-week-name{font-size:13px;font-weight:600;color:#6b6b6b}.ac-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.ac-day{background:#fff;border-radius:10px;padding:8px;min-height:60px;position:relative;box-shadow:0 2px 6px #00000014;cursor:pointer;transition:.15s}.ac-day:hover{background:#eef4ff}.ac-empty{height:60px}.ac-date{font-size:14px;font-weight:600}.ac-today{border:2px solid #1976d2}.ac-status-dot{width:10px;height:10px;border-radius:50%;position:absolute;bottom:6px;right:6px}.ac-present{background:#4caf50}.ac-absent{background:#d32f2f}.ac-leave{background:#0288d1}.ac-unpaid-leave{background:#ff9800}.ac-sick{background:#9c27b0}.ac-half-day{background:#fbc02d}.ac-loading{padding:30px;text-align:center;font-size:15px;color:#64748b}.aem-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:4000}.aem-container{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #E2E8F0;box-shadow:0 8px 28px #00000026;overflow:hidden;animation:slideUp .25s ease-out}.aem-header{padding:14px 18px;border-bottom:1px solid #E2E8F0;display:flex;justify-content:space-between;align-items:center}.aem-header h3{font-size:18px;font-weight:700;color:#1e293b;margin:0}.aem-user{font-size:13px;color:#64748b}.aem-close-btn{cursor:pointer;color:#475569}.aem-close-btn:hover{color:#1e293b}.aem-body{padding:18px;max-height:70vh;overflow-y:auto}.aem-empty{text-align:center;padding:20px 0;font-size:15px;color:#64748b}.aem-status-badge{width:100%;padding:8px 12px;border-radius:8px;font-weight:700;font-size:13px;margin-bottom:14px;text-transform:uppercase;text-align:center}.aem-status-badge.present{background:#dcfce7;color:#166534}.aem-status-badge.absent{background:#fee2e2;color:#b91c1c}.aem-status-badge.half-day{background:#fef9c3;color:#92400e}.aem-status-badge.leave{background:#e0f2fe;color:#0369a1}.aem-status-badge.sick{background:#f3e8ff;color:#7e22ce}.aem-status-badge.unpaid-leave{background:#fff7ed;color:#9a3412}.aem-section{margin-bottom:20px}.aem-section-title{font-size:15px;font-weight:700;color:#1e293b;margin-bottom:10px}.aem-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #E2E8F0}.aem-info-label{font-size:14px;color:#64748b;font-weight:500}.aem-info-value{font-size:14px;color:#1e293b;font-weight:600;text-align:right;max-width:60%}.aem-img{width:100%;border-radius:10px;margin-top:12px;border:1px solid #E2E8F0}.as-page{padding:10px;background:var(--bg);min-height:100%}.as-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:12px;background:#fff;border-radius:10px;border:1px solid var(--border)}.as-title{font-size:22px;font-weight:700}.as-subtitle{font-size:13px;color:var(--muted);padding-bottom:5px;border-bottom:1px solid #e5e7eb}.as-search{width:100%;display:flex;align-items:center;gap:8px;padding:10px;border-radius:10px;background:#fff;border:1px solid var(--border);margin-bottom:16px}.as-search input{border:none;flex:1;outline:none;font-size:14px}.as-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.as-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.as-card svg{color:var(--primary)}.as-card h3{font-size:15px;font-weight:700}.as-card p{font-size:12px;color:var(--muted)}.as-card.pending{background:#fefce8}.as-card.approved{background:#ecfdf5}.as-card.rejected{background:#fef2f2}.as-card.total{background:#eff6ff}.as-list{display:flex;flex-direction:column;gap:10px}.as-row{padding:12px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);cursor:pointer}.as-row-left{display:flex;align-items:center;gap:12px}.as-avatar{width:40px;height:40px;border-radius:12px;background:#0369a12e;display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:700;font-size:18px}.as-name{font-size:13px;font-weight:700}.as-email{font-size:11px;color:var(--muted)}.as-row-right{text-align:right}.as-amount{font-size:14px;font-weight:700}.as-label{font-size:11px;color:var(--muted)}.muted.center{text-align:center;color:var(--muted);margin-top:14px}.as-controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.as-controls input[type=month]{width:100%;padding:8px;border-radius:8px;border:1px solid #e2e8f0}.as-export-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:8px;border:none;background:#0f172a;color:#fff;font-size:13px;font-weight:700;cursor:pointer}.as-modal-overlay{position:fixed;inset:0;z-index:9999;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px}.as-modal{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 8px 22px #00000029;overflow:hidden}.as-modal-header{padding:14px 18px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.as-modal-header h3{font-size:16px;font-weight:700;margin:0}.as-modal-header button{background:none;border:none;cursor:pointer;color:#64748b}.as-modal-body{padding:16px 18px}.as-totals{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px;margin-bottom:16px}.as-total-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.as-total-row strong{font-weight:700}.as-total-row.pending strong{color:#d97706}.as-list-section{border-top:1px solid #e2e8f0;padding-top:12px;max-height:260px;overflow-y:auto;scrollbar-width:thin}.as-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid #f1f5f9}.as-list-item:last-child{border-bottom:none}.as-list-left{flex:1;min-width:0}.as-list-left strong{font-size:15px}.as-list-left p{font-size:12px;color:#64748b;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{display:inline-flex;align-items:center;flex-shrink:0;white-space:nowrap;font-size:12px;padding:4px 10px;border-radius:6px;font-weight:700}.badge.approved{background:#d1fae5;color:#059669}.badge.rejected{background:#fee2e2;color:#b91c1c}.badge.pending{background:#fef3c7;color:#b45309}.as-modal-footer{padding:14px 18px;border-top:1px solid #e2e8f0}.as-modal-footer button{width:100%;padding:12px;background:#0f172a;color:#fff;border-radius:10px;border:none;font-size:15px;font-weight:700;cursor:pointer}.muted{color:#64748b}.center{text-align:center}.as-export-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:8px;border:none;background:#0f172a;color:#fff;font-size:13px;font-weight:700;cursor:pointer}.as-export-btn:disabled{opacity:.6;cursor:not-allowed}.as-list-item{display:flex;justify-content:space-between;align-items:center;gap:12px}.as-list-left{min-width:0;flex:1}.badge{flex-shrink:0;white-space:nowrap}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--muted: #64748b;--primary: #0369a1;--radius: 14px;--shadow: 0 6px 14px rgba(0,0,0,.06)}.te-page{padding:10px;background:var(--bg);min-height:100%}.pes-header{margin-bottom:16px;text-align:center;padding:12px;background:#fff;border-radius:10px;border:1px solid var(--border)}.te-title{font-size:22px;font-weight:700}.te-subtitle{font-size:12px;color:var(--muted);margin-top:4px}.te-search{display:flex;align-items:center;gap:6px;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:10px;margin-bottom:10px}.te-search input{border:none;outline:none;width:100%;font-size:13px}.te-list{display:flex;flex-direction:column;gap:10px}.te-row{padding:12px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.te-row:hover{transform:translateY(-1px);box-shadow:0 10px 22px #00000014}.te-row-left{display:flex;align-items:center;gap:12px}.te-avatar{width:40px;height:40px;border-radius:12px;background:#0369a12e;display:flex;align-items:center;justify-content:center;color:var(--primary);font-weight:700;font-size:18px}.te-name{font-size:13px;font-weight:700}.te-email{font-size:11px;color:var(--muted)}.te-row-right{text-align:right}.te-count{font-size:12px;color:var(--muted)}.muted{color:var(--muted)}.te-modal{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid var(--border);box-shadow:0 8px 22px #00000029;overflow:hidden}.te-modal-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.te-line:last-child{border-bottom:none}.te-line-project{font-size:12px;color:var(--muted);word-break:break-word}.te-line a{font-size:12px;color:var(--primary);text-decoration:none;font-weight:600}.te-line button{font-size:12px;background:none;border:none;color:#dc2626;cursor:pointer}.te-modal-footer{padding:14px 18px;border-top:1px solid var(--border)}.te-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:3000}.te-modal{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 8px 22px #00000029;overflow:hidden}.te-modal-header{padding:14px 18px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.te-modal-header h3{font-size:16px;font-weight:700}.te-modal-close{background:none;border:none;cursor:pointer}.te-modal-body{padding:16px 18px;max-height:65vh;overflow-y:auto}.te-line{padding:10px 0;border-bottom:1px solid #f1f5f9}.te-line-type{font-weight:600;font-size:13px}.te-line-project{font-size:12px;color:#64748b;white-space:pre-wrap}.te-modal-footer{padding:14px 18px;border-top:1px solid #e2e8f0}.te-close-btn{width:100%;padding:12px;background:#0f172a;color:#fff;border-radius:10px;border:none;font-weight:700;cursor:pointer}:root{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--primary: #2563eb;--success-bg: #dcfce7;--success-text: #166534;--warning-bg: #e0e7ff;--warning-text: #3730a3;--danger-bg: #fee2e2;--danger-text: #9b1c1c;--radius: 12px;--shadow: 0 4px 14px rgba(0, 0, 0, .06)}.ald-container{padding:10px;background:var(--bg);min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont}.AlDheader{background:var(--card);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.ald-title{width:100%;text-align:center;font-size:22px;font-weight:700;color:var(--text-dark)}.ald-subtitle{font-size:14px;color:var(--text-light);padding-bottom:14px;border-bottom:1px solid #e5e7eb}.ald-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.ald-filters input,.ald-filters select{flex:1;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#fff;font-size:13px;color:var(--text-dark)}.ald-btn{width:100%;padding:10px 14px;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:14px;font-weight:700;border:none;cursor:pointer}.ald-header{text-align:center;padding:10px;background:#fff;border-radius:10px;border:1px solid var(--border);margin-bottom:12px}.ald-search{margin-bottom:12px}.ald-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border)}.ald-controls{background:#fff;border-radius:10px;border:1px solid var(--border);padding:10px;margin-bottom:14px}.ald-filters{display:flex;gap:10px;margin-bottom:10px}.ald-status-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.ald-status-tab{padding:10px;border-radius:10px;border:1px solid var(--border);background:#f1f5f9;font-size:12px;font-weight:600;cursor:pointer}.ald-status-tab.active{background:#dbeafe;color:var(--primary);border-color:#bfdbfe}.ald-empty{text-align:center;margin:30px 0;font-size:14px;color:var(--text-light)}.ald-list{display:flex;flex-direction:column;gap:12px}.ald-item{display:flex;justify-content:space-between;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:.2s ease}.ald-item:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.ald-name{font-size:15px;font-weight:700;color:var(--text-dark)}.ald-email{font-size:13px;color:var(--text-light)}.ald-type{margin-top:6px;font-size:12px;font-weight:600;color:var(--text-dark)}.ald-dates{font-size:12px;color:var(--text-light)}.ald-status{padding:5px 10px;border-radius:5px;font-size:10px;font-weight:700;text-transform:uppercase}.ald-status.pending{border-radius:5px;background:var(--warning-bg);color:var(--warning-text)}.ald-status.approved{border-radius:5px;background:var(--success-bg);color:var(--success-text)}.ald-status.rejected{border-radius:5px;background:var(--danger-bg);color:var(--danger-text)}.ald-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right}.ald-date-row,.ald-name-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.ald-right-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.ald-item{display:flex;justify-content:space-between;align-items:flex-start}.ald-item-left{display:flex;flex-direction:column;gap:4px}.ald-item-right{display:flex;flex-direction:column;align-items:flex-end;text-align:right;gap:4px}.ald-item-right .ald-dates{font-size:12px;color:var(--text-light);white-space:nowrap}.ald-days{font-size:12px;font-weight:600;color:var(--text-light)}.ald-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.ald-modal{width:100%;max-width:720px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.ald-header{padding:14px 16px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.ald-close{background:none;border:none;cursor:pointer}.ald-body{padding:16px;display:flex;flex-direction:column;gap:12px}.ald-user-row{display:flex;justify-content:space-between;align-items:center}.ald-user-name{font-size:15px;font-weight:700}.ald-user-email{font-size:13px;color:#64748b}.ald-status{padding:6px 12px;border-radius:999px;font-size:10px;font-weight:700}.ald-btn.secondary{width:100%;padding:12px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;font-size:14px;font-weight:700;color:#0f172a;cursor:pointer;transition:.2s ease}.ald-btn.secondary:hover{background:#f1f5f9}.ald-status.pending{border-radius:5px;background:#fff7ed;color:#c2410c}.ald-status.approved{border-radius:5px;background:#dcfce7;color:#166534}.ald-status.rejected{border-radius:5px;background:#fee2e2;color:#991b1b}.ald-row{display:flex;justify-content:space-between;gap:12px}.ald-label{font-size:13px;font-weight:600;color:#334155}.ald-value{font-size:14px;color:#0f172a;text-align:right;max-width:65%}.ald-radio-group{display:flex;gap:10px}.ald-radio{padding:8px 12px;border-radius:10px;border:1px solid #e6eef6;cursor:pointer;font-size:13px}.ald-radio.active{background:#e0f2fe;border-color:var(--primary)}.ald-textarea{width:100%;padding:10px;border-radius:10px;border:1px solid #e6eef6;min-height:80px}.ald-footer{padding:12px;border-top:1px solid #f1f5f9;display:flex;gap:10px}.ald-btn{padding:12px;border-radius:12px;border:none;font-size:14px;font-weight:600;cursor:pointer}.ald-btn.secondary{background:#fff;border:1px solid #e6eef6}.ald-btn.reject{background:#dc2626;color:#fff}.ald-btn.approve{background:#059669;color:#fff}.ald-success{background:#fff;padding:24px;border-radius:12px;text-align:center;width:100%;max-width:360px;box-shadow:0 24px 48px #02102b33}.aldet-container{padding:18px;background:#f8fafc;min-height:100%;box-sizing:border-box}.aldet-title{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:12px}.aldet-status{padding:10px;border-radius:10px;text-align:center;font-weight:700;margin-bottom:16px;color:#fff;font-size:15px}.aldet-status.pending{background:#f59e0b}.aldet-status.approved{background:#10b981}.aldet-status.rejected{background:#991b1b}.aldet-card{background:#fff;padding:18px;border-radius:16px;border:1px solid #E2E8F0;box-shadow:0 4px 12px #0000000f;margin-bottom:22px}.aldet-section{margin-bottom:16px}.aldet-section h4{font-size:14px;color:#475569;font-weight:600;margin-bottom:4px}.aldet-section p{font-size:15px;color:#0f172a}.aldet-subtext{font-size:12px;color:#64748b}.aldet-email{font-size:13px;color:#6b7280}.aldet-bold{font-size:16px;font-weight:700}.aldet-attachment{color:#2563eb;font-weight:600;text-decoration:underline}.aldet-radio-group{display:flex;gap:10px}.aldet-radio{padding:10px 14px;border:1px solid #CBD5E1;border-radius:12px;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;font-weight:600;color:#475569;background:#f1f5f9}.aldet-radio.active{border-color:#3b82f6;background:#e0edff;color:#1d4ed8}.aldet-radio input{display:none}.aldet-actions textarea{width:100%;padding:12px;border-radius:12px;border:1px solid #CBD5E1;min-height:100px;margin-bottom:14px;font-size:15px;outline:none}.aldet-actions{margin-bottom:18px}.aldet-btn{width:100%;padding:14px;border-radius:12px;font-size:16px;font-weight:700;margin-bottom:10px;border:none;cursor:pointer;transition:.2s;color:#fff}.aldet-btn.approve{background:#10b981}.aldet-btn.approve:hover{background:#0d946a}.aldet-btn.reject{background:#991b1b}.aldet-btn.reject:hover{background:#c53030}.aldet-back{width:100%;padding:14px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:.2s}.aldet-back:hover{background:#1d4ed8}.aldet-empty{text-align:center;color:#64748b;margin-top:40px}.ew-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.ew-modal{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.ew-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.ew-header h3{margin:0;font-size:16px;font-weight:700;color:#0f172a}.ew-close{background:none;border:none;cursor:pointer}.ew-body{padding:14px 16px;display:flex;flex-direction:column;gap:14px}.ew-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.ew-label{font-size:13px;font-weight:600;color:#334155}.ew-date{padding:8px 10px;border-radius:8px;border:1px solid #e5e7eb;font-size:13px;font-weight:600}.ew-empty{text-align:center;font-size:14px;color:#64748b}.ew-log-list{display:flex;flex-direction:column;gap:10px}.ew-log-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.ew-log-text{font-size:13px;font-weight:600;color:#0f172a;margin:0;flex:1}.ew-log-hours{font-size:12px;font-weight:700;color:#0369a1;white-space:nowrap}.ew-footer{padding:12px;border-top:1px solid #e2e8f0}.ew-close-btn{width:100%;padding:12px;border-radius:12px;background:#fff;border:1px solid #e6eef6;font-size:14px;font-weight:600;cursor:pointer}.ew-log-meta{gap:10px;display:flex;justify-content:space-between;align-items:center}.ew-log-project{font-size:12px;font-weight:600;color:#64748b}.wr-page{padding:14px;background:#f8fafc;min-height:100vh}.wr-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.wr-back{background:transparent;border:none;color:#0369a1;cursor:pointer;display:flex;align-items:center;gap:4px}.wr-list{display:flex;flex-direction:column;gap:12px}.wr-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px}.wr-top{display:flex;justify-content:space-between;font-weight:600}.wr-empty{text-align:center;color:#64748b;margin-top:40px}.mw-page{padding:10px;background:var(--bg);min-height:100%}.mw-page h3{text-align:center;font-size:20px;font-weight:700;margin-bottom:14px}.mw-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:16px}.mw-form textarea,.mw-form input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);font-size:13px;margin-bottom:10px}.mw-form textarea{min-height:90px;resize:none}.mw-form button{width:100%;padding:10px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.mw-list{display:flex;flex-direction:column;gap:12px}.mw-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px}.mw-card p{font-size:13px;color:var(--text-dark);margin-bottom:6px}.mw-card small{font-size:11px;color:var(--text-light)}.mw-select{margin:12px 0}.mw-select select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;font-size:14px;font-weight:600}.mw-project{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#f8fafc;margin-bottom:12px}.mw-label{font-size:13px;font-weight:600;color:#64748b}.mw-project-name{font-size:14px;font-weight:700;color:#0f172a}.mw-meta{font-size:12px;color:#64748b}.wp-page{padding:10px;background:var(--bg)}.wp-header{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center;margin-bottom:14px}.wp-header h2{border-bottom:1px solid #e5e7eb;font-size:20px;font-weight:700;padding-bottom:5px;margin-bottom:5px}.wp-search{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);font-size:13px}.wp-list{display:flex;flex-direction:column;gap:14px}.wp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;cursor:pointer;transition:var(--transition)}.wp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.wp-card-left{display:flex;align-items:center;gap:12px}.wp-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.wp-info{display:flex;justify-content:space-between;align-items:center;width:100%}.wp-info b{font-size:13px;font-weight:700;color:var(--text-dark)}.wp-info small{font-size:12px;color:var(--text-light)}.wp-empty{text-align:center;margin-top:40px;font-size:14px;color:var(--text-light)}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--primary: #0369a1;--text-dark: #0f172a;--text-light: #64748b;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0,0,0,.05);--shadow-md: 0 8px 28px rgba(0,0,0,.08)}.awp-page{padding:14px;background:var(--bg);min-height:100%}.awp-page h2{text-align:center;margin-bottom:16px}.awp-list{display:flex;flex-direction:column;gap:12px}.awp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:var(--shadow-sm);transition:.2s}.awp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.awp-card b{font-size:14px;color:var(--text-dark)}.awp-card small{font-size:12px;color:var(--text-light)}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--text-light: #64748b;--primary: #0369a1;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .05);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .2s ease}.edw-page{padding:10px;background:var(--bg);min-height:100%}.edw-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:16px;gap:6px;padding:10px;background:#fff;border-radius:10px;border:1px solid #e5e7eb}.edw-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.edw-subtitle{font-size:14px;color:var(--text-light);padding-bottom:8px;border-bottom:1px solid #e5e7eb}.edw-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.edw-list{display:flex;flex-direction:column;gap:14px}.edw-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;cursor:pointer;transition:var(--transition);display:flex;flex-direction:column;gap:10px}.edw-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.edw-card-top{display:flex;width:100%;align-items:flex-start;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.edw-card-left{display:flex;align-items:center;gap:12px;flex:1}.edw-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.edw-card-info{display:flex;flex-direction:column;gap:4px}.edw-card-title{font-size:13px;font-weight:700;color:var(--text-dark);margin:0}.edw-card-desc{font-size:11px;color:var(--text-light)}.edw-footer{text-align:center}.edw-footer-text{font-size:12px;font-weight:600;color:var(--primary)}.edw-search{margin-bottom:12px}.edw-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;outline:none}.edw-search{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.edw-export-btn{width:100%;background-color:#000;color:#fff;border:none;padding:12px 16px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:background-color .2s ease,transform .1s ease}.edw-export-btn:hover{background-color:#1a1a1a}.edw-export-btn:active{transform:scale(.98)}.edw-export-btn:disabled{background-color:#9ca3af;cursor:not-allowed;transform:none}.te-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#0f172a;color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #0003;z-index:9999;animation:teFadeUp .9s ease}@keyframes teFadeUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.notification-page{min-height:100%;background:#fff;max-width:720px;padding:10px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border:1px solid #e5e5ea;border-radius:5px}.notification-header h2{font-size:16px;font-weight:600;margin:0;color:#000}.mark-all-btn{background:none;border:none;color:#0369a1;font-size:13px;font-weight:500;cursor:pointer;padding:0}.mark-all-btn:hover{text-decoration:underline}.notif-empty{text-align:center;padding:40px 16px;font-size:14px;color:#8e8e93}.notification-list{display:flex;flex-direction:column}.notification-item{padding:12px 16px;border-bottom:1px solid #e5e5ea;cursor:pointer;transition:background .15s ease}.notification-item:hover{background:#f7f7f7}.notification-item.unread{background:#f2f7ff}.notification-item.unread .notification-title{font-weight:700}.notification-title{font-size:14px;font-weight:600;color:#000;margin-bottom:4px}.notification-message{font-size:13px;color:#6e6e73;line-height:1.4}.notification-date{font-size:11px;color:#8e8e93;margin-top:6px}.employee-dashboard{min-height:100%;background:var(--bg);padding:var(--space-l) 0 20px;color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.emp-container{width:calc(100% - 32px);max-width:var(--container-width);margin:0 auto}.skeleton{background:linear-gradient(90deg,#f0f3f7,#e8eef6,#f0f3f7);background-size:200% 100%;animation:shimmer 1.2s linear infinite;border-radius:8px}.skeleton-card{height:86px;border-radius:var(--radius)}.emp-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.emp-title{font-size:18px;font-weight:700;color:var(--text-dark);margin:0}.emp-subtitle{font-size:12px;color:var(--muted);margin:0;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:20px;padding:0}.tile{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:14px;transition:transform var(--transition),box-shadow var(--transition);min-height:86px;display:flex;align-items:center;justify-content:center}.tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}.tile-inner{display:flex;flex-direction:column;gap:8px;align-items:center}.tile-title{font-size:13px;color:var(--text-dark);font-weight:600;margin:0}.tile-value{font-size:18px;font-weight:600;color:var(--muted);margin:0}.section-title{font-size:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-bottom:40px}.action-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition);min-height:110px;cursor:pointer}.action-card:hover,.action-card:focus{transform:translateY(-6px);box-shadow:var(--shadow-md);outline:none}.action-card:active{transform:translateY(-2px) scale(.995)}.action-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#0a74ff14,#0a74ff0f);color:var(--primary);box-shadow:0 6px 18px #0a74ff0f}.action-label{font-size:10px;color:var(--text-dark);text-align:center;margin:0}:root{--bg: #F8FAFC;--card-bg: #ffffff;--primary: #0a74ff;--primary-dark: #0b5ed7;--muted: #64748B;--text-dark: #0F1724;--border: #E2E8F0;--radius: 14px;--shadow-sm: 0 3px 12px rgba(2, 6, 23, .06);--shadow-md: 0 8px 28px rgba(2, 6, 23, .08);--space-m: 12px;--space-l: 16px;--transition: .22s cubic-bezier(.2, .9, .2, 1);--container-width: 760px}:root{--app-header-height: 50px;--bottom-nav-height: 56px;--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom)}.am-root{position:fixed;inset:0;width:100%;height:100%;background:#0f172a;display:flex;justify-content:center;align-items:stretch;overflow:hidden;font-family:Inter,system-ui,-apple-system,Helvetica Neue,Arial}.am-video-wrap{position:relative;width:100%;height:100vh;overflow:hidden}.am-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}.am-top-bar{position:absolute;top:calc(var(--app-header-height) + var(--safe-top) + 12px);left:14px;right:14px;display:flex;justify-content:space-between;align-items:center;pointer-events:none;z-index:60}.am-top-bar .am-flip-btn{pointer-events:auto;background:#ffffff1f;border:none;padding:10px;border-radius:10px;color:#fff;display:inline-flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer}.am-top-bar .am-flip-btn:disabled{opacity:.6;cursor:not-allowed}.am-top-bar .am-perms{pointer-events:auto;display:flex;gap:8px;align-items:center;color:#fff;font-size:13px;opacity:.95}.perm{padding:6px 8px;border-radius:8px;background:#00000040;border:1px solid rgba(255,255,255,.06)}.perm.ok{background:#4caf50}.perm.warn{background:#d32f2f}.am-bottom-bar{position:absolute;bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + 12px);left:12px;right:12px;z-index:70;display:flex;gap:12px;align-items:center;justify-content:space-between}.am-info{flex:1;max-width:calc(100% - 160px);background:#ffffff0f;padding:10px 12px;border-radius:12px;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:13px}.am-info-row{display:flex;gap:12px;align-items:center;margin-bottom:4px}.am-label{min-width:68px;color:#cbd5e1;font-weight:600}.am-value{color:#f8fafc;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.am-location{max-width:320px}.am-error{margin-top:6px;color:#fecaca;font-size:13px}.am-actions{width:150px;display:flex;align-items:center;justify-content:center}.am-action-btn{width:140px;padding:12px 10px;border-radius:12px;border:none;font-weight:700;font-size:16px;cursor:pointer;box-shadow:0 6px 18px #10182873}.am-checkin{background:linear-gradient(180deg,#1976d2,#165aab);color:#fff}.am-checkout{background:linear-gradient(180deg,#10b981,#0f9d73);color:#fff}.am-done{background:#ffffff1f;color:#e2e8f0}.am-top-bar,.am-bottom-bar{transition:opacity .2s ease}.ios-modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999}.ios-modal{width:85%;max-width:360px;background:#fff;border-radius:20px;padding:22px;text-align:center;color:#111;box-shadow:0 10px 30px #00000040;animation:iosPop .25s ease}@keyframes iosPop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.ios-modal h3{margin-bottom:8px;font-size:18px;font-weight:600}.ios-modal p{margin-bottom:18px;font-size:15px;color:#333}.ios-btn-primary{width:100%;padding:12px;background:#1976d2;border-radius:12px;border:none;font-size:16px;color:#fff;font-weight:600;margin-bottom:10px}.ios-btn-secondary{width:100%;padding:12px;background:#e5e5e7;border-radius:12px;border:none;font-size:16px;color:#333;font-weight:500}.tdm-container{width:100%;max-width:900px;margin:0 auto;padding:10px;font-family:Inter,system-ui,sans-serif}.tdm-title{font-size:22px;font-weight:700;color:#111827;text-align:center;padding:10px;background-color:#fff;border:1px solid #e5e7eb;border-radius:10px}.tdm-loading,.tdm-empty{text-align:center;font-size:15px;color:#6b7280;margin-top:20px}.tdm-content{display:flex;flex-direction:column;gap:20px;margin-top:10px}.tdm-status-badge{text-align:center;padding:10px 16px;border-radius:10px;font-size:15px;font-weight:600;width:100%;margin:0 auto 10px;color:#fff}.tdm-status-badge.present{background:#dcfce7;color:#166534}.tdm-status-badge.absent{background:#fee2e2;color:#b91c1c}.tdm-status-badge.half-day{background:#f59e0b}.tdm-status-badge.leave,.tdm-status-badge.unpaid-leave{background:#3b82f6}.tdm-status-badge.sick{background:#8b5cf6}.tdm-card{background:#fff;border-radius:12px;padding:16px 18px;box-shadow:0 4px 8px #00000014;border:1px solid #f1f1f3}.tdm-card-title{font-size:18px;font-weight:700;margin-bottom:14px;color:#1f2937}.tdm-row{display:flex;justify-content:space-between;margin-bottom:6px}.tdm-label{color:#6b7280;font-weight:500;font-size:14px}.tdm-value{color:#111827;font-weight:600;font-size:14px}.tdm-address{max-width:70%;display:block;text-align:right;white-space:normal;line-height:1.3}.tdm-img{width:100%;height:auto;object-fit:cover;border-radius:12px;margin-top:10px;border:1px solid #e5e7eb}.tdm-subtitle{text-align:center;margin-bottom:22px;font-size:14px;color:var(--text-light);margin-top:4px}.tdm-status-badge.not-marked{background:#e5e7eb;color:#374151;border:1px dashed #9ca3af}*{box-sizing:border-box}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--primary: #0369a1;--text-dark: #0f172a;--text-light: #64748b;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0,0,0,.05);--shadow-md: 0 8px 28px rgba(0,0,0,.08);--transition: .2s ease}.dep-page{padding:10px;background:var(--bg);min-height:100vh}.dep-header{text-align:center;padding:10px;background:#fff;border-radius:10px;border:1px solid var(--border);margin-bottom:12px}.dep-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.dep-subtitle{font-size:14px;color:var(--text-light);padding-bottom:8px;border-bottom:1px solid #e5e7eb}.dep-search{margin-bottom:12px}.dep-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb}.dep-controls{background:#fff;border-radius:10px;border:1px solid var(--border);padding:10px;margin-bottom:14px}.dep-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.dep-tab{padding:10px;border-radius:10px;border:1px solid var(--border);background:#f1f5f9;font-size:12px;font-weight:600;color:var(--text-light);cursor:pointer}.dep-tab.active{background:#dbeafe;color:var(--primary);border-color:#bfdbfe}.dep-add-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:10px;border:none;background:#0284c7;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.dep-add-btn:hover{background:#0369a1}.dep-empty{text-align:center;margin:32px 0;font-size:14px;color:var(--text-light)}.dep-list{display:flex;flex-direction:column;gap:14px}.dep-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;display:flex;justify-content:space-between;cursor:pointer;transition:var(--transition)}.dep-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.dep-card-left{display:flex;gap:12px}.dep-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.dep-card-info{display:flex;flex-direction:column;gap:4px}.dep-card-title{font-size:13px;font-weight:700}.dep-card-desc{font-size:13px;color:var(--text-light)}.dep-card-right{border-left:1px solid var(--border);padding-left:12px;display:flex;flex-direction:column;gap:6px}.dep-code{font-size:13px;font-weight:600;color:var(--text-light)}.dep-status{padding:6px 10px;font-size:12px;font-weight:700;border-radius:5px;text-transform:capitalize}.dep-status.pending{background:#fff7ed;color:#c2410c}.dep-status.approved{background:#dbeafe;color:#2563eb}.dep-status.rejected{background:#fee2e2;color:#991b1b}.dep-status.completed{background:#dcfce7;color:#166534}.expModal-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.expModal-box{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.expModal-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.expModal-header h3{font-size:16px;font-weight:700;margin:0}.expModal-close{border:none;background:none;cursor:pointer}.expModal-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.expModal-field{display:flex;flex-direction:column;gap:6px}.expModal-field label{font-size:13px;font-weight:600;color:#334155}.expModal-field input,.expModal-field select,.expModal-field textarea{width:100%;padding:10px;border-radius:10px;border:1px solid #e6eef6;font-size:14px}.expModal-field textarea{width:100%;min-height:90px;resize:vertical}.expModal-footer{padding:12px;border-top:1px solid #e2e8f0}.expModal-submit{width:100%;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer}.native-file-wrapper{position:relative;width:100%}.native-file-wrapper input[type=file]{width:100%;padding-right:42px;border-radius:10px}.native-file-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.ed-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.ed-box{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.ed-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.ed-title{font-size:16px;font-weight:700;margin:0;color:#0f172a}.ed-close{background:none;border:none;cursor:pointer}.ed-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.ed-amount-box{display:flex;justify-content:space-between;align-items:center}.ed-amount{font-size:20px;font-weight:700;color:#0f172a}.ed-status-badge{padding:6px 10px;border-radius:5px;font-size:13px;font-weight:600;text-transform:capitalize}.ed-status-badge.completed{background:#d1fae5;color:#059669}.ed-status-badge.pending{background:#fff7ed;color:#c2410c}.ed-status-badge.approved{background:#dcfce7;color:#166534}.ed-status-badge.rejected{background:#fee2e2;color:#991b1b}.ed-section label{font-size:13px;font-weight:600;color:#334155}.ed-section p{font-size:14px;margin-top:4px;color:#0f172a}.ed-footer{padding:12px;border-top:1px solid #e2e8f0;display:flex;gap:10px}.ed-view-btn{flex:1;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer}.ed-close-btn{flex:1;padding:12px;border-radius:12px;background:#fff;border:1px solid #e6eef6;font-size:14px;font-weight:600;cursor:pointer}.ed-image-overlay{position:fixed;inset:0;background:#020617a6;display:flex;align-items:center;justify-content:center;z-index:4000;padding:16px}.ed-image-modal{position:relative;background:#fff;border-radius:12px;padding:12px;max-width:92vw;max-height:85vh;box-shadow:0 24px 48px #02102b33}.ed-image-close{position:absolute;top:10px;right:10px;background:#0009;border:none;color:#fff;border-radius:50%;padding:6px;cursor:pointer}.ed-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:10px}.ed-section{display:flex;justify-content:space-between;align-items:center;gap:12px}.ed-section label{font-size:13px;font-weight:600;color:#334155;flex-shrink:0}.ed-section p{font-size:12px;color:#0f172a;text-align:right;margin:0;max-width:65%;word-break:break-word}.attendance-page{background:#f8fafc;min-height:100%;padding-bottom:5rem;font-family:Inter,sans-serif}.page-title{font-size:20px;margin:5px;color:#1e293b;font-weight:600}.list-wrapper{padding:0 15px}.empty-msg{text-align:center;padding:20px;color:#64748b}.attendance-card{background:#fff;padding:14px;margin-bottom:14px;border-radius:12px;box-shadow:0 2px 10px #0000000f;display:flex;justify-content:space-between;align-items:center}.left-block h3{font-size:16px;color:#1e293b;margin-bottom:4px}.time-text{font-size:13px;color:#475569}.status{padding:6px 10px;border-radius:8px;font-size:13px;font-weight:600;text-transform:uppercase}.status.approved{background:#d4f8df;color:#2e7d32}.status.pending{background:#fff3cd;color:#ed6c02}.status.rejected{background:#fbd5d5;color:#c62828}.lv-container{padding:10px;max-width:900px;margin:auto}.lv-header{font-size:22px;font-weight:700;margin-bottom:12px}.lv-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.lv-tabs{display:flex;justify-content:center;gap:8px;border-radius:10px;background-color:#fff}.lv-tabs button{padding:10px 30px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-size:13px;font-weight:600;cursor:pointer}.lv-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.lv-balance-box{background:#fff;border:1px solid #e6eef6;border-radius:14px;padding:16px;margin-bottom:20px}.lv-balance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:10px}.lv-bal-card{background:#f8fafc;border-radius:12px;padding:12px;text-align:center}.lv-bal-card p{font-size:13px;color:#64748b;margin:0}.lv-bal-card h3{font-size:20px;font-weight:700;margin:4px 0 0}.lv-title{margin:12px 0;font-size:16px;font-weight:700}.lv-empty{text-align:center;color:#64748b;margin:20px 0}.lv-item{background:#fff;border:1px solid #e6eef6;border-radius:14px;padding:15px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:10px;transition:.2s ease}.lv-item:hover{background:#f8fafc}.lv-item-left{display:flex;flex-direction:column}.lv-type{font-size:13px;font-weight:700;margin-bottom:10px}.lv-dates{font-size:11px;color:#64748b}.lv-status-badge{padding:6px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase}.lv-status-badge.pending{border-radius:5px;background:#fff7ed;color:#c2410c}.lv-status-badge.approved{border-radius:5px;background:#e6eef6;color:#c6529c}.lv-status-badge.rejected{border-radius:10px;background:#c6529c}.lv-status-badge.approved{background:#dcfce7;border-radius:5px;color:#166534}.lv-status-badge.rejected{background:#fee2e2;border-radius:5px;color:#991b1b}.lv-request-btn{width:100%;padding:12px;border-radius:12px;background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer}.lv-balance-grid{display:flex;gap:12px}.lv-bal-card{flex:1;background:#f8fafc;border-radius:12px;padding:12px;text-align:center;border-bottom:2px solid #e5e7eb}:root{--bg-overlay: rgba(15, 23, 42, .55);--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--text-light: #64748b;--primary: #0369a1;--primary-dark: #075985;--radius: 14px;--shadow: 0 8px 28px rgba(0, 0, 0, .15);--transition: .2s ease}.emp-modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.emp-modal{width:100%;max-width:720px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.emp-modal-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.emp-modal-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text-dark)}.emp-close-btn{background:none;border:none;cursor:pointer;color:var(--text-light)}.emp-modal-body{padding:18px;display:flex;flex-direction:column;gap:14px}.alm-section{display:flex;flex-direction:column;gap:6px}.alm-label{font-size:13px;font-weight:600;color:var(--text-light)}.alm-input,.alm-textarea{color:#9ca3af;width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);font-size:14px;font-family:inherit}.alm-textarea{resize:none;min-height:80px}.alm-footer{padding:14px 18px;border-top:1px solid var(--border);display:flex;gap:10px}.alm-btn-secondary,.alm-btn-primary{flex:1;padding:12px;border-radius:10px;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:var(--transition)}.alm-btn-secondary{background:#f1f5f9;color:var(--text-dark)}.alm-btn-primary{background:var(--primary);color:#fff}.alm-btn-primary:hover{background:var(--primary-dark)}.alm-btn-secondary:disabled,.alm-btn-primary:disabled{opacity:.6;cursor:not-allowed}.alm-popup-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999}.alm-popup{background:#fff;padding:20px;border-radius:10px;width:90%;max-width:320px;text-align:center}.alm-popup p{margin-bottom:16px;font-size:14px}.alm-popup button{padding:8px 16px;border-radius:6px;border:none;cursor:pointer}.alm-popup.success p{color:#15803d}.alm-popup.error p{color:#b91c1c}.eld-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:3000}.eld-modal{width:100%;max-width:540px;background:#fff;border-radius:12px;box-shadow:0 24px 48px #02102b24;display:flex;flex-direction:column;overflow:hidden}.eld-header{padding:14px 16px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.eld-header h3{margin:0;font-size:16px;font-weight:700}.eld-close{background:none;border:none;cursor:pointer}.eld-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.eld-status{width:fit-content;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:700}.eld-status.pending,.eld-status-inline.pending{background:#fff7ed;color:#c2410c}.eld-status.approved,.eld-status-inline.approved{background:#dcfce7;color:#166534}.eld-status.rejected,.eld-status-inline.rejected{background:#fee2e2;color:#991b1b}.eld-row{display:flex;justify-content:space-between;gap:12px}.eld-label{align-content:center;font-size:13px;font-weight:600;color:#334155;flex-shrink:0}.eld-value{font-size:14px;color:#0f172a;text-align:right;max-width:65%;word-break:break-word}.eld-status-inline{padding:6px 12px;border-radius:5px;font-size:13px;font-weight:700;text-transform:uppercase}.eld-view-btn{padding:8px 12px;border-radius:10px;background:var(--primary);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer}.eld-footer{padding:12px;border-top:1px solid #f1f5f9}.eld-close-btn{width:100%;padding:12px;border-radius:12px;background:#fff;border:1px solid #e6eef6;font-size:14px;font-weight:600;cursor:pointer}.eld-image-overlay{position:fixed;inset:0;background:#020617a6;display:flex;align-items:center;justify-content:center;z-index:4000;padding:16px}.eld-image-modal{position:relative;background:#fff;border-radius:12px;padding:12px;max-width:92vw;max-height:85vh;box-shadow:0 24px 48px #02102b33}.eld-image-close{position:absolute;top:10px;right:10px;background:#0009;border:none;color:#fff;border-radius:50%;padding:6px;cursor:pointer}.eld-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:10px}:root{--bg: #f6f7fb;--card: #ffffff;--muted: #6b7280;--accent: #5b8def;--danger: #991b1b;--glass: rgba(255, 255, 255, .6)}.ap-root{padding:18px;background:var(--bg);min-height:100%;font-family:Inter,system-ui,-apple-system}.ap-header{margin-bottom:12px}.ap-title{margin:0;font-size:20px;font-weight:700}.ap-card.soft{background:var(--card);border-radius:14px;padding:16px;box-shadow:0 10px 30px #1118270f;display:flex;flex-direction:column;gap:12px}.ap-label{font-weight:600;color:#374151;font-size:13px;margin-bottom:6px}.ap-select,.ap-input,.ap-textarea,.ap-file{padding:10px 12px;border-radius:10px;border:1px solid #e6e9ee;background:#fbfcff;outline:none;font-size:14px}.ap-select{appearance:none;-webkit-appearance:none}.ap-textarea{min-height:100px;resize:vertical}.ap-row{display:flex;gap:12px}.ap-field{flex:1;display:flex;flex-direction:column}.ap-file-preview{font-size:13px;color:var(--muted);margin-top:6px}.ap-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.ap-cancel{padding:10px 12px;border-radius:10px;background:#fff;border:1px solid #e6e9ee;cursor:pointer}.ap-submit{padding:10px 12px;border-radius:10px;background:var(--accent);color:#fff;border:none;cursor:pointer;box-shadow:0 8px 24px #5b8def2e}.ap-error{color:var(--danger);background:#ef44440f;padding:8px;border-radius:8px;font-weight:600}:root{--bg: #f6f7fb;--card: #ffffff;--muted: #6b7280;--accent: #5b8def;--success: #10b981;--danger: #991b1b}.ld-root{padding:18px;min-height:100%;font-family:Inter,system-ui,-apple-system;background:var(--bg)}.ld-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ld-title{margin:0;font-size:20px;font-weight:700}.ld-back{background:transparent;border:none;color:var(--accent);font-weight:700;cursor:pointer}.ld-card.soft{background:var(--card);border-radius:14px;padding:16px;box-shadow:0 10px 30px #1118270f}.ld-status{display:inline-block;padding:8px 12px;border-radius:999px;color:#fff;font-weight:700;margin-bottom:12px}.ld-status.pending{background:#f59e0b}.ld-status.approved{background:var(--success)}.ld-status.rejected{background:var(--danger)}.ld-grid{display:flex;flex-direction:column;gap:12px;margin-top:8px}.ld-row{display:flex;gap:12px;align-items:flex-start}.ld-label{width:110px;color:var(--muted);font-weight:600;font-size:13px}.ld-value{flex:1;color:#0f172a;font-size:14px}.ld-attach{color:var(--accent);font-weight:700;text-decoration:none}.ld-empty{text-align:center;padding:18px;color:var(--muted)}.ld-error{color:var(--danger);background:#ef44440f;border-radius:10px;padding:8px}.notes-page{padding:16px 16px 90px;background:#f7f8fa;font-family:Inter,sans-serif;display:flex;flex-direction:column;align-items:center}.page-title{width:100%;max-width:720px;font-size:22px;font-weight:600;margin-bottom:16px;color:#1f2937;text-align:left}.notes-input-card{width:100%;max-width:720px;background:#fff;padding:16px;border-radius:14px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;box-sizing:border-box}.notes-input-card textarea{width:100%;min-height:100px;resize:none;padding:12px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:15px;font-family:inherit;color:#374151;background:#fafafa;transition:.2s ease;box-sizing:border-box}.notes-input-card textarea:focus{border-color:#1976d2;background:#fff}.add-btn{width:100%;margin-top:12px;padding:12px;border-radius:10px;background:#1976d2;color:#fff;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:background .25s}.add-btn:hover{background:#125da0}.notes-list{width:100%;max-width:720px;margin-top:10px}.empty-msg{text-align:center;color:#6b7280;font-size:14px;margin-top:20px}.note-card{display:flex;justify-content:space-between;background:#fff;padding:16px;border-radius:14px;margin-bottom:14px;align-items:flex-start;box-shadow:0 1px 6px #00000012;border-left:4px solid #1976d2;animation:fadeIn .2s ease;width:100%;box-sizing:border-box}.note-left{max-width:80%}.note-text{font-size:15px;font-weight:500;color:#1f2937;margin-bottom:6px;line-height:1.5;word-break:break-word}.note-date{font-size:12px;color:#6b7280}.note-actions button{background:#f5f5f5;border:none;border-radius:50%;padding:8px;cursor:pointer;transition:.2s ease}.note-actions button:hover{background:#ffe5e5}.delete-btn svg{stroke:#d32f2f}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.title-input{width:100%;padding:12px;border-radius:10px;border:1px solid #d1d5db;background:#fafafa;margin-bottom:12px;font-weight:600;font-size:15px;color:#1f2937;outline:none;transition:.2s ease}.title-input:focus{border-color:#1976d2;background:#fff}.note-title{font-size:16px;font-weight:600;color:#111827;margin-bottom:4px}.employee-holidays-page{padding:10px;background:var(--bg);min-height:100vh}.employee-holidays-title{text-align:center;font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:18px;padding:10px;background-color:#fff;border:1px solid #e5e7eb;border-radius:10px}.employee-holidays-grid{display:flex;flex-direction:column;gap:14px}.employee-holiday-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:var(--transition)}.employee-holiday-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.employee-holiday-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.employee-holiday-icon{width:44px;height:44px;border-radius:12px;background:#0369a11a;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.employee-holiday-content{display:flex;flex-direction:column;gap:4px;min-width:0}.employee-holiday-name{font-size:13px;font-weight:700;color:var(--text-dark);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-holiday-desc{font-size:13px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-holiday-date{margin-left:12px;padding-left:12px;border-left:1px solid var(--border);font-size:11px;font-weight:700;color:var(--accent);white-space:nowrap}.employee-holidays-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}.hm-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;justify-content:center;align-items:center;padding:18px;z-index:4000}.hm-box{width:100%;max-width:720px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);animation:slideUp .25s ease;overflow:hidden}.hm-header{padding:14px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.hm-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text)}.hm-close{background:transparent;border:none;cursor:pointer;color:var(--muted)}.hm-body{padding:18px;text-align:center}.hm-icon{width:50px;height:50px;background:#dbeafe;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);margin:0 auto 12px}.hm-title{font-size:18px;font-weight:700;margin-bottom:6px}.hm-date{font-size:13px;color:var(--muted);margin-bottom:10px}.hm-desc{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.4}.hm-footer{padding:14px 18px;border-top:1px solid var(--border)}.hm-btn{width:100%;padding:12px;background:var(--primary);color:#fff;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer;transition:var(--transition)}.hm-btn:hover{background:#075985}.vep-page{padding:10px;background:var(--bg);min-height:100%}.vep-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.vep-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.vep-subtitle{font-size:14px;color:var(--text-light);padding-bottom:14px;border-bottom:1px solid #e5e7eb}.vep-empty{text-align:center;margin-top:40px;font-size:14px;color:var(--text-light)}.vep-list{display:flex;flex-direction:column;gap:14px}.vep-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;display:flex;flex-direction:column;gap:12px;transition:var(--transition)}.vep-card-top{display:flex;align-items:flex-start;width:100%}.vep-card-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.vep-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.vep-card-info{display:flex;flex-direction:column;gap:4px;min-width:0}.vep-card-title{font-size:13px;font-weight:700;color:var(--text-dark);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vep-card-desc{font-size:13px;color:var(--text-light);margin:0;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vep-card-right{padding-left:12px;margin-left:12px;border-left:1px solid var(--border);display:flex;align-items:center;white-space:nowrap}.vep-status{padding:6px 10px;font-size:11px;font-weight:700;border-radius:5px;text-transform:capitalize}.vep-status.pending{background:#fff7ed;color:#c2410c}.vep-status.approved{background:#dbeafe;color:#2563eb}.vep-status.rejected{background:#fee2e2;color:#991b1b}.vep-status.completed{background:#dcfce7;color:#166534}.vep-action-btn{width:100%;padding:10px;border-radius:10px;font-weight:700;display:flex;justify-content:center;gap:8px;border:none;cursor:pointer}.vep-action-btn.primary{background:var(--primary);color:#fff}.vep-action-btn.ghost{background:#e2e8f0;color:#0f172a}.vep-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:3000}.vep-modal,.vep-image-modal{background:#fff;border-radius:var(--radius);padding:20px;position:relative;max-width:380px;width:100%;box-shadow:var(--shadow-md)}.vep-image-modal{max-width:90%}.vep-modal-close{position:absolute;top:12px;right:12px;cursor:pointer}.vep-modal-title{text-align:center;margin-bottom:14px}.vep-file-input{width:100%;padding:10px;border-radius:8px;border:1px solid var(--border);margin-bottom:14px}.vep-primary-btn{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-weight:700}.vep-image-preview{max-width:100%;max-height:80vh;object-fit:contain;border-radius:12px}.vep-modal-overlay{display:flex;align-items:center;justify-content:center}.vep-image-modal{background:#fff;padding:12px;border-radius:14px;position:relative;max-width:92vw;max-height:85vh;display:flex;align-items:center;justify-content:center;box-shadow:0 24px 48px #02102b2e}.vep-modal-close{position:absolute;top:10px;right:10px;cursor:pointer;color:#475569;z-index:2}.vep-image-preview{max-width:100%;max-height:80vh;width:auto;height:auto;object-fit:contain;border-radius:10px}.vep-search{margin-bottom:12px}.vep-search input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;outline:none}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text-dark: #0f172a;--text-light: #64748b;--primary: #0369a1;--accent: #0284c7;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .05);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .2s ease}.ann-view-page{padding:10px;background:var(--bg);min-height:100vh}.ann-view-title{text-align:center;font-size:22px;font-weight:700;color:var(--text-dark);margin-bottom:18px;padding:10px;background-color:#fff;border:1px solid #e5e7eb;border-radius:10px}.ann-view-list{display:flex;flex-direction:column;gap:14px}.ann-view-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:var(--transition)}.ann-view-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.ann-view-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.ann-view-icon{width:44px;height:44px;border-radius:12px;background:#0369a11a;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ann-view-info{display:flex;flex-direction:column;gap:4px;min-width:0}.ann-title{font-size:13px;font-weight:700;color:var(--text-dark);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ann-message{font-size:13px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ann-view-date{margin-left:12px;padding-left:12px;border-left:1px solid var(--border);font-size:11px;font-weight:700;color:var(--accent);white-space:nowrap}.ann-empty{text-align:center;margin-top:32px;font-size:14px;color:var(--text-light)}:root{--card: #ffffff;--border: #e2e8f0;--bg-overlay: rgba(15, 23, 42, .55);--text: #0f172a;--muted: #64748b;--primary: #0369a1;--radius: 14px;--shadow: 0 8px 28px rgba(0,0,0,.12);--transition: .2s ease}.ann-modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;justify-content:center;align-items:center;padding:18px;z-index:4000;overflow-y:auto}.ann-modal-box{width:100%;max-width:720px;max-height:90vh;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);animation:slideUp .25s ease;overflow-y:auto}.ann-modal-header{padding:14px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff;z-index:2}.ann-modal-header h3{font-size:18px;font-weight:700;color:var(--text)}.ann-modal-close{background:transparent;border:none;cursor:pointer;color:var(--muted)}.ann-modal-body{padding:18px;text-align:center}.ann-modal-icon{width:50px;height:50px;background:#dbeafe;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);margin:0 auto 12px}.ann-modal-title{font-size:18px;font-weight:700;margin-bottom:6px;color:var(--text)}.ann-modal-msg{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.5}.ann-modal-date{margin-top:10px;font-size:12px;color:var(--muted)}.ann-modal-footer{padding:14px 18px;border-top:1px solid var(--border);background:#fff;position:sticky;bottom:0}.ann-modal-btn{width:100%;padding:12px;background:var(--primary);color:#fff;border-radius:var(--radius);border:none;font-weight:700;cursor:pointer;transition:var(--transition)}.ann-modal-btn:hover{background:#075985}:root{--bg: #F8FAFC;--card: #FFFFFF;--border: #E2E8F0;--primary: #0369A1;--text-dark: #0F172A;--text-light: #64748B;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0,0,0,.05);--shadow-md: 0 8px 28px rgba(0,0,0,.08);--transition: .2s ease}.mpp-page{padding:10px;background:var(--bg);min-height:100%}.mpp-header{margin-bottom:16px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.mpp-header h2{font-size:22px;font-weight:700;color:var(--text-dark)}.mpp-subtitle{font-size:14px;color:var(--text-light);padding-bottom:14px;border-bottom:1px solid #e5e7eb}.mpp-card-right{padding-left:12px;margin-left:12px;border-left:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.mpp-empty{text-align:center;margin-top:40px;font-size:14px;color:var(--text-light)}.mpp-list{display:flex;flex-direction:column;gap:14px}.mpp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:var(--transition)}.mpp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.mpp-card-left{display:flex;align-items:center;gap:12px}.mpp-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.mpp-card-info{display:flex;flex-direction:column;gap:4px}.mpp-card-title{font-size:13px;font-weight:700;color:var(--text-dark);margin:0}.mpp-card-desc{font-size:13px;color:var(--text-light);margin:0;line-height:1.3}.mpp-code{font-size:11px;color:var(--text-light);font-weight:600}.mpp-status{display:inline-block;margin-top:6px;padding:6px 10px;font-size:11px;font-weight:700;border-radius:5px;text-transform:capitalize}.mpp-status.not-started{background:#eef2ff;color:#4338ca}.mpp-status.in-progress{background:#dbeafe;color:#2563eb}.mpp-status.completed{background:#d1fae5;color:#059669}.mpp-card{display:flex;justify-content:space-between;align-items:flex-start}.pd-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:4000}.pd-modal{width:100%;max-width:720px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 24px 48px #02102b2e;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.pd-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.pd-header h3{margin:0;font-size:16px;font-weight:700;color:#0f172a}.pd-close{background:none;border:none;cursor:pointer;color:#64748b;transition:.2s ease}.pd-close:hover{color:#0f172a}.pd-body{padding:10px;display:flex;flex-direction:column;gap:14px}.pd-row{display:flex;flex-direction:column;gap:4px}.pd-label{font-size:13px;font-weight:600;color:#475569}.pd-value{font-size:13px;font-weight:600;color:#0f172a}.pd-value.muted{color:#64748b}.pd-code{color:#64748b;font-weight:600}.pd-status{align-self:flex-start;padding:6px 10px;border-radius:5px;font-size:12px;font-weight:700;text-transform:capitalize}.pd-status.not-started{background:#e0e7ff;color:#4338ca}.pd-status.in-progress{background:#dbeafe;color:#2563eb}.pd-status.completed{background:#d1fae5;color:#059669}.pd-team{display:flex;flex-direction:column;gap:8px}.pd-member{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0}.pd-avatar{width:34px;height:34px;border-radius:50%;background:#0369a1;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.pd-member-name{font-size:14px;font-weight:600;color:#0f172a}.pd-footer{padding:14px 16px;border-top:1px solid #e2e8f0}.pd-close-btn{width:100%;padding:12px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;font-size:14px;font-weight:700;color:#0f172a;cursor:pointer;transition:.2s ease}.pd-close-btn:hover{background:#f1f5f9}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--muted: #64748b;--primary: #0369a1;--danger: #dc2626;--success: #16a34a;--warning: #f59e0b;--radius: 14px;--shadow: 0 6px 14px rgba(0,0,0,.06)}.docs-page{max-width:900px;margin:0 auto;padding:20px 14px;background:var(--bg);min-height:100%}.docs-header{margin-bottom:16px;text-align:center;padding:12px;background:#fff;border-radius:10px;border:1px solid var(--border)}.docs-title{font-size:22px;font-weight:700}.docs-subtitle{font-size:12px;color:var(--muted);margin-top:4px;padding-bottom:5px;border-bottom:1px solid #e5e7eb}.doc-error{background:#dc26261a;color:var(--danger);border:1px solid rgba(220,38,38,.25);padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:14px}.upload-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center;margin-bottom:20px}.upload-box select,.upload-box input[type=file]{padding:10px;font-size:13px;border-radius:10px;border:1px solid var(--border);background:#fff}.upload-box button{padding:10px 16px;border-radius:10px;border:none;background:var(--primary);color:#fff;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap}.upload-box button:disabled{opacity:.6;cursor:not-allowed}.doc-list{display:flex;flex-direction:column;gap:12px}.doc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;display:flex;justify-content:space-between;align-items:center;gap:12px}.doc-left{display:flex;flex-direction:column;gap:10px}.doc-type{font-size:13px;font-weight:700}.doc-file{font-size:12px;color:var(--muted);word-break:break-word}.doc-status{display:inline-block;margin-top:6px;padding:3px 8px;font-size:11px;font-weight:700;border-radius:999px;width:fit-content}.doc-status.pending{background:#f59e0b26;color:var(--warning)}.doc-status.approved{background:#16a34a26;color:var(--success)}.doc-status.rejected{background:#dc262626;color:var(--danger)}.view-btn{padding:8px 14px;font-size:12px;font-weight:700;border-radius:10px;background:#0f172a;color:#fff;text-decoration:none;white-space:nowrap}.muted{text-align:center;color:var(--muted);font-size:13px;margin-top:12px}@media(max-width:768px){.upload-box{grid-template-columns:1fr}.doc-card{flex-direction:row;align-items:flex-start}.view-btn{align-self:flex-end}}.edit-select{width:100%;padding:10px;font-size:13px;border-radius:10px;border:1px solid var(--border);background:#fff;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-box input[type=file]{width:100%;max-width:100%;box-sizing:border-box}@media(max-width:768px){.upload-box{grid-template-columns:1fr;gap:12px}}.upload-box>*{width:100%;min-width:0}.export-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999}.export-modal{background:#fff;padding:24px 28px;border-radius:14px;width:90%;max-width:380px;text-align:center;box-shadow:0 10px 30px #00000026;animation:exportModalIn .25s ease-out}.export-modal h3{margin-bottom:8px;font-size:18px;font-weight:600;color:#16a34a}.export-modal p{font-size:14px;color:#555;margin-bottom:20px;line-height:1.5}.export-modal button{background:#16a34a;color:#fff;border:none;padding:10px 26px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s ease,transform .1s ease}.export-modal button:hover{background:#15803d;transform:translateY(-1px)}.export-modal button:active{transform:translateY(0)}@keyframes exportModalIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.export-modal{padding:20px;max-width:92%}.export-modal h3{font-size:16px}.export-modal p{font-size:13px}}.upload-page{background:#f8fafc;min-height:100%;font-family:Inter,sans-serif}.page-title{font-size:20px;font-weight:600;margin:5px;color:#1e293b}.upload-card{background:#fff;padding:16px;margin:16px;border-radius:12px;box-shadow:0 2px 10px #0000000f}.upload-card input[type=file]{margin-bottom:14px}.upload-card input[type=text]{width:100%;padding:10px;border-radius:8px;border:1px solid #E2E8F0;margin-bottom:14px}.upload-btn{width:100%;background:#1e3a8a;padding:12px;border-radius:10px;color:#fff;border:none;cursor:pointer}.upload-btn:hover{background:#162d67}.profile-container{max-width:720px;margin:auto;padding:10px;text-align:center;font-family:Inter,sans-serif}.profile-title{font-size:22px;font-weight:700;margin-bottom:16px}.avatar-section{display:flex;flex-direction:column;align-items:center;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.avatar-wrapper{position:relative;cursor:pointer;transition:.3s ease}.avatar-wrapper:hover{transform:scale(1.03)}.avatar-img,.avatar-placeholder{width:115px;height:115px;border-radius:50%;object-fit:cover;background:#e5e7eb;display:flex;justify-content:center;align-items:center;border:3px solid #f3f4f6;box-shadow:0 3px 10px #00000014;transition:.25s ease-in-out}.avatar-edit{position:absolute;bottom:4px;right:4px;background:#0369a1;padding:6px;border-radius:50%;color:#fff;border:2px solid white;display:flex;justify-content:center;align-items:center;transition:.25s ease-in-out}.avatar-wrapper:hover .avatar-edit{background:#0284c7;transform:scale(1.1)}.profile-name{font-size:20px;margin-top:12px;font-weight:600}.profile-role{font-size:13px;font-weight:600;color:#0369a1;letter-spacing:1px;margin-top:2px}.menu-list{margin-top:12px}.menu-item{display:flex;align-items:center;gap:12px}.menu-item .arrow{margin-left:auto;text-align:right;font-size:18px;color:#94a3b8}.menu-item{background:#fff;display:flex;align-items:center;gap:14px;padding:16px;border-radius:12px;margin-bottom:10px;border:1px solid #f1f1f1;cursor:pointer;transition:.2s ease}.menu-item:hover{background:#f8fafc}.menu-item span{flex:1;text-align:left;font-size:15px}.arrow{text-align:right;font-size:20px;color:#9ca3af}.logout-btn{width:100%;margin-top:25px;padding:14px;background:#0369a1;color:#fff;border:none;border-radius:12px;font-size:16px;cursor:pointer;transition:.2s ease}.logout-btn:hover{background:#0284c7}.success-modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:9999}.success-modal{background:#fff;border-radius:16px;padding:24px;width:90%;max-width:320px;text-align:center;box-shadow:0 10px 30px #00000026;animation:popIn .25s ease}.success-modal h3{margin-top:12px;font-size:18px;font-weight:700;color:#0f172a}.success-modal p{margin:8px 0 18px;font-size:14px;color:#475569}.success-btn{padding:10px 18px;border-radius:10px;border:none;background:#0369a1;color:#fff;font-weight:700;cursor:pointer}@keyframes popIn{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.profile-container .menu-item{cursor:pointer}.profile-container button.menu-item{width:100%;margin-top:1rem;padding:.85rem 1rem;display:flex;align-items:center;gap:.6rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.6rem;font-size:1rem;font-weight:500;color:#0f172a}.profile-container button.menu-item:hover{background:#e2e8f0}.profile-container button.menu-item:active{transform:scale(.98)}@media(min-width:480px){.profile-container button.menu-item{width:10;align-self:center;padding:.85rem 1.5rem}}:root{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--primary: #0284c7;--primary-dark: #0369a1;--danger: #dc2626;--radius: 14px;--shadow-sm: 0 2px 10px rgba(0, 0, 0, .06);--shadow-md: 0 6px 20px rgba(0, 0, 0, .08)}.edit-container{max-width:720px;margin:0 auto;padding:12px;min-height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg)}.edit-header{display:flex;align-items:center;gap:10px;padding:12px;margin-bottom:14px;background:var(--card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.edit-header h2{font-size:18px;font-weight:700;color:var(--text-dark)}.back-icon{cursor:pointer;color:var(--text-light);transition:.2s ease}.back-icon:hover{color:var(--text-dark)}.edit-form{background:var(--card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:10px}.edit-form label{font-size:12px;font-weight:600;color:var(--text-light)}.edit-form input,.edit-form select,.edit-form textarea{width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--border);font-size:14px;font-family:inherit;color:var(--text-dark);background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.edit-form textarea{resize:vertical;min-height:70px}.edit-form input:focus,.edit-form select:focus,.edit-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0284c726}.edit-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 18px) calc(1em + 2px),calc(100% - 13px) calc(1em + 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}.disabled-input{background:#f1f5f9;color:#64748b;cursor:not-allowed}.edit-error{background:#fee2e2;color:#991b1b;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.save-btn{margin-top:12px;background:var(--primary);color:#fff;border:none;padding:13px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .15s ease}.save-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.save-btn:active{transform:translateY(0)}.edit-skeleton{height:260px;border-radius:var(--radius);background:linear-gradient(90deg,#e5e7eb,#f1f5f9,#e5e7eb);background-size:200% 100%;animation:shimmer 1.3s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.confirm-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:999}.confirm-modal{background:#fff;padding:22px;border-radius:14px;width:90%;max-width:360px;text-align:center;box-shadow:var(--shadow-md)}.confirm-modal h3{margin-bottom:10px;font-size:16px;font-weight:700}.confirm-modal p{font-size:14px;color:var(--text-light)}.confirm-actions{display:flex;gap:10px;margin-top:20px}.cancel-btn{flex:1;background:#e5e7eb;color:#334155;border:none;padding:11px;border-radius:10px;cursor:pointer}.confirm-btn{flex:1;background:var(--primary-dark);color:#fff;border:none;padding:11px;border-radius:10px;cursor:pointer}:root{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text-dark: #0f172a;--text-light: #64748b;--primary: #0284c7;--primary-dark: #0369a1;--danger: #dc2626;--success: #16a34a;--radius: 14px;--shadow: 0 6px 20px rgba(0, 0, 0, .08)}.change-container{max-width:720px;margin:auto;padding:20px}.change-header{margin-bottom:16px;display:flex;flex-direction:row;align-items:center;text-align:center;margin-bottom:var(--space-l);gap:6px;padding:10px;background-color:#fff;border-radius:10px;border:1px solid #e5e7eb}.change-header h2{font-size:22px;color:var(--text-dark)}.back-icon{cursor:pointer;color:var(--text-light)}.change-form{background:var(--card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}.change-form label{font-size:13px;font-weight:600;color:var(--text-light)}.change-form input{padding:10px 12px;border-radius:10px;border:1px solid var(--border);font-size:14px;font-family:inherit}.change-note{text-align:center;border-bottom:1px solid #e5e7eb;padding-bottom:10px;font-size:13px;color:var(--text-light)}.change-error{background:#fee2e2;color:#991b1b;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.change-success{background:#dcfce7;color:#166534;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.save-btn{margin-top:10px;background:var(--primary);color:#fff;border:none;padding:12px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:.2s ease}.save-btn:hover{background:var(--primary-dark)}.save-btn:disabled{opacity:.6;cursor:not-allowed}:root{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--primary: #0369a1;--text-dark: #0f172a;--text-light: #64748b;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .05);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .2s ease}.ead-page{padding:10px;background:var(--bg);min-height:100%}.ead-header{text-align:center;gap:6px;padding:10px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;margin-bottom:14px}.ead-header h2{font-size:22px;font-weight:700}.ead-subtitle{font-size:14px;color:var(--text-light);padding-bottom:10px;border-bottom:1px solid #e5e7eb}.ead-summary{display:flex;justify-content:space-between;gap:10px;margin-bottom:14px}.ead-summary div{flex:1;background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}.ead-summary strong{display:block;font-size:16px}.ead-summary span{font-size:12px;color:var(--text-light)}.ead-form{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.ead-form input,.ead-form textarea{padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;font-size:14px}.ead-form button{padding:12px;border-radius:10px;background:var(--primary);color:#fff;font-size:14px;font-weight:700;border:none;cursor:pointer}.ead-form button:disabled{opacity:.6}.ead-list{display:flex;flex-direction:column;gap:14px}.ead-empty{text-align:center;margin-top:30px;font-size:14px;color:var(--text-light)}.ead-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;display:flex;justify-content:space-between;cursor:pointer;transition:var(--transition)}.ead-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.ead-card-left{display:flex;align-items:center;gap:12px}.ead-icon{width:44px;height:44px;border-radius:12px;background:#0369a114;color:var(--primary);display:flex;align-items:center;justify-content:center}.ead-card-info{display:flex;flex-direction:column;gap:4px}.ead-card-title{font-size:14px;font-weight:700}.ead-card-desc{font-size:13px;color:var(--text-light)}.ead-card-right{display:flex;align-items:center}.ead-status{padding:6px 10px;font-size:12px;font-weight:700;border-radius:6px}.ead-status.pending{background:#fff7ed;color:#c2410c}.ead-status.approved{background:#dcfce7;color:#166534}.ead-status.rejected{background:#fee2e2;color:#991b1b}.ead-request-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;margin:14px 0 18px;background:#0369a1;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:0 8px 22px #0369a159}.ead-request-btn:hover{background:#0284c7;transform:translateY(-2px);box-shadow:0 12px 28px #0369a173}.ead-request-btn:active{transform:translateY(0);box-shadow:0 6px 16px #0369a14d}.ead-request-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.ead-request-btn svg{flex-shrink:0}.eam-overlay{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;z-index:3000;padding:16px}.eam-modal{width:100%;max-width:720px;background:#fff;border-radius:14px;box-shadow:0 24px 48px #02102b24;overflow:hidden}.eam-header{padding:14px 16px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.eam-header h3{font-size:16px;font-weight:700}.eam-close{background:none;border:none;cursor:pointer}.eam-body{padding:16px;display:flex;flex-direction:column;gap:12px}.eam-body input,.eam-body textarea{padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb;font-size:14px}.eam-body button{padding:12px;border-radius:10px;background:#0369a1;color:#fff;font-weight:700;border:none}.eam-body button:disabled{opacity:.6}.login{min-height:100vh;background:var(--bg-light);display:flex;justify-content:center;align-items:center;padding:24px}.login__card{width:100%;max-width:380px;background:#fff;padding:32px 26px;border-radius:var(--radius);box-shadow:0 6px 20px #00000014;border:1px solid #e2e8f0}.login__logo-box{display:flex;justify-content:center;margin-bottom:12px}.login__logo{width:140px;height:auto}.login__title{border:1px solid #e5e7eb;border-radius:10px 30px;padding:10px;background-color:#f0f8ff;text-align:center;font-size:12px;font-weight:800;color:var(--primary-dark);margin-bottom:18px}.login__error{text-align:center;color:var(--danger, #dc2626);font-size:14px;margin-bottom:14px}.login__form{margin-top:8px}.login__field{margin-bottom:16px}.login__field label{display:block;font-size:14px;color:var(--text-dark);font-weight:500;margin-bottom:6px}.login__field input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #cbd5e1;background:#f8fafc;font-size:14px;transition:var(--transition);outline:none}.login__field input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #1a73e840}.login__btn{width:100%;padding:12px;margin-top:6px;border-radius:10px;background:var(--primary);border:none;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:var(--transition)}.login__btn:hover{background:#135fbd}.login__btn:disabled{opacity:.6;cursor:not-allowed}:root{--primary: #1A73E8;--primary-dark: #001B5E;--text-dark: #1E293B;--text-light: #64748B;--bg-light: #FFFFFF;--bg-gray: #F7F9FC;--radius: 12px;--transition: .25s ease;--font-main: "Inter", "Poppins", sans-serif}body{margin:0;padding:0;font-family:var(--font-main);background:var(--bg-light);color:var(--text-dark)}:root{--bg: #F8FAFC;--card: #FFFFFF;--border: #E2E8F0;--text-dark: #0F172A;--muted: #64748B;--primary: #0369A1;--radius: 14px;--shadow-sm: 0 3px 12px rgba(0, 0, 0, .06);--shadow-md: 0 8px 28px rgba(0, 0, 0, .08);--transition: .22s cubic-bezier(.2, .9, .2, 1)}.profile-page{min-height:100%;background:var(--bg);padding:10px}.profile-header-card{background:var(--card);padding:26px 18px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:center;margin-bottom:24px;animation:fadeUp .35s ease}@keyframes fadeUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-avatar-wrapper{width:86px;height:86px;margin:0 auto 12px}.profile-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid #E2E8F0;box-shadow:var(--shadow-sm)}.profile-avatar-placeholder{width:100%;height:100%;border-radius:50%;display:flex;justify-content:center;align-items:center;background:#e2e8f0;color:var(--muted);font-size:12px;border:2px solid var(--border)}.profile-name{font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:4px}.profile-email{font-size:13px;color:var(--muted)}.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.profile-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 6px;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:var(--transition);cursor:pointer}.profile-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}.profile-card-icon{width:45px;height:45px;border-radius:50%;background:#0369a114;display:flex;justify-content:center;align-items:center;color:var(--primary);box-shadow:0 6px 18px #0369a10f;margin-bottom:8px;transition:.2s ease}.profile-card:hover .profile-card-icon{transform:scale(1.08)}.profile-card-label{font-size:10px;color:var(--text-dark);text-align:center}#root{margin:0!important;padding:0!important;width:100%;min-height:100%;text-align:left}.logo,.card,.read-the-docs{all:unset}body.modal-open{overflow:hidden;height:100%}:root{--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom)}@supports (padding: constant(safe-area-inset-top)){:root{--safe-top: constant(safe-area-inset-top);--safe-bottom: constant(safe-area-inset-bottom)}}
