*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--bg:#f1f5f9;--card:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--sw:220px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,-apple-system,sans-serif;font-size:14px}.sidebar{width:var(--sw);z-index:100;background:#1e293b;flex-direction:column;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sb-brand{border-bottom:1px solid #334155;padding:20px 20px 14px}.sb-brand h1{color:#f8fafc;font-size:14px;font-weight:700}.sb-brand p{color:#94a3b8;margin-top:3px;font-size:11px}.sb-user{border-bottom:1px solid #334155;padding:14px 20px}.sb-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:7px;font-size:14px;font-weight:700;display:flex}.sb-name{color:#f1f5f9;font-size:13px;font-weight:600}.sb-role{color:#94a3b8;margin-top:2px;font-size:11px}.sb-nav{flex:1;padding:10px 0;overflow-y:auto}.sb-footer{border-top:1px solid #334155;padding:14px 20px}.logout-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #475569;border-radius:8px;width:100%;padding:8px;font-family:inherit;font-size:13px;transition:all .15s}.logout-btn:hover{color:#f1f5f9;background:#334155}.nav-item{color:#94a3b8;cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:10px;padding:9px 20px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:#f1f5f9;background:#334155}.nav-item.active{color:#f1f5f9;border-left-color:var(--primary);background:#1d4ed820}.nav-icon{text-align:center;width:18px;font-size:15px}.page-content{padding:26px}.page-header{margin-bottom:22px}.page-header h2{font-size:21px;font-weight:700}.page-header p{color:var(--muted);margin-top:3px;font-size:13px}.live-clock{color:var(--primary);letter-spacing:2px;margin-bottom:3px;font-size:26px;font-weight:700}.live-date{color:var(--muted);margin-bottom:18px;font-size:13px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:18px;padding:22px}.card-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:13px;font-weight:600}.action-row{flex-wrap:wrap;gap:14px;margin-bottom:18px;display:flex}.action-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;flex:1;min-width:200px;padding:24px 28px}.action-card h3{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:500}.rec-times{color:var(--muted);flex-wrap:wrap;justify-content:center;gap:12px;margin-top:6px;font-size:12px;display:flex}.status-badge{border-radius:999px;margin-bottom:18px;padding:5px 14px;font-size:13px;font-weight:600;display:inline-block}.badge-present{color:#166534;background:#dcfce7}.badge-out{color:#475569;background:#f1f5f9}.badge-notmarked{color:#991b1b;background:#fee2e2}.stats-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;padding:18px}.stat-card .sv{margin-bottom:3px;font-size:28px;font-weight:700}.stat-card .sl{color:var(--muted);font-size:12px;font-weight:500}.stat-card.blue .sv{color:var(--primary)}.stat-card.green .sv{color:var(--success)}.stat-card.red .sv{color:var(--danger)}.stat-card.amber .sv{color:var(--warning)}.bal-row{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:18px;display:grid}.bal-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:10px;padding:14px}.bal-num{color:var(--primary);font-size:24px;font-weight:700}.bal-used{color:var(--muted);margin-top:2px;font-size:11px}.bal-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-top:5px;font-size:11px;font-weight:600}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:not(:disabled):hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:not(:disabled):hover{background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:not(:disabled):hover{background:#b91c1c}.btn-outline{background:var(--bg);border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--border)}.btn-sm{padding:5px 12px;font-size:12px}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.tbl-wrap{border:1px solid var(--border);border-radius:10px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th{text-align:left;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#f8fafc;padding:10px 13px;font-weight:600}td{border-bottom:1px solid var(--border);padding:10px 13px}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc}.pill{border-radius:999px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.pill-approved{color:#166534;background:#dcfce7}.pill-pending{color:#854d0e;background:#fef9c3}.pill-rejected{color:#991b1b;background:#fee2e2}.pill-present{color:#1e40af;background:#dbeafe}.pill-admin{color:#5b21b6;background:#ede9fe}.pill-manager{color:#92400e;background:#fef3c7}.pill-employee{color:#1e40af;background:#dbeafe}.fg{margin-bottom:14px}.fl{color:var(--text);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.fc{border:1.5px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.fc:focus{border-color:var(--primary)}textarea.fc{resize:vertical;min-height:72px}.fr{grid-template-columns:1fr 1fr;gap:14px;display:grid}.fr3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.alert{border-radius:8px;margin-bottom:14px;padding:11px 14px;font-size:13px;font-weight:500;display:none}.alert.show,.alert-success,.alert-error,.alert-info{align-items:center;gap:8px;display:flex}.alert-success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.alert-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.alert-info{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.loader{border:2px solid #e2e8f0;border-top-color:var(--primary);vertical-align:middle;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.pg-loading{height:180px;color:var(--muted);justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.empty{text-align:center;color:var(--muted);padding:36px 18px;font-size:13px}.empty-icon{margin-bottom:8px;font-size:34px}.divider{border:none;border-top:1px solid var(--border);margin:18px 0}.bal-hint{color:var(--success);min-height:18px;margin-top:4px;font-size:12px;font-weight:500}.days-preview{background:var(--primary);color:#fff;border-radius:20px;padding:2px 12px;font-size:13px;font-weight:600;display:inline-block}.half-opts{gap:14px;margin-top:6px;display:flex}.radio-lbl{cursor:pointer;align-items:center;gap:5px;font-size:13px;font-weight:500;display:flex}.cal-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cal-month{font-size:15px;font-weight:700}.cal-nav-btn{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:7px;padding:5px 13px;font-family:inherit;font-size:14px;font-weight:600}.cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.cal-head{text-align:center;color:var(--muted);padding:6px 2px;font-size:10px;font-weight:700}.cal-cell{border:1px solid var(--border);cursor:pointer;border-radius:7px;min-height:54px;padding:5px;transition:border-color .15s}.cal-cell:hover{border-color:var(--primary)}.cal-empty{min-height:54px}.cal-day-num{font-size:11px;font-weight:600}.cal-day-icon{text-align:center;margin-top:2px;font-size:14px}.cal-hol-name{color:var(--primary);white-space:nowrap;text-overflow:ellipsis;font-size:9px;overflow:hidden}.cal-present{background:#dcfce7;border-color:#86efac}.cal-absent{background:#fee2e2;border-color:#fca5a5}.cal-leave{background:#fef9c3;border-color:#fde047}.cal-halfday{background:#fed7aa;border-color:#fb923c}.cal-holiday{background:#dbeafe;border-color:#93c5fd}.cal-sunday{background:#f8fafc;border-color:#e2e8f0}.cal-sunday .cal-day-num{color:#94a3b8}.cal-future{background:#fff;border-color:#e2e8f0}.cal-future .cal-day-num{color:#cbd5e1}.cal-today{box-shadow:0 0 0 2px var(--primary)!important}.cal-selected{box-shadow:0 0 0 2px var(--warning)!important}.cal-legend{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.cal-li{color:var(--muted);align-items:center;gap:4px;font-size:11px;font-weight:500;display:flex}.cal-dot{border:1px solid #0000001a;border-radius:3px;flex-shrink:0;width:10px;height:10px}.cal-detail{background:var(--bg);border:1px solid var(--border);border-radius:10px;margin-top:14px;padding:14px}.cal-detail-title{margin-bottom:8px;font-size:13px;font-weight:700}.cal-detail-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.cal-detail-row:last-child{border-bottom:none}.cal-detail-key{color:var(--muted);font-weight:500}.view-toggle{gap:6px;margin-bottom:14px;display:flex}.view-btn{border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:6px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.view-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.ap-card{background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;padding:16px 18px}.ap-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.ap-name{font-size:14px;font-weight:700}.ap-meta{color:var(--muted);margin-bottom:3px;font-size:12px}.ap-reason{border-left:3px solid var(--border);background:#f8fafc;border-radius:6px;margin-top:7px;padding:7px 11px;font-size:13px}.side-panel{background:var(--card);border-left:1px solid var(--border);z-index:200;width:420px;height:100vh;padding:24px;transition:right .25s;position:fixed;top:0;right:-440px;overflow-y:auto}.side-panel.open{right:0}.sp-overlay{z-index:199;background:#00000059;display:none;position:fixed;inset:0}.sp-overlay.show{display:block}.sp-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.sp-title{font-size:16px;font-weight:700}.sp-close{cursor:pointer;color:var(--muted);background:0 0;border:none;font-size:22px;line-height:1}.sal-summary{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-bottom:18px;display:grid}.sal-stat{background:var(--bg);text-align:center;border-radius:10px;padding:12px}.sal-stat .sn{color:var(--primary);font-size:20px;font-weight:700}.sal-stat .sk{color:var(--muted);margin-top:2px;font-size:11px}@media (width<=640px){:root{--sw:0px}.sidebar{width:220px;transition:transform .25s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.page-content{padding:14px}.fr,.fr3{grid-template-columns:1fr}.live-clock{font-size:20px}.cal-cell{min-height:36px;padding:3px}.side-panel{width:100%;right:-100%}}
