.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:999;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fade-in .25s cubic-bezier(.4,0,.2,1)}.drawer{background:var(--bg);width:100%;max-width:800px;max-height:90vh;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px var(--border);display:flex;flex-direction:column;overflow:hidden;animation:modal-pop .3s cubic-bezier(.34,1.56,.64,1);position:relative}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.drawer-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface);flex-shrink:0}.drawer-title{margin:0;font-size:1.25rem;font-weight:700}.drawer-close-btn{background:var(--surface-3);border:none;color:var(--text-muted);width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.drawer-close-btn:hover{background:var(--surface-hover);color:var(--text)}.drawer-wrapper{display:flex;flex:1;overflow:hidden;height:100%}.drawer-sidebar{width:220px;background:var(--surface-2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;padding:1rem 0;overflow-y:auto}.drawer-tab{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;text-align:left;transition:all .2s ease;position:relative}.drawer-tab:hover{background:var(--surface-3);color:var(--text-primary)}.drawer-tab.active{background:var(--accent-light);color:var(--accent);font-weight:700}.drawer-tab.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:0 4px 4px 0}.drawer-tab-icon{font-size:1.1rem}.drawer-body{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;background:var(--surface)}.drawer-tab-content{flex:1;display:flex;flex-direction:column}:root{--bg: #080d1a;--surface: #0d1526;--surface-2: #131e33;--surface-3: #1a2640;--border: rgba(255, 255, 255, .07);--border-light: rgba(255, 255, 255, .04);--text-primary: #f0f4ff;--text-secondary: #8b9ab5;--text-muted: #556070;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: rgba(99, 102, 241, .15);--accent-glow: rgba(99, 102, 241, .25);--success: #22c55e;--success-bg: rgba(34, 197, 94, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 4px 12px rgba(0, 0, 0, .2);--shadow: 0 8px 32px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .4);--shadow-accent: 0 8px 24px rgba(99, 102, 241, .35);--nav-h: 64px}[data-theme=light]{--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .04);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #4f46e5;--accent-hover: #4338ca;--accent-light: rgba(79, 70, 229, .12);--accent-glow: rgba(79, 70, 229, .2);--success: #16a34a;--success-bg: rgba(22, 163, 74, .12);--danger: #dc2626;--danger-bg: rgba(220, 38, 38, .12);--warning: #d97706;--warning-bg: rgba(217, 119, 6, .12);--shadow-sm: 0 4px 12px rgba(0, 0, 0, .05);--shadow: 0 8px 32px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .12);--shadow-accent: 0 8px 24px rgba(79, 70, 229, .25)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{max-width:100%}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.layout{display:flex;flex-direction:column;min-height:100vh}:root{--sidebar-w: 220px;--topbar-h: 52px}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;transition:transform .25s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-logo{display:flex;align-items:center;gap:.6rem;padding:1.1rem 1rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo-icon{font-size:1.3rem}.sidebar-logo-text{font-size:.95rem;font-weight:800;color:var(--text-primary);letter-spacing:-.3px;flex:1}.sidebar-close-btn{display:none;background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.sidebar-group{margin-bottom:.25rem}.sidebar-group-label{font-size:.58rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted);padding:.6rem 1rem .3rem;display:block}.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.5rem 1rem;border-radius:0;color:var(--text-secondary);font-size:.84rem;font-weight:500;transition:background .12s,color .12s;text-decoration:none;margin:1px .5rem;border-radius:var(--radius-sm)}.sidebar-link:hover{background:var(--surface-2);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-light);color:var(--accent);font-weight:700}.sidebar-link-icon{font-size:1rem;width:18px;text-align:center;flex-shrink:0}.sidebar-link-label{flex:1}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border);flex-shrink:0}.sidebar-logout-btn{width:100%;display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:all .15s}.sidebar-logout-btn:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.sidebar-topbar{display:none;position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:150;align-items:center;padding:0 1rem;gap:.75rem}.sidebar-topbar-title{font-size:.95rem;font-weight:800;color:var(--text-primary)}.sidebar-hamburger{display:flex;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.sidebar-hamburger span{display:block;width:20px;height:2px;background:var(--text-secondary);border-radius:99px;transition:all .2s}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}.page-content{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay,.sidebar-close-btn{display:block}.sidebar-topbar{display:flex}.main-content{margin-left:0;padding-top:var(--topbar-h)}.page-content{padding:1.25rem 1rem}}.filter-tab{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:99px;color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.filter-tab:hover{border-color:var(--accent);color:var(--text-primary)}.filter-tab.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:700}.filter-tab-count{background:var(--surface-3);border-radius:99px;padding:0 6px;font-size:.68rem;font-weight:700;min-width:18px;text-align:center}.filter-tab.active .filter-tab-count{background:var(--accent-light)}.task-card{display:flex;flex-direction:column}.dept-card{transition:transform .12s,box-shadow .12s}.dept-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0003}.navbar{position:sticky;top:0;z-index:100;height:var(--nav-h);background:#080d1ad9;border-bottom:1px solid var(--border);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;padding:0 2rem}.navbar-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1100px;margin:0 auto}.navbar-brand{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.brand-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);flex-shrink:0}.navbar-nav{display:flex;align-items:center;gap:.25rem}.nav-link{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.nav-link:hover{background:var(--surface-2);color:var(--text-primary)}.nav-link.active{background:var(--accent-light);color:var(--accent)}.navbar-right{display:flex;align-items:center;gap:1rem}.navbar-user{font-size:.8rem;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;border:none;outline:none;transition:all .2s ease;cursor:pointer;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 6px 24px #6366f173;transform:translateY(-1px)}.btn-ghost{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-3);color:var(--text-primary);border-color:#ffffff1f}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:12px 28px;font-size:1rem}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s}.card:hover{border-color:#ffffff1c}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;transition:transform .2s,border-color .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#ffffff1f}.stat-icon{font-size:1.5rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;margin-bottom:.25rem}.stat-icon.indigo{background:var(--accent-light)}.stat-icon.green{background:var(--success-bg)}.stat-icon.red{background:var(--danger-bg)}.stat-icon.amber{background:var(--warning-bg)}.stat-value{font-size:2rem;font-weight:800;letter-spacing:-1px;line-height:1;color:var(--text-primary)}.stat-label{font-size:.8rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;gap:1rem;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.page-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:2px}.section-title{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:1.25rem}.form-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.form-input,.form-select{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 14px;font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238b9ab5' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}.form-select option{background:var(--surface-2)}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead tr{background:var(--surface-2)}thead th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:1px solid var(--border)}tbody tr{border-bottom:1px solid var(--border-light);transition:background .15s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface-2)}tbody td{padding:13px 16px;color:var(--text-secondary);vertical-align:middle}tbody td:first-child{color:var(--text-primary);font-weight:500}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-present{background:var(--success-bg);color:var(--success)}.badge-absent{background:var(--danger-bg);color:var(--danger)}.badge-halfday{background:var(--warning-bg);color:var(--warning)}.badge-default{background:var(--surface-3);color:var(--text-muted)}.att-toggle{display:inline-flex;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.att-toggle-btn{padding:5px 12px;font-size:.75rem;font-weight:600;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.att-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.att-toggle-btn.active-present{background:var(--success-bg);color:var(--success)}.att-toggle-btn.active-absent{background:var(--danger-bg);color:var(--danger)}.att-toggle-btn.active-halfday{background:var(--warning-bg);color:var(--warning)}.att-toggle-btn.active-late{background:#f973161f;color:#f97316}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fadeIn .2s ease}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:460px;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.modal-close{background:var(--surface-3);border:none;color:var(--text-muted);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:background .2s,color .2s}.modal-close:hover{background:var(--danger-bg);color:var(--danger)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.search-bar{position:relative}.search-bar .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.9rem;pointer-events:none}.search-bar .form-input{padding-left:36px}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.empty-state-text{font-size:.875rem}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;margin-bottom:1rem;display:flex;align-items:center;gap:8px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(34,197,94,.2)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%);top:-200px;right:-200px;pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.05) 0%,transparent 70%);bottom:-100px;left:-100px;pointer-events:none}.login-box{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:2rem}.login-logo-dot{width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 16px var(--accent)}.login-logo-text{font-size:1.2rem;font-weight:800;letter-spacing:-.5px}.login-heading{font-size:1.6rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.4rem}.login-subheading{font-size:.875rem;color:var(--text-muted);margin-bottom:2rem}.employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.employee-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:transform .2s,border-color .2s,box-shadow .2s}.employee-card:hover{transform:translateY(-2px);border-color:#ffffff1f;box-shadow:var(--shadow)}.employee-avatar{width:44px;height:44px;border-radius:12px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--accent);flex-shrink:0}.employee-card-header{display:flex;align-items:center;gap:12px}.employee-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.employee-role{font-size:.8rem;color:var(--text-muted)}.employee-phone{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:5px}.employee-actions{display:flex;gap:.5rem;margin-top:auto}.report-cell{text-align:center;font-size:.75rem;font-weight:600;padding:8px 4px!important;min-width:28px}.report-cell.p{color:var(--success)}.report-cell.a{color:var(--danger)}.report-cell.h{color:var(--warning)}.report-cell.dash{color:var(--text-muted)}.date-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.date-input-wrap{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer}.date-input-wrap input[type=date],.date-input-wrap input[type=month]{background:transparent;border:none;color:var(--text-primary);font-size:.875rem;outline:none;cursor:pointer}.date-input-wrap input[type=date]::-webkit-calendar-picker-indicator,.date-input-wrap input[type=month]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}.loading-wrap{display:flex;align-items:center;justify-content:center;padding:4rem}.divider{height:1px;background:var(--border);margin:1.5rem 0}.quick-action-bar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:2rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease}@media (max-width: 768px){.page-content{padding:1.25rem 1rem}.navbar{padding:0 1rem}.navbar-nav{display:none}.input-row{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr}.employee-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.modal{padding:1.5rem}}@media (max-width: 480px){.stat-grid{grid-template-columns:1fr}.stat-value{font-size:1.5rem}.date-controls{flex-direction:column;align-items:flex-start}}.emp-home{min-height:100vh;background:var(--bg);padding:0 0 4rem;max-width:480px;margin:0 auto}.emp-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem .75rem;background:#080d1ae6;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.emp-greeting{font-size:1.05rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.emp-role{font-size:.78rem;color:var(--text-muted);margin-top:2px}.emp-date-bar{display:flex;align-items:center;gap:8px;padding:.75rem 1.25rem;font-size:.82rem;color:var(--text-muted);border-bottom:1px solid var(--border-light)}.emp-checkin-card{margin:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2rem 1.5rem;text-align:center;min-height:220px;display:flex;align-items:center;justify-content:center}.emp-checkin-center{width:100%;display:flex;flex-direction:column;align-items:center}.emp-checkin-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 36px;border-radius:var(--radius-xl);font-size:1.05rem;font-weight:700;border:none;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 6px 28px #22c55e66;transition:transform .2s,box-shadow .2s;width:100%;max-width:300px;letter-spacing:-.3px}.emp-checkin-btn:hover{transform:translateY(-2px);box-shadow:0 10px 36px #22c55e80}.emp-checkin-btn:active{transform:scale(.98)}.emp-status-done{display:flex;flex-direction:column;align-items:center;gap:.5rem}.emp-status-icon{font-size:3rem;margin-bottom:.25rem}.emp-status-title{font-size:1.15rem;font-weight:700;color:var(--success)}.emp-checkin-error{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:1.25rem}.emp-gps-msg{font-size:.85rem;color:var(--text-secondary);text-align:center;line-height:1.5}.emp-distance-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:100px;font-size:.78rem;font-weight:700}.emp-section{margin:0 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.25rem}.emp-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.emp-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.emp-cal-dot{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:transform .15s;cursor:default}.emp-cal-num{font-size:.65rem;font-weight:600;color:inherit}.dot-present{background:var(--success-bg);color:var(--success)}.dot-absent{background:var(--danger-bg);color:var(--danger)}.dot-half{background:var(--warning-bg);color:var(--warning)}.dot-today{outline:2px solid var(--accent);outline-offset:1px}.settings-option-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;border-radius:var(--radius-lg);border:1.5px solid var(--border);cursor:pointer;transition:border-color .2s,background .2s,transform .15s;text-align:center;background:var(--surface)}.settings-option-card:hover{transform:translateY(-2px)}.settings-option-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.settings-option-label{font-size:.875rem;font-weight:700;color:var(--text-primary);line-height:1.3}.settings-option-sub{font-size:.72rem;color:var(--text-muted)}@media (max-width: 480px){.settings-option-card{padding:1rem .75rem}.settings-option-label{font-size:.8rem}}.emp-app{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--bg);position:relative;overflow:hidden}.emp-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.emp-greeting{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.emp-role{font-size:.72rem;color:var(--text-muted);margin-top:2px}.emp-content{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.emp-bottom-nav{display:flex;align-items:stretch;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;z-index:20;padding-bottom:env(safe-area-inset-bottom,0px)}.emp-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:.6rem .25rem;background:none;border:none;cursor:pointer;transition:background .15s,color .15s;position:relative}.emp-nav-btn:before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:transparent;border-radius:0 0 99px 99px;transition:background .2s}.emp-nav-btn.active:before{background:var(--accent)}.emp-nav-icon{font-size:1.25rem;line-height:1;transition:transform .15s}.emp-nav-btn.active .emp-nav-icon{transform:translateY(-1px)}.emp-nav-label{font-size:.62rem;font-weight:600;letter-spacing:.3px;color:var(--text-muted);transition:color .15s;text-transform:uppercase}.emp-nav-btn.active .emp-nav-label{color:var(--accent)}.emp-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;margin-bottom:.75rem}.emp-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.emp-checkin-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.25rem;display:flex;align-items:center;justify-content:center;min-height:180px}.emp-status-done{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.35rem}.emp-status-icon{font-size:2.5rem}.emp-status-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.emp-status-sub{font-size:.82rem;color:var(--text-muted)}.emp-checkin-center{display:flex;flex-direction:column;align-items:center;width:100%}.emp-checkin-btn{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--success) 0%,#16a34a 100%);color:#fff;border:none;border-radius:var(--radius);padding:.9rem 2rem;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #22c55e59;transition:transform .15s,box-shadow .15s;letter-spacing:.2px}.emp-checkin-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #22c55e73}.emp-checkin-btn:active{transform:translateY(0)}.emp-checkin-error{display:flex;flex-direction:column;align-items:center;text-align:center}.emp-gps-msg{font-size:.82rem;color:var(--text-muted)}.emp-distance-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:99px;font-size:.78rem;font-weight:600}.emp-distance-badge.success{background:var(--success-bg);color:var(--success)}.emp-distance-badge.danger{background:var(--danger-bg);color:var(--danger)}.emp-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.emp-cal-dot{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:600;cursor:default;transition:transform .1s}.emp-cal-num{font-size:.6rem;font-weight:600}.dot-present{background:#22c55e40;color:var(--success)}.dot-absent{background:#ef444433;color:var(--danger)}.dot-half{background:#eab30833;color:var(--warning)}.dot-empty{background:var(--surface-3);color:var(--text-muted)}.dot-today{outline:1.5px solid var(--accent);outline-offset:1px}.section-title{font-size:.8rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}
