@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--primary-900: #003A28;--primary-800: #006848;--primary-700: #007856;--primary-600: #008866;--primary-500: #009870;--primary-400: #4DB594;--primary-300: #80C9B0;--primary-200: #B3DCC9;--primary-100: #D9EDE3;--primary-50: #EDF7F2;--accent-teal: #009098;--accent-teal-bg: #E6F4F5;--accent-red: #E81828;--accent-red-bg: #FDE7E9;--accent-green: #006848;--accent-green-bg: #E6F0EC;--accent-amber: #F59E0B;--gray-900: #111827;--gray-800: #1f2937;--gray-700: #374151;--gray-600: #4b5563;--gray-500: #6b7280;--gray-400: #9ca3af;--gray-300: #d1d5db;--gray-200: #e5e7eb;--gray-100: #f3f4f6;--gray-50: #f9fafb;--white: #ffffff;--blue: #3b82f6;--orange: #f97316;--yellow: #f59e0b;--red: #ef4444;--purple: #8b5cf6;--green: #10b981;--sidebar-w: 240px;--sidebar-w-closed: 70px;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 10px 30px rgba(11,36,71,.15)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,sans-serif;background:var(--gray-50);color:var(--gray-900);font-size:14px}button{cursor:pointer;font-family:inherit;border:none;background:none}.font-mono{font-family:DM Mono,monospace}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,var(--primary-900) 0%,var(--primary-800) 100%);display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease;overflow:hidden}.sidebar.closed{width:var(--sidebar-w-closed)}.sidebar-logo{padding:18px 16px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.08);min-height:80px}.sidebar-logo-img{height:56px;width:auto;max-width:200px;transition:all .25s ease;object-fit:contain}.sidebar-logo-img.compact{height:42px;max-width:50px;object-position:left;object-fit:cover;width:50px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#fff9;font-size:13.5px;font-weight:500;transition:all .15s;position:relative;white-space:nowrap}.nav-item:hover{color:#fff;background:#ffffff12}.nav-item.active{color:#fff;background:var(--primary-700)}.nav-item.logout{color:#fff6;margin-top:4px}.nav-item.logout:hover{color:var(--red);background:#ef44441a}.nav-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent-amber);border-radius:2px}.sidebar-footer{padding:12px 8px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:2px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:4px}.user-avatar-sm{width:32px;height:32px;background:var(--primary-600);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.user-name-sm{color:#fff;font-size:13px;font-weight:600;display:block}.user-role-sm{color:var(--primary-300);font-size:11px;display:block}.powered-by{padding:8px 16px 14px;font-size:10.5px;color:#ffffff59;text-align:center;letter-spacing:.5px}.powered-by strong{color:#fff9}.main-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:64px;background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:16px;padding:0 24px;flex-shrink:0;box-shadow:var(--shadow)}.sidebar-toggle{padding:8px;border-radius:8px;color:var(--gray-600)}.sidebar-toggle:hover{background:var(--gray-100)}.hamburger{display:flex;flex-direction:column;gap:4px;width:18px}.hamburger span{display:block;height:2px;background:currentColor;border-radius:2px;transition:all .2s}.topbar-search{flex:1;max-width:400px;display:flex;align-items:center;gap:8px;background:var(--gray-100);border-radius:8px;padding:0 12px;height:38px}.search-icon{color:var(--gray-400);flex-shrink:0}.search-input{border:none;background:none;font-family:inherit;font-size:14px;flex:1;outline:none;color:var(--gray-900)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}.lang-switcher{display:flex;gap:2px;background:var(--gray-100);padding:3px;border-radius:8px}.lang-btn{padding:5px 10px;border-radius:6px;font-size:12px;font-weight:600;color:var(--gray-600);transition:all .15s}.lang-btn.active{background:var(--white);color:var(--primary-800);box-shadow:var(--shadow)}.icon-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--gray-600)}.icon-btn:hover{background:var(--gray-100)}.notif-btn{position:relative}.notif-badge{position:absolute;top:2px;right:2px;background:var(--red);color:#fff;font-size:10px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.notif-wrapper{position:relative}.notif-dropdown{position:absolute;top:44px;right:0;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);width:320px;z-index:100}.notif-header{padding:12px 16px;font-weight:600;font-size:13px;border-bottom:1px solid var(--gray-100)}.notif-item{padding:12px 16px;display:flex;gap:10px;align-items:flex-start}.notif-item:hover{background:var(--gray-50)}.notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}.notif-item.warning .notif-dot{background:var(--yellow)}.notif-item.danger .notif-dot{background:var(--red)}.notif-item.info .notif-dot{background:var(--blue)}.notif-text{font-size:13px;color:var(--gray-700)}.notif-time{font-size:11px;color:var(--gray-400)}.topbar-user{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;cursor:pointer}.topbar-user:hover{background:var(--gray-100)}.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-700),var(--primary-500));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700}.user-name{font-size:13.5px;font-weight:600;color:var(--gray-900)}.page-content{flex:1;overflow-y:auto;background:var(--gray-50)}.page-wrapper{padding:28px 32px;max-width:1600px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;color:var(--gray-900)}.page-subtitle{font-size:13.5px;color:var(--gray-500);margin-top:2px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}.grid-3-1{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:20px}@media(max-width:1024px){.grid-4,.grid-3,.grid-5{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3-1{grid-template-columns:1fr}.page-wrapper{padding:16px}}@media(max-width:640px){.grid-4,.grid-3{grid-template-columns:1fr}.grid-5{grid-template-columns:repeat(2,1fr)}.page-title{font-size:18px}}.card{background:var(--white);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.04);margin-bottom:20px}.card:last-child{margin-bottom:0}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14.5px;font-weight:600;color:var(--gray-900)}.kpi-card{background:var(--white);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.04);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.kpi-blue:before{background:var(--primary-700)}.kpi-green:before{background:var(--accent-green)}.kpi-orange:before{background:var(--orange)}.kpi-purple:before{background:var(--purple)}.kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.kpi-label{font-size:12px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.kpi-icon-wrap{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.icon-blue{background:var(--primary-50);color:var(--primary-700)}.icon-green{background:var(--accent-green-bg);color:var(--accent-green)}.icon-orange{background:#fff7ed;color:var(--orange)}.icon-purple{background:#f5f3ff;color:var(--purple)}.kpi-value{font-size:28px;font-weight:700;color:var(--gray-900);margin-bottom:6px;line-height:1}.kpi-change{font-size:12px;color:var(--gray-500)}.stars-row{display:flex;gap:2px;margin-top:6px}.country-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.country-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);border:2px solid;background:var(--gray-50)}.country-flag{font-size:32px}.country-info{flex:1}.country-name{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.country-count{font-size:26px;font-weight:800;line-height:1;margin:2px 0}.country-pct{font-size:11px;color:var(--gray-500)}.quick-stat-card{background:var(--white);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.04)}.quick-stat-icon{color:var(--primary-700);margin:0 auto 8px;display:block}.quick-stat-value{font-size:22px;font-weight:700;color:var(--gray-900)}.quick-stat-label{font-size:12px;color:var(--gray-500);margin-top:4px}.status-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--gray-100)}.status-legend-item{display:flex;align-items:center;gap:6px}.status-dot{width:10px;height:10px;border-radius:50%}.status-legend-label{font-size:12.5px;color:var(--gray-600)}.status-legend-val{font-size:12.5px;font-weight:700;color:var(--gray-900)}.team-grid{display:flex;flex-wrap:wrap;gap:10px}.team-avatar-wrap{position:relative}.team-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-100);color:var(--primary-800);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2.5px solid transparent;transition:transform .15s}.team-avatar.more{background:var(--gray-200);color:var(--gray-700)}.team-avatar:hover{transform:scale(1.1)}.team-status-dot{position:absolute;bottom:1px;right:1px;width:11px;height:11px;border-radius:50%;border:2px solid white}.activity-list{display:flex;flex-direction:column;gap:0}.activity-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--gray-100);align-items:flex-start}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-500);flex-shrink:0;margin-top:5px}.activity-icon-mini{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-text{font-size:13px;color:var(--gray-700);line-height:1.4}.activity-time{font-size:11px;color:var(--gray-400);margin-top:2px;display:block}.activity-content{flex:1}.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--primary-700);color:#fff;padding:9px 18px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--primary-800)}.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300);padding:9px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;transition:all .15s}.btn-secondary:hover{background:var(--gray-50)}.btn-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.full-width{width:100%;justify-content:center}.filters-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:6px;background:var(--white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);padding:0 12px;height:38px;min-width:280px}.search-icon-sm{color:var(--gray-400)}.search-input-sm{border:none;background:none;font-family:inherit;font-size:13.5px;flex:1;outline:none}.filter-group{display:flex;align-items:center;gap:8px;color:var(--gray-500);flex-wrap:wrap}.select-sm{border:1px solid var(--gray-300);border-radius:var(--radius-sm);padding:8px 10px;font-family:inherit;font-size:13.5px;background:var(--white);cursor:pointer;outline:none;color:var(--gray-700)}.filter-count{font-size:12.5px;color:var(--gray-400);margin-left:auto}.filter-pill{padding:5px 12px;border-radius:20px;font-size:12.5px;font-weight:500;color:var(--gray-600);border:1px solid var(--gray-200)}.filter-pill.active{background:var(--primary-700);color:#fff;border-color:var(--primary-700)}.card-filters{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;color:var(--gray-500)}.ml-auto{margin-left:auto}.table-layout{display:flex;gap:16px}.table-card{flex:1;min-width:0}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table th{text-align:left;padding:10px 12px;font-size:11.5px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--gray-100);white-space:nowrap;background:var(--gray-50)}.data-table td{padding:11px 12px;border-bottom:1px solid var(--gray-50);vertical-align:middle}.table-row{transition:background .1s;cursor:pointer}.table-row:hover{background:var(--gray-50)}.table-row.selected{background:var(--primary-50)}.employee-cell{display:flex;align-items:center;gap:10px}.emp-avatar{width:38px;height:38px;border-radius:50%;background:var(--primary-100);color:var(--primary-800);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.emp-avatar-sm{width:28px;height:28px;border-radius:50%;background:var(--primary-100);color:var(--primary-800);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.emp-name{font-weight:600;color:var(--gray-900);font-size:13.5px}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-gray{color:var(--gray-600)}.text-muted{color:var(--gray-400)}.text-green{color:var(--accent-green)}.text-red{color:var(--red)}.text-orange{color:var(--orange)}.font-medium{font-weight:600}.green-text{color:var(--accent-green)}.action-btns{display:flex;gap:4px}.action-btn{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--gray-500);border:1px solid var(--gray-200)}.action-btn:hover{background:var(--gray-100);color:var(--gray-900)}.action-btn.green:hover{background:var(--accent-green-bg);color:var(--accent-green);border-color:var(--accent-green)}.action-btn.red:hover{background:#fef2f2;color:var(--red);border-color:#fecaca}.reason-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--gray-600)}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-green{background:var(--accent-green-bg);color:var(--accent-green)}.badge-blue{background:var(--primary-50);color:var(--primary-700)}.badge-orange{background:#fff7ed;color:#c2410c}.badge-red{background:#fef2f2;color:#b91c1c}.badge-purple{background:#f5f3ff;color:#6d28d9}.badge-yellow{background:#fffbeb;color:#92400e}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-outline{background:transparent;color:var(--gray-600);border:1px solid var(--gray-200)}.days-badge{background:var(--primary-100);color:var(--primary-800);padding:3px 8px;border-radius:6px;font-size:12px;font-weight:700;font-family:DM Mono,monospace}.tab-badge{background:var(--accent-amber);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:6px}.profile-panel{width:300px;flex-shrink:0;height:fit-content}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.close-btn{color:var(--gray-400);padding:4px;border-radius:6px}.close-btn:hover{background:var(--gray-100);color:var(--gray-700)}.profile-hero{text-align:center;padding:16px 0;border-bottom:1px solid var(--gray-100);margin-bottom:16px}.profile-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary-700),var(--primary-400));color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}.profile-name{font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:2px}.profile-position{font-size:13px;color:var(--gray-500);margin-bottom:8px}.profile-section{margin-bottom:16px}.section-label{font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;display:block}.info-list{display:flex;flex-direction:column;gap:6px}.info-row{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;color:var(--gray-700)}.info-row svg{color:var(--primary-700);flex-shrink:0;margin-top:1px}.panel-actions{margin-top:4px}.tabs{display:flex;gap:4px;background:var(--gray-100);padding:4px;border-radius:var(--radius-sm);width:fit-content;margin-bottom:20px;flex-wrap:wrap}.tab{padding:7px 16px;border-radius:6px;font-size:13.5px;font-weight:500;color:var(--gray-600);transition:all .15s;display:inline-flex;align-items:center}.tab.active{background:var(--white);color:var(--primary-700);font-weight:600;box-shadow:var(--shadow)}.view-toggle{display:flex;gap:4px;background:var(--gray-100);padding:4px;border-radius:var(--radius-sm);width:fit-content}.toggle-btn{padding:7px 14px;border-radius:6px;font-size:13px;font-weight:500;color:var(--gray-600)}.toggle-btn.active{background:var(--white);color:var(--primary-700);font-weight:600;box-shadow:var(--shadow)}.vacation-map-header{background:var(--white);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.map-employee-selector{display:flex;align-items:center;gap:10px;color:var(--primary-700)}.map-emp-select{border:none;outline:none;font-family:inherit;font-size:14px;font-weight:600;color:var(--primary-900);background:transparent;cursor:pointer;min-width:280px}.map-stats{display:flex;gap:32px;flex-wrap:wrap}.map-stat{display:flex;flex-direction:column;align-items:center}.map-stat-label{font-size:11.5px;color:var(--gray-500);margin-bottom:4px}.map-stat-value{font-size:22px;font-weight:700;color:var(--primary-900)}.map-stat-select{border:1px solid var(--gray-300);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:13px;font-weight:600;color:var(--primary-900);cursor:pointer}.vacation-legend{background:var(--white);border-radius:var(--radius);padding:12px 20px;margin-bottom:16px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;box-shadow:var(--shadow)}.legend-spacer{flex:1}.legend-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--gray-700)}.legend-box{width:16px;height:16px;border-radius:3px}.legend-box.approved{background:var(--accent-green)}.legend-box.pending{background:#fb923c}.legend-box.holiday{background:#c5cb7c}.legend-box.weekend{background:var(--gray-200)}.cal-year-nav{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--gray-600)}.cal-year-nav:hover{background:var(--gray-100)}.cal-year-label{font-size:15px;font-weight:700;color:var(--primary-900);min-width:50px;text-align:center}.vacation-map-card{padding:16px}.vac-map-scroll{overflow-x:auto}.vacation-map-table{border-collapse:collapse;font-family:DM Mono,monospace;font-size:11px;width:100%}.vmt-month-head{width:36px}.vmt-day-head{width:28px;font-size:10.5px;font-weight:600;color:var(--gray-500);text-align:center;padding:4px 0;font-family:DM Sans,sans-serif}.vmt-month-cell{font-size:11.5px;font-weight:700;color:var(--gray-700);font-family:DM Sans,sans-serif;padding:6px 8px;text-transform:uppercase;letter-spacing:.3px}.vmt-day-cell{width:28px;height:32px;text-align:center;border:1px solid var(--gray-100);position:relative;vertical-align:middle;background:var(--white)}.vmt-day-num{display:block;font-size:11px;font-weight:600;color:var(--gray-700);line-height:1}.vmt-day-letter{display:block;font-size:8.5px;color:var(--gray-400);margin-top:1px;font-family:DM Sans,sans-serif}.vmt-empty{border:none}.vmt-weekend{background:var(--gray-100)}.vmt-weekend .vmt-day-num{color:var(--gray-500)}.vmt-holiday{background:#dce382}.vmt-holiday .vmt-day-num{color:#5c5c00;font-weight:700}.vmt-approved{background:var(--accent-green)}.vmt-approved .vmt-day-num,.vmt-approved .vmt-day-letter{color:#fff;font-weight:700}.vmt-pending{background:#fb923c}.vmt-pending .vmt-day-num,.vmt-pending .vmt-day-letter{color:#fff;font-weight:700}.progress-bar-bg{height:8px;background:var(--gray-100);border-radius:4px;position:relative;overflow:hidden}.progress-bar-fill{position:absolute;top:0;height:100%;border-radius:4px}.progress-bar-fill.used{background:var(--accent-green);left:0}.progress-bar-fill.pending-bar{background:var(--orange)}.clock-hero-card{background:linear-gradient(135deg,var(--primary-800),var(--primary-600));border-radius:var(--radius);padding:32px;margin-bottom:20px;position:relative;overflow:hidden;color:#fff;box-shadow:var(--shadow-lg)}.clock-hero-bg{position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}.clock-hero-content{position:relative;z-index:1}.clock-hero-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;flex-wrap:wrap;gap:16px}.clock-date{font-size:14px;font-weight:500;opacity:.85;text-transform:capitalize}.clock-status-line{font-size:13px;margin-top:4px;display:flex;align-items:center;gap:6px;opacity:.9}.clock-big{font-family:DM Mono,monospace;font-size:64px;font-weight:700;letter-spacing:-2px;line-height:1}.clock-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.clock-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 12px;background:#ffffff1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);color:#fff;font-size:14px;font-weight:600;transition:all .2s}.clock-btn:hover:not(.disabled){background:#ffffff38;transform:translateY(-2px)}.clock-btn-in:hover:not(.disabled){background:#10b98166;border-color:#10b98199}.clock-btn-out:hover:not(.disabled){background:#ef444466;border-color:#ef444499}.clock-btn-lunch:hover:not(.disabled){background:#f59e0b66;border-color:#f59e0b99}.clock-btn.disabled{opacity:.4;cursor:not-allowed}.clock-summary{display:flex;align-items:center;justify-content:space-around;background:#0000002e;border-radius:var(--radius);padding:16px;gap:12px;flex-wrap:wrap}.clock-summary-item{display:flex;flex-direction:column;align-items:center;min-width:80px}.cs-label{font-size:11px;opacity:.75;text-transform:uppercase;letter-spacing:.5px}.cs-value{font-size:20px;font-weight:700;font-family:DM Mono,monospace;margin-top:2px}.clock-summary-divider{width:1px;height:30px;background:#fff3}@media(max-width:640px){.clock-hero-card{padding:20px 16px}.clock-big{font-size:42px;letter-spacing:-1px}.clock-actions{grid-template-columns:1fr;gap:10px}.clock-btn{padding:16px 12px;flex-direction:row}.clock-summary-divider{display:none}.clock-summary{gap:8px}}.mobile-preview{display:flex;flex-direction:column;align-items:center;padding:12px 0}.phone-frame{width:220px;height:420px;background:var(--gray-900);border-radius:28px;padding:8px;box-shadow:var(--shadow-lg);position:relative}.phone-frame:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:60px;height:14px;background:var(--gray-900);border-radius:0 0 10px 10px;z-index:2}.phone-screen{background:linear-gradient(180deg,var(--primary-700),var(--primary-800));height:100%;border-radius:22px;padding:32px 16px 16px;display:flex;flex-direction:column;align-items:center;color:#fff}.mp-header{font-size:11px;font-weight:700;opacity:.85;letter-spacing:2px;text-transform:uppercase}.mp-time{font-family:DM Mono,monospace;font-size:42px;font-weight:700;margin:16px 0 0}.mp-date{font-size:11px;opacity:.85;text-transform:capitalize;margin-bottom:16px}.mp-status{font-size:11px;padding:4px 10px;background:#10b9814d;border-radius:12px;margin-bottom:24px}.mp-buttons{display:flex;flex-direction:column;gap:10px;width:100%;margin-bottom:auto}.mp-btn{padding:12px;border-radius:10px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px}.mp-btn.mp-in{background:#10b981d9;color:#fff}.mp-btn.mp-out{background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.3)}.mp-summary{font-size:11px;opacity:.85;margin-top:12px;padding-bottom:8px}.mobile-note{font-size:12px;color:var(--gray-500);text-align:center;margin-top:16px;line-height:1.5;max-width:280px}.stat-mini-card{padding:16px;border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow)}.stat-mini-val{font-size:26px;font-weight:700}.stat-mini-label{font-size:12px;color:var(--gray-500);margin-top:4px}.time-badge{background:var(--gray-100);color:var(--gray-800);padding:3px 8px;border-radius:6px;font-size:12.5px;font-weight:600;font-family:DM Mono,monospace}.time-badge.late{background:#fff7ed;color:#c2410c}.time-badge.working{background:var(--accent-green-bg);color:var(--accent-green)}.status-with-icon{display:flex;align-items:center;gap:6px}.attendance-rate-circle{display:flex;flex-direction:column;align-items:center;padding:16px 0}.rate-label{font-size:12.5px;color:var(--gray-400);margin-top:8px}.expense-detail-panel{width:380px;flex-shrink:0;height:fit-content;max-height:calc(100vh - 120px);overflow-y:auto}.expense-header-info{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--gray-100);margin-bottom:16px}.expense-total-big{text-align:right}.exp-total-label{font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;display:block}.exp-total-val{font-size:22px;font-weight:800;color:var(--primary-800);font-family:DM Mono,monospace}.workflow-section{margin-bottom:20px}.workflow-steps{display:flex;flex-direction:column;gap:4px}.wf-step{display:flex;align-items:center;gap:10px}.wf-circle{width:26px;height:26px;border-radius:50%;background:var(--gray-200);color:var(--gray-500);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.wf-step.done .wf-circle{background:var(--accent-green);color:#fff}.wf-step.pending .wf-circle{background:var(--orange);color:#fff}.wf-text{font-size:12.5px}.wf-title{font-weight:600;color:var(--gray-800)}.wf-sub{font-size:11px;color:var(--gray-500)}.wf-line{width:2px;height:12px;background:var(--gray-200);margin-left:12px}.expense-motive{background:var(--gray-50);padding:12px;border-radius:var(--radius-sm);margin-bottom:16px}.motive-text{font-size:12.5px;color:var(--gray-700);line-height:1.5;margin-top:4px}.expense-lines{margin-bottom:16px}.expense-line{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--gray-100);border-radius:var(--radius-sm);margin-bottom:6px}.line-icon{width:32px;height:32px;background:var(--primary-50);color:var(--primary-700);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.line-content{flex:1;min-width:0}.line-desc{font-size:13px;font-weight:600;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-meta{font-size:11px;color:var(--gray-500)}.line-payment{padding:4px}.line-amount{font-size:14px;font-weight:700;color:var(--gray-900);font-family:DM Mono,monospace}.expense-summary{background:var(--primary-50);padding:12px 14px;border-radius:var(--radius-sm);margin-bottom:16px}.exp-sum-row{display:flex;justify-content:space-between;font-size:13px;color:var(--gray-700);padding:3px 0}.exp-sum-row.total{font-weight:700;font-size:15px;color:var(--primary-800);padding-top:8px;border-top:1px solid var(--primary-200);margin-top:4px}.modal-backdrop{position:fixed;inset:0;background:#0b244780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:#fff;border-radius:var(--radius);width:100%;max-width:720px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:18px 24px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:16px;font-weight:700}.modal-body{padding:20px 24px}.modal-footer{padding:14px 24px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:8px}.form-row{display:flex;gap:12px}.form-row.two-col>*{flex:1}.form-field{margin-bottom:12px}.form-field label{display:block;font-size:11.5px;font-weight:600;color:var(--gray-700);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;border:1px solid var(--gray-300);border-radius:var(--radius-sm);padding:8px 12px;font-family:inherit;font-size:13.5px;outline:none;background:#fff;transition:border-color .15s}.form-input:focus{border-color:var(--primary-500)}.form-input.small{padding:8px 10px}.new-line-row{display:flex;gap:6px;padding:10px;background:var(--gray-50);border-radius:var(--radius-sm);margin-top:6px;flex-wrap:wrap;align-items:center}.info-box{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--primary-50);border:1px dashed var(--primary-300);border-radius:var(--radius-sm);font-size:12.5px;color:var(--primary-800);margin-top:12px}.info-box-secondary{font-size:11.5px;color:var(--gray-500);margin-top:6px;font-style:italic}.score-cell{display:flex;flex-direction:column}.score-num{font-size:15px;font-weight:700;line-height:1}.score-label{font-size:11px;font-weight:500;margin-top:1px}.score-detail{text-align:center;margin-top:8px}.score-big{font-size:28px;font-weight:800}.score-big-label{font-size:13px;font-weight:600;color:var(--gray-500)}.dist-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:12.5px}.dist-label{width:160px;flex-shrink:0;color:var(--gray-600)}.dist-bar-bg{flex:1;height:10px;background:var(--gray-100);border-radius:5px;overflow:hidden}.dist-bar{height:100%;border-radius:5px;transition:width .5s}.dist-count{width:24px;text-align:right;font-weight:700;color:var(--gray-700)}.payroll-breakdown{display:flex;flex-direction:column;gap:12px}.breakdown-row{display:flex;align-items:center;gap:10px;font-size:13.5px}.breakdown-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.breakdown-label{flex:1;color:var(--gray-600)}.breakdown-value{font-weight:600;color:var(--gray-900)}.report-nav{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px;background:var(--white);padding:8px;border-radius:var(--radius);box-shadow:var(--shadow)}.report-nav-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--gray-600)}.report-nav-btn:hover{background:var(--gray-100)}.report-nav-btn.active{background:var(--primary-700);color:#fff}.trend-note{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-top:16px}.trend-note.success{background:var(--accent-green-bg);color:var(--accent-green);border:1px solid #BBE5C8}.mb-4{margin-bottom:16px}.filters-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:16px;flex-wrap:wrap;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px 14px;box-shadow:var(--shadow)}.filter-group-inline{display:flex;flex-direction:column;gap:4px}.filter-label{font-size:10.5px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.4px}.dept-vacation-table .vmt-emp-head{width:180px;text-align:left;padding:6px 10px;background:var(--gray-50);font-size:11px;font-weight:700;color:var(--gray-600);font-family:DM Sans,sans-serif;text-transform:uppercase;letter-spacing:.3px}.dept-vacation-table .vmt-emp-cell{background:var(--gray-50);padding:6px 10px;font-size:12px;border:1px solid var(--gray-100);min-width:180px;width:180px}.dept-vacation-table .vmt-day-head{width:22px;min-width:22px;padding:3px 0}.dept-vacation-table .vmt-day-cell{width:22px;min-width:22px;height:28px}.workmode-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:600;margin-left:8px}.wm-local{background:#fff3;color:#fff}.wm-remote{background:#3b82f64d;color:#fff}.wm-client{background:#f59e0b4d;color:#fff}.workmode-modal{max-width:520px}.workmode-intro{font-size:13px;color:var(--gray-600);margin-bottom:16px}.workmode-options{display:flex;flex-direction:column;gap:10px}.workmode-option{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--white);border:2px solid var(--gray-200);border-radius:var(--radius);text-align:left;width:100%;transition:all .15s;cursor:pointer}.workmode-option:hover{border-color:var(--primary-700);background:var(--primary-50);transform:translate(4px)}.wm-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wm-icon-local{background:var(--primary-100);color:var(--primary-800)}.wm-icon-remote{background:#dbeafe;color:#1d4ed8}.wm-icon-client{background:#fef3c7;color:#b45309}.wm-text{flex:1}.wm-title{font-size:15px;font-weight:700;color:var(--gray-900)}.wm-sub{font-size:12px;color:var(--gray-500);margin-top:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.lang-dropdown-wrap{position:relative}.lang-dropdown-btn{display:flex;align-items:center;gap:6px;background:var(--gray-100);padding:6px 10px;border-radius:8px;font-size:12px;font-weight:600;color:var(--gray-700);transition:background .15s}.lang-dropdown-btn:hover{background:var(--gray-200)}.lang-flag{font-size:14px}.lang-code{letter-spacing:.4px}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:6px;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 8px 24px #0000001a;min-width:160px;padding:4px;z-index:100}.lang-opt{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;font-size:13px;color:var(--gray-700);border-radius:6px;text-align:left;font-weight:500}.lang-opt:hover{background:var(--gray-50)}.lang-opt.active{background:var(--primary-50);color:var(--primary-800);font-weight:700}.nav-item.mobile-launch{margin-top:12px;background:#ffffff0f;border-top:1px solid rgba(255,255,255,.1);padding-top:12px}.nav-item.mobile-launch:hover{background:#ffffff1f}
