:root{color-scheme:light dark;--bg: #FBF7F4;--bg-elevated: #FFFFFF;--surface: #FFFFFF;--surface-alt: #EFE9E5;--ink: #241F1C;--ink-muted: #7C726C;--ink-faint: #A8998F;--border: #EBE3DE;--border-strong: #D8C3BD;--accent: #D7322A;--accent-soft: #FBE9E7;--accent-hover: #A8221C;--on-accent: #FFFFFF;--success: #2E7D5B;--success-soft: #E8F3EC;--warning: #C97B22;--danger: #D7322A;--danger-soft: #FBE9E7;--shadow-card: 0 4px 18px rgba(11,15,23,.06);--shadow-floating: 0 8px 28px rgba(11,15,23,.12);--shadow-inset: inset 0 1px 2px rgba(11,15,23,.06);--font: "Manrope", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-display: "Sora", "Manrope", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-pill: 999px;--motion-fast: .14s;--motion-base: .22s;--motion-slow: .36s}[data-theme=dark]{--bg: #1A1614;--bg-elevated: #241F1C;--surface: #241F1C;--surface-alt: #2E2724;--ink: #FBF7F4;--ink-muted: #D8C3BD;--ink-faint: #7C726C;--border: #3A3128;--border-strong: #4A3F35;--accent: #E8463D;--accent-soft: #2E1816;--accent-hover: #D7322A;--on-accent: #FFFFFF;--success: #4ECCA3;--success-soft: #0F2A1E;--warning: #E89B3C;--danger: #E8463D;--danger-soft: #2E1816;--shadow-card: 0 4px 20px rgba(0,0,0,.4);--shadow-floating: 0 8px 32px rgba(0,0,0,.55);--shadow-inset: inset 0 1px 2px rgba(0,0,0,.3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--motion-base) ease,color var(--motion-base) ease}.t-display{font-family:var(--font-display);font-size:34px;line-height:40px;font-weight:700;letter-spacing:-.6px}.t-title{font-family:var(--font-display);font-size:26px;line-height:32px;font-weight:700;letter-spacing:-.4px}.t-heading{font-family:var(--font-display);font-size:20px;line-height:26px;font-weight:600;letter-spacing:-.2px}.t-body{font-size:16px;line-height:24px;font-weight:400}.t-label{font-size:14px;line-height:20px;font-weight:600;letter-spacing:.1px}.t-caption{font-size:13px;line-height:18px;font-weight:500;letter-spacing:.2px}.t-mono{font-family:var(--font-mono);font-size:14px;line-height:20px;font-weight:600;letter-spacing:1px}.ink-muted{color:var(--ink-muted)}.ink-faint{color:var(--ink-faint)}.ink-accent{color:var(--accent)}.ink-success{color:var(--success)}.ink-danger{color:var(--danger)}.app-shell{max-width:1160px;margin:0 auto;padding:0 24px 64px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:20px 0 16px;border-bottom:1px solid var(--border);margin-bottom:24px}.topbar-brand{display:flex;align-items:center;gap:12px}.topbar-brand-icon{width:40px;height:40px;background:url(/brand/logo.svg) center / 80% no-repeat;border-radius:var(--radius-sm);font-size:0;flex-shrink:0}.topbar-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-sm);padding:10px 18px;font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:.1px;cursor:pointer;transition:all var(--motion-fast) ease;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--on-accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-alt);color:var(--ink);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-strong);background:var(--bg-elevated)}.btn-ghost{background:transparent;color:var(--ink-muted);padding:8px 12px}.btn-ghost:hover{color:var(--ink);background:var(--surface-alt)}.btn-icon{width:38px;height:38px;padding:0;border-radius:var(--radius-sm);background:var(--surface-alt);border:1px solid var(--border);color:var(--ink-muted);cursor:pointer;display:grid;place-items:center;font-size:18px;transition:all var(--motion-fast) ease}.btn-icon:hover{border-color:var(--border-strong);color:var(--ink)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);transition:background var(--motion-base) ease,border-color var(--motion-base) ease,box-shadow var(--motion-base) ease}.card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-card);transition:all var(--motion-base) ease}.stat-card:hover{border-color:var(--border-strong)}.stat-label{font-size:13px;font-weight:500;color:var(--ink-muted);letter-spacing:.2px;margin-bottom:6px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.4px;line-height:1.1}.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px}.tab{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-pill);font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--ink-muted);transition:all var(--motion-fast) ease}.tab:hover{border-color:var(--border-strong);color:var(--ink)}.tab.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.tab-count{background:#0000001f;border-radius:var(--radius-pill);padding:1px 8px;font-size:12px;font-weight:700}.tab.active .tab-count{background:#fff3}.grid-2{display:grid;grid-template-columns:1fr 1.5fr;gap:20px}@media(max-width:860px){.grid-2{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 8px;vertical-align:top}th{color:var(--ink-faint);font-size:12px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;border-bottom:1px solid var(--border)}td{border-bottom:1px solid var(--border)}tbody tr{transition:background var(--motion-fast) ease}tbody tr:hover{background:var(--surface-alt)}tbody tr:last-child td{border-bottom:none}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:700;letter-spacing:.3px}.pill-in{background:var(--success-soft);color:var(--success)}.pill-out{background:var(--danger-soft);color:var(--danger)}.pill-accent{background:var(--accent-soft);color:var(--accent)}.pill-neutral{background:var(--surface-alt);color:var(--ink-muted)}.field-group{margin-bottom:16px}.field-label{display:block;font-size:13px;font-weight:600;color:var(--ink-muted);letter-spacing:.1px;margin-bottom:6px}.field-input{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--ink);font-family:var(--font);font-size:15px;outline:none;transition:border-color var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.login-card{width:380px;max-width:100%}.login-card .login-logo{width:48px;height:48px;background:var(--accent);border-radius:var(--radius-md);display:grid;place-items:center;color:var(--on-accent);font-weight:800;font-size:22px;margin-bottom:20px}.login-card h1{font-size:26px;font-weight:700;letter-spacing:-.4px;margin-bottom:4px}.login-card .login-sub{color:var(--ink-muted);font-size:15px;margin-bottom:28px}.login-card .btn-primary{width:100%;padding:12px;margin-top:8px;font-size:15px}.error-msg{color:var(--danger);font-size:13px;font-weight:500;margin-top:8px}.error-banner{background:var(--danger-soft);color:var(--danger);padding:12px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;margin-bottom:20px}.empty{color:var(--ink-faint);font-size:14px;padding:24px 0;text-align:center}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);display:inline-block;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.geo-ok{color:var(--success);font-weight:600}.geo-warn{color:var(--warning);font-weight:600}.face-score{font-family:var(--font-mono);font-size:13px;color:var(--ink-muted)}@media(max-width:600px){.topbar-brand-text{display:none}.stats-row{grid-template-columns:1fr 1fr}}.worker-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:600px){.worker-cards{grid-template-columns:1fr}}.punch-card{display:flex;flex-direction:column;gap:16px;cursor:pointer;transition:border-color var(--motion-fast) ease}.punch-card:hover{border-color:var(--border-strong)}.punch-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:grid;place-items:center;font-size:24px;font-weight:700}.punch-icon-in{background:#10b9811f;color:var(--success)}.punch-icon-out{background:#ef44441f;color:var(--danger)}.site-option{display:flex;align-items:center;justify-content:space-between;padding:16px;border-radius:var(--radius-md);border:1.5px solid var(--border);cursor:pointer;transition:all var(--motion-fast) ease}.site-option:hover{border-color:var(--border-strong)}.camera-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#05060a;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px}.camera-ring{position:relative;width:300px;height:300px;border-radius:50%;overflow:hidden}@media(max-width:400px){.camera-ring{width:260px;height:260px}}.camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-ring-border{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid var(--accent, #818CF8);pointer-events:none;animation:camera-pulse 2.8s ease-in-out infinite}@keyframes camera-pulse{0%,to{transform:scale(1);box-shadow:0 0 20px #818cf840}50%{transform:scale(1.03);box-shadow:0 0 40px #818cf880}}.topbar-nav{display:flex;gap:4px;margin-left:24px}.topbar-nav .btn-ghost.active{background:var(--accent);color:#fff}.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:16px}.profile-grid-edit{display:flex;flex-wrap:wrap;gap:12px;padding:16px}.profile-field{display:flex;flex-direction:column;gap:2px}.profile-field-label{font-size:12px;font-weight:500;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em}.profile-field-value{font-size:15px;font-weight:500;color:var(--ink)}.earnings-page{max-width:500px;margin:0 auto;padding-bottom:32px}.earnings-header{background:var(--accent);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.earnings-month-picker{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px}.earnings-hero{background:linear-gradient(135deg,var(--accent),#6366f1);color:#fff;border-radius:var(--radius-lg);padding:24px;margin:0 16px 16px;text-align:center}.earnings-hero-label{font-size:13px;opacity:.8;margin-bottom:4px}.earnings-hero-amount{font-size:36px;font-weight:700;letter-spacing:-.02em}.earnings-hero-sub{font-size:13px;opacity:.75;margin-top:4px}.earnings-projected{margin-top:12px;padding:8px 12px;background:#ffffff26;border-radius:var(--radius);font-size:13px}.earnings-breakdown{margin:0 16px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.earnings-break-item{display:flex;justify-content:space-between;padding:10px 16px;font-size:14px;border-bottom:1px solid var(--border)}.earnings-break-item:last-child{border-bottom:none}.earnings-break-label{color:var(--ink-faint)}.earnings-break-val{font-weight:600;color:var(--ink)}.earnings-break-gross{background:#4f46e50d}.earnings-break-gross .earnings-break-val{color:var(--accent)}.earnings-break-ded .earnings-break-val{color:var(--danger)}.earnings-break-net{background:#10b98114;font-weight:600}.earnings-break-net .earnings-break-label{color:var(--ink);font-weight:600}.earnings-break-net .earnings-break-val{color:var(--success);font-size:16px}.earnings-info{margin:0 16px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.earnings-info-row{display:flex;justify-content:space-between;padding:10px 16px;font-size:13px;border-bottom:1px solid var(--border)}.earnings-info-row:last-child{border-bottom:none}.earnings-info-row span:first-child{color:var(--ink-faint)}.earnings-info-row span:last-child{font-weight:500}.earnings-daily{margin:0 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.earnings-day-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.earnings-day-row:last-child{border-bottom:none}.earnings-day-date{font-weight:500;font-size:13px;min-width:90px}.earnings-day-times{flex:1;display:flex;gap:8px;font-size:12px}.earnings-day-in{color:var(--success)}.earnings-day-out{color:var(--danger)}.earnings-day-hrs{color:var(--ink-faint)}.earnings-day-amount{font-weight:600;font-size:14px;color:var(--success);white-space:nowrap}.success-msg{background:#10b9811a;color:var(--success);padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500}.home-page{min-height:100vh;background:var(--bg);overflow-x:hidden}.home-theme-btn{position:fixed;top:20px;right:20px;z-index:50;width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--ink-muted);font-size:18px;cursor:pointer;box-shadow:var(--shadow-card);transition:all var(--motion-fast) ease;display:grid;place-items:center}.home-theme-btn:hover{border-color:var(--accent);color:var(--accent)}.home-hero{background:linear-gradient(135deg,#a8221c,#d7322a,#e8463d);padding:80px 24px 60px;text-align:center;position:relative;overflow:hidden}.home-hero:before{content:"";position:absolute;top:-60%;left:-20%;width:140%;height:200%;background:radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}.home-hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}.home-logo-wrap{display:flex;justify-content:center;margin-bottom:24px}.home-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:24px;background:#fff url(/brand/logo.svg) center / 75% no-repeat;border:1px solid var(--border);box-shadow:0 8px 22px #d7322a24;font-size:0}.home-title{color:#fff;font-size:clamp(28px,5vw,42px);font-weight:800;letter-spacing:-.8px;line-height:1.15;margin-bottom:8px}.home-tagline{color:#ffffffd9;font-size:clamp(16px,2.5vw,20px);font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px}.home-subtitle{color:#ffffffb3;font-size:16px;line-height:1.65;max-width:520px;margin:0 auto}.home-stats{display:flex;justify-content:center;align-items:center;gap:0;padding:32px 24px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.home-stat{text-align:center;padding:8px 32px}.home-stat-num{font-size:32px;font-weight:800;letter-spacing:-.5px;color:var(--accent);line-height:1.1}.home-stat-label{font-size:13px;font-weight:500;color:var(--ink-muted);margin-top:4px;letter-spacing:.2px}.home-stat-divider{width:1px;height:40px;background:var(--border)}@media(max-width:600px){.home-stat{padding:8px 16px}.home-stat-num{font-size:24px}.home-stat-divider{display:none}.home-stats{gap:8px}}.home-actions{max-width:680px;margin:0 auto;padding:40px 24px 20px;display:flex;flex-direction:column;gap:16px}.home-action-card{display:flex;align-items:center;gap:20px;padding:24px 28px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--motion-fast) ease;box-shadow:var(--shadow-card)}.home-action-card:hover{border-color:var(--accent);box-shadow:0 8px 32px #4f46e51f;transform:translateY(-2px)}.home-action-icon{width:56px;height:56px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.home-action-icon-worker{background:#10b9811a;color:var(--success)}.home-action-icon-admin{background:#4f46e51a;color:var(--accent)}.home-action-text{flex:1}.home-action-text h3{font-size:18px;font-weight:700;margin-bottom:4px;letter-spacing:-.2px}.home-action-text p{font-size:14px;color:var(--ink-muted);line-height:1.4}.home-action-arrow{font-size:22px;color:var(--ink-faint);transition:all var(--motion-fast) ease}.home-action-card:hover .home-action-arrow{color:var(--accent);transform:translate(4px)}.home-services{max-width:900px;margin:0 auto;padding:48px 24px}.home-section-title{text-align:center;font-size:24px;font-weight:700;letter-spacing:-.3px;margin-bottom:32px;color:var(--ink)}.home-services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.home-service-card{text-align:center;padding:28px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--motion-fast) ease}.home-service-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-card)}.home-service-emoji{font-size:36px;margin-bottom:12px;line-height:1}.home-service-card h4{font-size:16px;font-weight:700;margin-bottom:8px;letter-spacing:-.1px}.home-service-card p{font-size:13px;color:var(--ink-muted);line-height:1.5}.home-clients{padding:20px 24px 48px;max-width:900px;margin:0 auto}.home-clients-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.home-client-chip{padding:10px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);font-size:14px;font-weight:600;color:var(--ink-muted);letter-spacing:.2px;transition:all var(--motion-fast) ease}.home-client-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.home-footer{background:var(--surface-alt);border-top:1px solid var(--border);padding:32px 24px}.home-footer-inner{max-width:900px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.home-footer-brand{display:flex;align-items:center;gap:14px}.home-footer-logo{width:44px;height:44px;border-radius:var(--radius-sm);background:#fff url(/brand/logo.svg) center / 80% no-repeat;border:1px solid var(--border);font-size:0;letter-spacing:0}.app-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;transition:grid-template-columns var(--motion-base) ease}.app-layout.app-layout-collapsed{grid-template-columns:68px 1fr}.main-content{padding:32px 40px 64px;max-width:1200px;width:100%;overflow-x:hidden}.sidebar{position:sticky;top:0;height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;transition:width var(--motion-base) ease;width:260px;z-index:100}.sidebar-collapsed{width:68px}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 16px 16px;border-bottom:1px solid var(--border);min-height:64px}.sidebar-brand-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:#fff url(/brand/logo.svg) center / 80% no-repeat;border:1px solid var(--border);font-size:0;letter-spacing:0;flex-shrink:0}.sidebar-brand-text{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.3px;white-space:nowrap}.sidebar-collapse-btn{margin-left:auto;width:28px;height:28px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--ink-faint);cursor:pointer;display:grid;place-items:center;transition:all var(--motion-fast) ease;flex-shrink:0}.sidebar-collapse-btn:hover{background:var(--surface-alt);color:var(--ink)}.sidebar-collapsed .sidebar-collapse-btn{margin-left:0;position:absolute;right:-14px;top:28px;width:28px;height:28px;background:var(--surface);border:1px solid var(--border);border-radius:50%;box-shadow:var(--shadow-card);z-index:10}.sidebar-collapsed .sidebar-brand{position:relative;justify-content:center;padding:20px 8px 16px}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-section{margin-bottom:4px}.sidebar-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-faint);padding:16px 12px 6px;white-space:nowrap;overflow:hidden}.sidebar-item{display:flex;align-items:center;gap:12px;width:100%;padding:9px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--ink-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--motion-fast) ease;white-space:nowrap;text-align:left}.sidebar-item:hover{background:var(--surface-alt);color:var(--ink)}.sidebar-item-active{background:var(--accent-soft);color:var(--accent);font-weight:600}.sidebar-item-active:hover{background:var(--accent-soft);color:var(--accent)}.sidebar-item-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.sidebar-item-label{overflow:hidden;text-overflow:ellipsis}.sidebar-item-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:var(--radius-pill);min-width:20px;text-align:center}.sidebar-item-danger:hover{color:var(--danger)}.sidebar-footer{border-top:1px solid var(--border);padding:8px 8px 12px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 12px 4px}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}.sidebar-user-name{font-size:13px;font-weight:500;color:var(--ink-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-mobile-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;width:44px;height:44px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-card)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:90}@media(max-width:860px){.app-layout{grid-template-columns:1fr}.sidebar{position:fixed;left:-280px;top:0;height:100vh;width:260px;z-index:100;box-shadow:var(--shadow-floating);transition:left var(--motion-base) ease}.sidebar.sidebar-mobile-open{left:0}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block}.main-content{padding:72px 16px 48px}.sidebar-collapse-btn{display:none}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;min-height:40px;flex-wrap:wrap}.page-header-left{display:flex;align-items:center;gap:12px}.page-header-back{font-size:13px;gap:4px}.page-header-title{font-size:22px;font-weight:700;letter-spacing:-.4px;color:var(--ink);margin:0}.page-header-subtitle{font-size:14px;color:var(--ink-muted);margin:2px 0 0}.page-header-actions{display:flex;gap:8px;flex-wrap:wrap}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state-icon{width:56px;height:56px;border-radius:50%;background:var(--surface-alt);display:grid;place-items:center;color:var(--ink-faint);margin-bottom:16px}.empty-state-title{font-size:16px;font-weight:600;color:var(--ink);margin:0 0 6px}.empty-state-desc{font-size:14px;color:var(--ink-muted);margin:0;max-width:320px}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:1000;animation:fadeIn var(--motion-fast) ease}.dialog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;max-width:400px;width:90%;box-shadow:var(--shadow-floating);animation:slideUp var(--motion-base) ease}.dialog-title{font-size:18px;font-weight:700;color:var(--ink);margin:0 0 8px}.dialog-message{font-size:14px;color:var(--ink-muted);margin:0 0 24px;line-height:1.5}.dialog-actions{display:flex;gap:8px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.search-bar{position:relative;display:flex;align-items:center}.search-bar-icon{position:absolute;left:14px;color:var(--ink-faint);pointer-events:none}.search-bar-input{width:100%;padding:10px 38px 10px 42px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--ink);font-size:14px;outline:none;transition:border-color var(--motion-fast) ease,box-shadow var(--motion-fast) ease}.search-bar-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-bar-input::placeholder{color:var(--ink-faint)}.search-bar-clear{position:absolute;right:10px;width:24px;height:24px;border:none;background:var(--surface-alt);border-radius:50%;color:var(--ink-faint);cursor:pointer;display:grid;place-items:center}.search-bar-clear:hover{color:var(--ink);background:var(--border)}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover{background:#dc2626}.skeleton{background:linear-gradient(90deg,var(--surface-alt) 25%,var(--border) 50%,var(--surface-alt) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-line{height:16px;margin-bottom:8px}.skeleton-card{height:80px;margin-bottom:12px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.worker-ess-page{min-height:100vh;background:var(--bg)}.ess-header{background:linear-gradient(135deg,var(--accent) 0%,#6366f1 100%);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:8px}.ess-header h2{color:#fff;font-size:18px}.ess-section{padding:16px}.ess-section-title{font-size:15px;font-weight:700;color:var(--ink);margin:0 0 12px}.ess-empty{text-align:center;padding:32px 16px;color:var(--ink-faint);font-size:14px}.worker-ess-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}.worker-ess-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--motion-fast) ease}.worker-ess-card:hover{border-color:var(--accent);box-shadow:var(--shadow-card);transform:translateY(-1px)}.worker-ess-card-icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:20px;font-weight:700}.worker-ess-card-label{font-size:13px;font-weight:600;color:var(--ink)}.ess-balance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.ess-balance-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;position:relative}.ess-balance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ess-balance-type{font-size:14px;font-weight:600;color:var(--ink)}.ess-balance-code{font-size:11px;font-weight:600;color:var(--ink-faint);background:var(--surface-alt);padding:2px 8px;border-radius:4px}.ess-balance-bar-wrap{height:6px;background:var(--surface-alt);border-radius:3px;margin-bottom:8px;overflow:hidden}.ess-balance-bar{height:100%;background:var(--accent);border-radius:3px;transition:width var(--motion-base) ease}.ess-balance-nums{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-muted)}.ess-balance-unpaid{position:absolute;top:8px;right:8px;font-size:10px;color:var(--warning);font-weight:600}.ess-requests-list{display:flex;flex-direction:column;gap:10px}.ess-request-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px}.ess-request-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.ess-request-type{font-size:14px;font-weight:600}.ess-request-status{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.ess-request-dates{font-size:13px;color:var(--ink-muted);display:flex;gap:8px;align-items:center}.ess-request-days{font-size:11px;background:var(--accent-soft);color:var(--accent);padding:1px 8px;border-radius:4px;font-weight:600}.ess-request-reason{font-size:13px;color:var(--ink-muted);margin-top:6px;font-style:italic}.ess-request-remarks{font-size:12px;color:var(--accent);margin-top:4px}.ess-payslip-list{display:flex;flex-direction:column;gap:12px;padding:0 16px 16px}.ess-payslip-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.ess-payslip-top{display:flex;justify-content:space-between;align-items:flex-start;padding:16px}.ess-payslip-month{font-size:16px;font-weight:700;color:var(--ink)}.ess-payslip-net{font-size:18px;font-weight:700;color:var(--accent)}.ess-payslip-breakdown{padding:0 16px 12px}.ess-payslip-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--ink-muted)}.ess-payslip-ded{color:var(--danger)}.ess-payslip-net-row{font-weight:700;color:var(--ink);border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.ess-payslip-actions{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--border);background:var(--surface-alt)}.ess-profile-hero{display:flex;flex-direction:column;align-items:center;padding:28px 16px 20px;gap:4px}.ess-profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:28px;font-weight:700;margin-bottom:8px}.ess-profile-name{font-size:20px;font-weight:700;color:var(--ink);margin:0}.ess-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.ess-info-row{display:flex;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px}.ess-info-row:last-child{border-bottom:none}.ess-info-label{color:var(--ink-muted);font-weight:500}.ess-info-value{color:var(--ink);font-weight:600;text-align:right;max-width:60%;word-break:break-word}.ess-att-stats{display:flex;justify-content:center;gap:32px;padding:12px 16px 20px}.ess-att-stat{text-align:center}.ess-att-stat-num{font-size:28px;font-weight:700;color:var(--accent)}.ess-att-stat-label{font-size:12px;color:var(--ink-muted);font-weight:500}.ess-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:0 12px 16px}.ess-cal-header{text-align:center;font-size:11px;font-weight:700;color:var(--ink-faint);padding:4px 0;text-transform:uppercase}.ess-cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:13px;position:relative;min-height:48px}.ess-cal-empty{background:transparent}.ess-cal-present{background:var(--success-soft);border:1px solid #86efac}.ess-cal-absent{background:var(--danger-soft)}.ess-cal-today{outline:2px solid var(--accent);outline-offset:-1px}.ess-cal-num{font-weight:600;font-size:13px;color:var(--ink)}.ess-cal-times{display:flex;flex-direction:column;align-items:center;gap:1px}.ess-cal-in,.ess-cal-out{font-size:8px;font-weight:600;color:var(--ink-muted)}.ess-legend{display:flex;justify-content:center;gap:20px;padding:8px 16px 24px}.ess-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-muted)}.ess-legend-dot{width:10px;height:10px;border-radius:50%}.ess-legend-present{background:var(--success)}.ess-legend-absent{background:var(--danger)}.ess-legend-today{background:var(--accent)}.doc-completeness{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.doc-completeness-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.doc-completeness-bar-wrap{height:8px;background:var(--surface-alt);border-radius:4px;overflow:hidden;margin-bottom:12px}.doc-completeness-bar{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--success) 100%);border-radius:4px;transition:width var(--motion-base) ease}.doc-completeness-items{display:flex;flex-wrap:wrap;gap:6px}.doc-completeness-chip{font-size:11px;font-weight:600;padding:3px 10px;border-radius:4px}.doc-chip-verified{background:var(--success-soft);color:var(--success)}.doc-chip-uploaded{background:var(--accent-soft);color:var(--accent)}.doc-chip-missing{background:var(--danger-soft);color:var(--danger)}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow var(--motion-fast) ease}.doc-card:hover{box-shadow:var(--shadow-card)}.doc-card-preview{height:120px;background:var(--surface-alt);display:grid;place-items:center;overflow:hidden}.doc-card-img{width:100%;height:100%;object-fit:cover}.doc-card-pdf{width:48px;height:48px;background:var(--danger-soft);color:var(--danger);border-radius:8px;display:grid;place-items:center;font-size:14px;font-weight:700}.doc-card-info{padding:12px}.doc-card-type{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:2px}.doc-card-actions{display:flex;gap:4px;padding:8px 12px;border-top:1px solid var(--border);background:var(--surface-alt);align-items:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:grid;place-items:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-card);border-radius:16px;padding:24px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.error-banner{background:var(--danger-soft);color:var(--danger);padding:10px 16px;border-radius:10px;margin-bottom:16px;font-size:14px;font-weight:500;display:flex;align-items:center}.btn-accent{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:6px 14px;font-weight:600;font-size:13px;cursor:pointer;transition:opacity .15s}.btn-accent:hover{opacity:.9}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:8px;padding:6px 14px;font-weight:600;font-size:13px;cursor:pointer;transition:opacity .15s}.btn-danger:hover{opacity:.9}.btn-sm{padding:4px 10px;font-size:12px;border-radius:6px}@media(max-width:600px){html,body{overflow-x:hidden}[style*=grid-template-columns]{grid-template-columns:1fr!important}[style*="display: flex"]{flex-wrap:wrap}.field-input,select.field-input,input.field-input,textarea.field-input{width:100%!important;min-width:0!important}.field-group{width:100%}.modal-overlay{padding:8px!important}.modal,.modal-content{width:100%!important;max-width:100%!important;max-height:92vh!important;padding:16px!important;border-radius:14px!important}img,video,canvas,iframe{max-width:100%}.page-header{flex-wrap:wrap;gap:12px}}
