:root,[data-theme=dark]{--sidebar-width: 260px;--header-height: 72px;--bg-deep: #070b14;--bg: #0b1220;--content-bg: #0f172a;--header-bg: #111827;--bg-elevated: #1e293b;--surface: #1e293b;--surface-solid: #1e293b;--surface-hover: rgba(148, 163, 184, .08);--border: rgba(148, 163, 184, .14);--glass-border: rgba(148, 163, 184, .14);--glass-border-strong: rgba(148, 163, 184, .22);--sidebar-bg: #0b1220;--sidebar-border: rgba(148, 163, 184, .1);--sidebar-text: #f8fafc;--sidebar-text-secondary: #94a3b8;--sidebar-muted: #64748b;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active: rgba(37, 99, 235, .22);--text: #f1f5f9;--text-secondary: #cbd5e1;--muted: #94a3b8;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #60a5fa;--primary-glow: rgba(37, 99, 235, .28);--accent: #059669;--accent-glow: rgba(5, 150, 105, .25);--violet: #7c3aed;--danger: #f87171;--danger-bg: rgba(248, 113, 113, .12);--success-bg: rgba(16, 185, 129, .12);--success-text: #34d399;--error-bg: rgba(248, 113, 113, .12);--error-text: #fca5a5;--warning: #fbbf24;--radius-sm: .5rem;--radius: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--shadow: 0 20px 40px rgba(0, 0, 0, .35);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .18);--transition: .2s cubic-bezier(.4, 0, .2, 1);--input-bg: #0f172a}[data-theme=light]{--bg-deep: #e2e8f0;--bg: #f1f5f9;--content-bg: #f1f5f9;--header-bg: #ffffff;--bg-elevated: #ffffff;--surface: #ffffff;--surface-solid: #ffffff;--surface-hover: #f8fafc;--border: #e2e8f0;--glass-border: #e2e8f0;--glass-border-strong: #cbd5e1;--sidebar-bg: #0f172a;--sidebar-border: rgba(255, 255, 255, .08);--sidebar-text: #f8fafc;--sidebar-text-secondary: #cbd5e1;--sidebar-muted: #94a3b8;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active: rgba(96, 165, 250, .2);--text: #0f172a;--text-secondary: #334155;--muted: #64748b;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #3b82f6;--primary-glow: rgba(37, 99, 235, .18);--accent: #059669;--accent-glow: rgba(5, 150, 105, .15);--violet: #7c3aed;--danger: #dc2626;--danger-bg: #fef2f2;--success-bg: #ecfdf5;--success-text: #059669;--error-bg: #fef2f2;--error-text: #dc2626;--warning: #d97706;--shadow: 0 16px 32px rgba(15, 23, 42, .08);--shadow-soft: 0 2px 8px rgba(15, 23, 42, .06);--input-bg: #ffffff}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;min-height:100dvh;font-family:Inter,Plus Jakarta Sans,system-ui,sans-serif;background:var(--content-bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.brand-logo-img{display:block;width:min(220px,100%);height:auto;max-height:52px;object-fit:contain;mix-blend-mode:screen}[data-theme=light] .login-card .brand-logo-img{mix-blend-mode:multiply}.erp-sidebar .brand-logo-img{mix-blend-mode:screen}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}input,select,textarea,button{font:inherit;color:inherit}input,select,textarea{width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition)}textarea{resize:vertical;min-height:120px;font-family:ui-monospace,Consolas,monospace;font-size:.9rem;line-height:1.5}input::placeholder,textarea::placeholder{color:var(--muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px var(--primary-glow)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 6.646a.5.5 0 0 1 .708 0L8 9.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.25rem}select option{background:var(--surface-solid);color:var(--text)}label{display:grid;gap:.4rem;font-size:.82rem;font-weight:600;color:var(--text-secondary)}h1,h2,h3{letter-spacing:-.02em}.page{animation:fadeUp .35s ease-out}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-ring{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.06);opacity:.2}}.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:1rem 1.25rem;background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.topbar-brand{display:flex;align-items:center;gap:1rem}.brand-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:grid;place-items:center;box-shadow:0 6px 18px var(--primary-glow);flex-shrink:0}.brand-icon svg{width:22px;height:22px;color:#fff}.topbar h1{margin:0;font-size:1.15rem;font-weight:700}.topbar p{margin:.15rem 0 0;color:var(--muted);font-size:.875rem}.topbar-actions{display:flex;align-items:center;gap:.75rem}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--violet));display:grid;place-items:center;font-size:.78rem;font-weight:700;color:#fff;border:2px solid var(--border)}.card{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.35rem;box-shadow:var(--shadow-soft)}.card-header{margin-bottom:1.15rem}.card-header h2{margin:0 0 .3rem;font-size:1.05rem;font-weight:700}.card-header p{margin:0;color:var(--muted);font-size:.875rem;line-height:1.5}.section-header-icon{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:1.15rem}.section-header-icon>div{min-width:0}.section-header-icon h2{margin:0 0 .3rem;font-size:1.05rem;font-weight:700}.section-header-icon p{margin:0;color:var(--muted);font-size:.875rem;line-height:1.5}.section-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:12px;background:#3b82f61f;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.section-icon svg{width:1.25rem;height:1.25rem}.section-icon.balance{background:#22c55e1f;color:#16a34a;border-color:#22c55e33}.section-icon.request{background:#6366f11f;color:#6366f1;border-color:#6366f133}.section-icon.history{background:#f59e0b1f;color:#d97706;border-color:#f59e0b33}.section-icon.profile{background:#6366f11f;color:#6366f1;border-color:#6366f133}.section-icon.security{background:#ef44441a;color:#dc2626;border-color:#ef444433}.btn-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:ui-spin .65s linear infinite;flex-shrink:0;opacity:.9}.btn.is-loading,.btn:disabled.is-loading{display:inline-flex;align-items:center;justify-content:center;gap:.45rem}@keyframes ui-spin{to{transform:rotate(360deg)}}.skeleton-bar{display:block;height:.85rem;max-width:100%;border-radius:6px;background:linear-gradient(90deg,color-mix(in srgb,var(--border) 70%,transparent) 25%,color-mix(in srgb,var(--border) 35%,transparent),color-mix(in srgb,var(--border) 70%,transparent) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.15s ease-in-out infinite}.skeleton-row td{padding:.85rem 1rem}.skeleton-stat{min-height:4.5rem;border-radius:var(--radius-md, 12px);border:1px solid var(--border);background:linear-gradient(90deg,color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 25%,color-mix(in srgb,var(--border) 25%,transparent),color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.15s ease-in-out infinite}.skeleton-card{min-height:5.5rem;border-radius:var(--radius-md, 12px);border:1px solid var(--border);background:linear-gradient(90deg,color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 25%,color-mix(in srgb,var(--border) 25%,transparent),color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.15s ease-in-out infinite}.skeleton-calendar{min-height:14rem;border-radius:var(--radius-md, 12px);border:1px solid var(--border);background:linear-gradient(90deg,color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 25%,color-mix(in srgb,var(--border) 25%,transparent),color-mix(in srgb,var(--surface-2, #f8fafc) 80%,transparent) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.15s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.15rem}.stack{display:grid;gap:.95rem}.tabs{display:flex;gap:.35rem;margin-bottom:1.15rem;padding:.3rem;background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap}.tabs button{display:inline-flex;align-items:center;gap:.5rem;border:none;background:transparent;padding:.6rem 1rem;border-radius:calc(var(--radius) - .2rem);cursor:pointer;font-weight:600;font-size:.85rem;color:var(--muted);transition:all var(--transition)}.tabs button:hover{color:var(--text-secondary);background:var(--surface-hover)}.tabs button.active{background:var(--primary);color:#fff}.tabs button svg{width:16px;height:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:none;border-radius:var(--radius-sm);padding:.65rem 1.1rem;cursor:pointer;font-weight:600;font-size:.875rem;transition:all var(--transition);white-space:nowrap}.btn svg{width:16px;height:16px}.btn.primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px var(--primary-glow)}.btn.primary:hover:not(:disabled){background:var(--primary-dark)}.btn.accent{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn.accent:hover:not(:disabled){filter:brightness(1.05)}.btn.outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn.outline:hover:not(:disabled){background:var(--surface-hover);border-color:var(--primary-light);color:var(--text)}.btn.secondary{background:var(--surface-hover);border:1px solid var(--border);color:var(--text-secondary)}.btn.secondary:hover:not(:disabled){color:var(--text)}.btn.small{padding:.38rem .7rem;font-size:.78rem}.btn.danger{background:var(--danger-bg);color:var(--danger);border:1px solid transparent}.btn.danger:hover:not(:disabled){filter:brightness(.95)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.full{width:100%}.alert{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem;font-weight:500}.alert.success{background:var(--success-bg);color:var(--success-text);border:1px solid color-mix(in srgb,var(--success-text) 25%,transparent)}.alert.error{background:var(--error-bg);color:var(--error-text);border:1px solid color-mix(in srgb,var(--error-text) 25%,transparent)}.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-solid)}table{width:100%;border-collapse:collapse}thead{background:var(--surface-hover)}th,td{text-align:left;padding:.8rem 1rem;font-size:.85rem}th{color:var(--muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}td{border-bottom:1px solid var(--border);color:var(--text-secondary)}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--surface-hover)}tbody tr:last-child td{border-bottom:none}.empty-row td{text-align:center;padding:2rem 1rem;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700}.badge:before{content:"";width:6px;height:6px;border-radius:50%}.badge.active{background:var(--success-bg);color:var(--success-text)}.badge.active:before{background:var(--accent)}.badge.inactive{background:var(--danger-bg);color:var(--danger)}.badge.inactive:before{background:var(--danger)}.badge.duration{background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary-light)}.badge.duration:before{display:none}.muted{color:var(--muted)}.section-panel{display:grid;gap:1.15rem}.print-only{display:none}.report-print-header{margin-bottom:1.35rem;padding-bottom:1rem;border-bottom:2px solid #1e293b;position:relative}.report-print-accent{height:4px;margin:-1px -1px 1rem;border-radius:4px 4px 0 0;background:linear-gradient(90deg,#2563eb,#7c3aed)}.report-print-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1.25rem}.report-print-brand{display:flex;align-items:center;gap:1rem;min-width:0}.report-print-logo{width:156px;height:auto;max-height:52px;object-fit:contain;mix-blend-mode:normal!important}.report-print-company{margin:0;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#64748b}.report-print-title{margin:.15rem 0 0;font-size:1.55rem;font-weight:800;color:#0f172a;line-height:1.15}.report-print-subtitle{margin:.25rem 0 0;font-size:.95rem;color:#475569}.report-print-badge-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.report-print-badge{display:inline-flex;padding:.28rem .65rem;border-radius:999px;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.report-print-link{font-size:.72rem;font-weight:600;color:#64748b;text-decoration:none}.report-print-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem 1rem;margin:1rem 0 0;padding:.85rem .95rem;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0}.report-print-meta-item{min-width:0}.report-print-meta dt{margin:0;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.report-print-meta dd{margin:.15rem 0 0;font-size:.88rem;font-weight:700;color:#0f172a;word-break:break-word}.report-print-footer{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-top:1.75rem;padding-top:.75rem;border-top:1px solid #cbd5e1;font-size:.72rem;color:#64748b}.report-print-footer-brand{display:flex;flex-direction:column;gap:.15rem}.report-print-footer-brand strong{color:#0f172a;font-size:.78rem}.report-print-footer-note{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;text-align:right}.report-print-confidential{font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#94a3b8}.print-section-title,.report-section-hidden{display:none}body.printing-full-report .report-section-hidden{display:block!important}.reports-hub{display:flex;flex-direction:column;gap:1.25rem;padding:0;border:none;background:transparent;box-shadow:none}.reports-hub.card{padding:0;border:none;background:transparent;box-shadow:none}.rpt-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.rpt-head-copy h2{margin:0 0 .35rem;font-size:clamp(1.25rem,2.5vw,1.55rem);font-weight:800;letter-spacing:-.03em}.rpt-head-copy p{margin:0;font-size:.9rem;color:var(--muted);line-height:1.5}.rpt-period-chip{padding:.45rem .9rem;border-radius:999px;font-size:.78rem;font-weight:700;color:var(--primary-light);background:color-mix(in srgb,var(--primary) 12%,var(--surface-solid));border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));white-space:nowrap}.rpt-toolbar{padding:1.25rem 1.35rem;border-radius:18px;border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 8%,transparent),transparent 50%),color-mix(in srgb,var(--surface-solid) 94%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 32px #0000000f}.rpt-toolbar-row{margin-bottom:1rem}.rpt-mode-tabs{display:inline-flex;padding:.25rem;border-radius:12px;background:color-mix(in srgb,var(--border) 35%,transparent);border:1px solid var(--border);gap:.25rem}.rpt-mode-tabs button{border:none;background:transparent;color:var(--muted);padding:.5rem 1.1rem;border-radius:9px;cursor:pointer;font-weight:700;font-size:.82rem;transition:all .2s ease}.rpt-mode-tabs button.active{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.rpt-filter-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.85rem;align-items:end}.rpt-field{display:flex;flex-direction:column;gap:.4rem;min-width:0}.rpt-field span{font-size:.68rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.rpt-field input,.rpt-field select{width:100%;padding:.65rem .85rem;border-radius:10px;border:1px solid var(--border);background:var(--input-bg, var(--surface-solid));color:var(--text);font-size:.9rem;transition:border-color .2s,box-shadow .2s}.rpt-field input:focus,.rpt-field select:focus{outline:none;border-color:color-mix(in srgb,var(--primary) 45%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 14%,transparent)}.rpt-presets{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.rpt-presets-label{font-size:.72rem;font-weight:700;color:var(--muted);margin-right:.25rem}.rpt-preset{border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 80%,transparent);color:var(--text-secondary);padding:.35rem .75rem;border-radius:999px;font-size:.76rem;font-weight:600;cursor:pointer;transition:all .15s ease}.rpt-preset:hover{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));color:var(--primary-light);background:color-mix(in srgb,var(--primary) 8%,var(--surface-solid))}.rpt-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem;margin-top:1rem}.rpt-download-main{display:inline-flex;align-items:center;gap:.45rem;box-shadow:0 6px 18px var(--primary-glow)}.rpt-download-main svg{width:16px;height:16px}.rpt-action-chip{padding:.45rem .85rem!important;border-radius:10px!important;font-size:.8rem!important}.rpt-filter-note{margin:.75rem 0 0;font-size:.78rem;color:var(--muted)}.rpt-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.85rem}.rpt-stat{position:relative;display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.05rem;border-radius:16px;overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 94%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .2s,box-shadow .2s}.rpt-stat:hover{transform:translateY(-2px);box-shadow:0 12px 28px #00000014}.rpt-stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.rpt-stat.stat-hours:before{background:linear-gradient(90deg,#6366f1,#818cf8)}.rpt-stat.stat-present:before{background:linear-gradient(90deg,#059669,#34d399)}.rpt-stat.stat-absent:before{background:linear-gradient(90deg,#ef4444,#f87171)}.rpt-stat.stat-leave:before{background:linear-gradient(90deg,#d97706,#fbbf24)}.rpt-stat.stat-work:before{background:linear-gradient(90deg,#2563eb,#60a5fa)}.rpt-stat.stat-weekend:before{background:linear-gradient(90deg,#64748b,#94a3b8)}.rpt-stat.stat-holiday:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.rpt-stat.stat-excess:before{background:linear-gradient(90deg,#dc2626,#f87171)}.rpt-stat-icon{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}.rpt-stat-icon svg{width:18px;height:18px}.stat-hours .rpt-stat-icon{background:#6366f126;color:#818cf8}.stat-present .rpt-stat-icon{background:#10b98126;color:#34d399}.stat-absent .rpt-stat-icon{background:#ef44441f;color:#f87171}.stat-leave .rpt-stat-icon{background:#f59e0b26;color:#fbbf24}.stat-work .rpt-stat-icon{background:#2563eb1f;color:var(--primary-light)}.stat-weekend .rpt-stat-icon{background:#64748b26;color:#94a3b8}.stat-holiday .rpt-stat-icon{background:#7c3aed26;color:#a78bfa}.stat-excess .rpt-stat-icon{background:#dc26261f;color:#f87171}.rpt-stat-label{margin:0;font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.rpt-stat-value{margin:.2rem 0 0;font-size:1.35rem;font-weight:800;letter-spacing:-.02em;line-height:1.1}.rpt-stat-value.green{color:var(--success-text)}.rpt-stat-value.red{color:var(--danger)}.rpt-view-tabs{display:flex;flex-wrap:wrap;gap:.45rem;padding:.35rem;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 88%,transparent)}.rpt-view-tabs button{border:none;background:transparent;color:var(--muted);padding:.55rem 1rem;border-radius:10px;cursor:pointer;font-weight:700;font-size:.82rem;transition:all .2s ease}.rpt-view-tabs button.active{color:#fff;background:linear-gradient(135deg,var(--primary),var(--violet));box-shadow:0 4px 14px var(--primary-glow)}.rpt-table-shell{border-radius:18px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 96%,transparent);overflow:hidden;box-shadow:0 8px 24px #0000000d}.reports-hub .table-wrap{border:none;border-radius:0;background:transparent}.reports-hub .table-wrap table thead{background:color-mix(in srgb,var(--primary) 6%,var(--surface-hover))}.reports-hub .table-wrap tbody tr:hover{background:color-mix(in srgb,var(--primary) 5%,transparent)}.reports-hub .month-block{padding:0 1rem 1rem}.reports-hub .month-block+.month-block{border-top:1px solid var(--border);padding-top:1rem}.reports-hub .calendar-card{border-radius:18px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 96%,transparent);box-shadow:0 12px 32px #0000000f;overflow:hidden}.reports-hub .subsection-title{margin:1rem 1rem .75rem;font-size:.95rem;font-weight:700;color:var(--text-secondary)}.rpt-snapshot{padding:1.35rem 1.5rem;border-radius:18px;border:1px solid color-mix(in srgb,var(--primary) 20%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 12%,transparent),transparent 55%),linear-gradient(225deg,color-mix(in srgb,var(--accent) 8%,transparent),transparent 45%),color-mix(in srgb,var(--surface-solid) 92%,transparent);box-shadow:0 16px 40px #00000014}.rpt-snapshot-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.rpt-snapshot-kicker{display:block;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary-light)}.rpt-snapshot-hours{margin:.35rem 0 0;font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.03em;line-height:1.1}.rpt-snapshot-hours strong{background:linear-gradient(135deg,var(--primary-light),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.rpt-snapshot-of{font-size:1rem;font-weight:600;color:var(--muted)}.rpt-snapshot-side{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}.rpt-snapshot-pct{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--text),var(--primary-light));-webkit-background-clip:text;background-clip:text;color:transparent}.rpt-snapshot-progress{height:8px;margin-top:1rem;border-radius:999px;background:color-mix(in srgb,var(--border) 70%,transparent);overflow:hidden}.rpt-snapshot-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary),var(--accent));box-shadow:0 0 12px var(--primary-glow);transition:width .6s cubic-bezier(.4,0,.2,1)}.rpt-snapshot-progress-fill.behind{background:linear-gradient(90deg,#ef4444,#f87171)}.rpt-snapshot-progress-fill.met{background:linear-gradient(90deg,#059669,#34d399)}.rpt-snapshot-foot{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid color-mix(in srgb,var(--border) 65%,transparent)}.rpt-snapshot-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600;color:var(--text-secondary);background:color-mix(in srgb,var(--border) 40%,transparent)}.rpt-snapshot-chip.pay{margin-left:auto;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--success-text)}.rpt-snapshot-chip.warn{background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger)}.rpt-period-summary{display:grid;grid-template-columns:1.2fr 1fr;gap:1.25rem;padding:1.25rem 1.35rem;margin-bottom:0;border-radius:18px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-solid) 94%,transparent)}.rpt-period-main .label{margin:0 0 .5rem;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.rpt-duration-display{display:flex;flex-wrap:wrap;gap:1rem 1.5rem}.rpt-duration-part{text-align:center}.rpt-duration-num{display:block;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;color:var(--primary-light);line-height:1}.rpt-duration-unit{display:block;margin-top:.2rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.rpt-period-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.rpt-period-stat{padding:.75rem .85rem;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--primary) 4%,transparent)}.rpt-period-stat .label{margin:0 0 .25rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.rpt-period-stat strong{font-size:.95rem;color:var(--text)}.rpt-daily-overview{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}.rpt-daily-hero{display:grid;grid-template-columns:1fr auto;gap:1.25rem 2rem;align-items:center;padding:1.35rem 1.5rem;border-radius:18px;border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));background:radial-gradient(ellipse 70% 80% at 0% 0%,rgba(99,102,241,.12),transparent 55%),color-mix(in srgb,var(--surface-solid) 96%,transparent);box-shadow:0 10px 32px #6366f114}.rpt-daily-kicker{display:block;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.rpt-daily-hours{margin:.35rem 0 0;font-size:clamp(2rem,4vw,2.75rem);font-weight:800;letter-spacing:-.03em;line-height:1;background:linear-gradient(135deg,var(--text),var(--primary-light));-webkit-background-clip:text;background-clip:text;color:transparent}.rpt-daily-sub{margin:.45rem 0 0;font-size:.85rem;color:var(--muted)}.rpt-daily-note{margin:.65rem 0 0;padding:.45rem .7rem;border-radius:10px;font-size:.8rem;color:var(--text-secondary);background:color-mix(in srgb,var(--border) 35%,transparent);border:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.rpt-daily-note strong{color:var(--text);font-weight:700}.rpt-daily-hero-side{min-width:min(100%,14rem);text-align:right}.rpt-daily-target{margin:.5rem 0 0;font-size:1.1rem;font-weight:700}.rpt-daily-target-of{color:var(--muted);font-weight:600}.rpt-daily-hero-side .rpt-snapshot-progress{margin-top:.75rem}.rpt-daily-pct{margin:.45rem 0 0;font-size:.78rem;font-weight:700;color:var(--muted)}.rpt-daily-stats{margin-top:0}.rpt-daily-table-shell{margin-top:.75rem}.rpt-daily-table-wrap{max-height:min(70vh,640px);overflow:auto}.rpt-scroll-table{overscroll-behavior:contain}.rpt-scroll-foot{margin:0;padding:.65rem 1rem .85rem;font-size:.78rem;font-weight:600;color:var(--muted);text-align:center;border-top:1px solid color-mix(in srgb,var(--border) 70%,transparent);background:color-mix(in srgb,var(--surface-solid) 92%,transparent)}.rpt-daily-table thead th{position:sticky;top:0;z-index:1;background:var(--surface-solid);box-shadow:0 1px 0 var(--border)}.rpt-daily-table tbody tr.present-row{background:color-mix(in srgb,var(--success) 4%,transparent)}.rpt-daily-table tbody tr.absent-row{background:color-mix(in srgb,var(--danger) 4%,transparent)}.rpt-daily-table tbody tr.leave-row{background:color-mix(in srgb,#f59e0b 6%,transparent)}.rpt-daily-table tbody tr.weekend-row,.rpt-daily-table tbody tr.holiday-row{background:color-mix(in srgb,var(--border) 25%,transparent);opacity:.92}.rpt-daily-date strong{font-weight:700;white-space:nowrap}.rpt-daily-hours-cell strong{font-variant-numeric:tabular-nums}.rpt-day-type{display:inline-block;font-size:.78rem;font-weight:700;color:var(--text-secondary)}.rpt-day-type.type-weekend,.rpt-day-type.type-public_holiday{color:var(--muted)}.rpt-holiday-tag{display:block;margin-top:.2rem;font-size:.72rem;font-weight:600;color:#a78bfa}.rpt-variance{font-size:.82rem;font-weight:700;font-variant-numeric:tabular-nums}.rpt-variance.positive{color:var(--success-text)}.rpt-variance.negative{color:var(--danger)}.rpt-status-badge{min-width:4.5rem;text-align:center}@media(max-width:768px){.rpt-filter-grid,.rpt-period-summary,.rpt-daily-hero{grid-template-columns:1fr}.rpt-daily-hero-side{text-align:left}.rpt-snapshot-chip.pay{margin-left:0}}@media(prefers-reduced-motion:reduce){.rpt-stat:hover{transform:none}}@page{margin:14mm 12mm 18mm;@bottom-center{content:"Technovez Attendance \b7  Page " counter(page) " of " counter(pages);font-size:8.5px;color:#94a3b8}}@media print{body,body.printing-report{background:#fff!important;color:#0f172a!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.no-print,.erp-sidebar,.erp-sidebar-backdrop,.erp-header,.topbar,.admin-stats,.tabs,.alert,.btn,.inner-tabs,.rpt-toolbar,.rpt-view-tabs,.rpt-head,.screen-only{display:none!important}.erp-layout,.erp-main,.page,.dashboard-content{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}.print-only{display:block!important}.printable-report,.card{border:none!important;box-shadow:none!important;background:#fff!important;color:#0f172a!important;break-inside:avoid-page}.table-wrap{overflow:visible!important}table{width:100%;border-collapse:collapse;font-size:10.5px;page-break-inside:auto}thead{display:table-header-group}tr{page-break-inside:avoid}th,td{border:1px solid #cbd5e1;padding:.35rem .45rem;text-align:left;vertical-align:top}th{background:#f1f5f9!important;color:#0f172a!important;font-weight:700}.badge,.ip-code{border:1px solid #94a3b8;color:#0f172a!important;background:#f8fafc!important}.badge:before{display:none!important}.mini-avatar,.progress-bar,.progress-fill{background:#e2e8f0!important;color:#0f172a!important}.report-totals-grid,.rpt-stats-grid,.total-tile,.rpt-stat,.report-hero,.report-hero-salary,.rpt-snapshot{break-inside:avoid-page}.total-tile,.rpt-stat,.report-hero,.rpt-snapshot{border:1px solid #cbd5e1!important;background:#f8fafc!important}.subsection-title{font-size:1rem;margin:1rem 0 .5rem;color:#0f172a}.print-section-title{display:block!important;margin:1.15rem 0 .55rem;padding-bottom:.35rem;border-bottom:2px solid #1e293b;font-size:.95rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#0f172a;break-after:avoid-page}.calendar-card,.calendar-shell,.period-table-summary{display:none!important}body.printing-full-report .report-hero,body.printing-full-report .report-snapshot,body.printing-full-report .rpt-snapshot,body.printing-full-report .report-totals-grid,body.printing-full-report .rpt-stats-grid{display:block!important}body.printing-full-report .report-print-section+.report-print-section{break-before:page;page-break-before:always}.report-print-top{align-items:center}.report-print-meta{grid-template-columns:repeat(3,minmax(0,1fr));background:#f8fafc!important;border:1px solid #cbd5e1!important}.report-print-badge{background:#eff6ff!important;border-color:#93c5fd!important;color:#1d4ed8!important}tbody tr:nth-child(2n) td{background:#f8fafc!important}tbody tr.empty-row td{background:#fff!important;font-style:italic;color:#64748b}.report-totals-grid,.rpt-stats-grid{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;margin-bottom:1rem}.total-tile,.rpt-stat{padding:.55rem .65rem!important;border-radius:6px!important}.total-tile .label,.total-tile .stat-label,.rpt-stat-label{font-size:.62rem!important}.total-tile .total-value,.total-tile .stat-value,.rpt-stat-value{font-size:1rem!important;font-weight:800!important}.report-hero{display:grid!important;grid-template-columns:1.4fr 1fr;gap:.85rem;margin-bottom:1rem;padding:.85rem!important;border-radius:8px!important}.report-hero-salary{display:grid!important;grid-template-columns:1fr;gap:.45rem}}@media print and (max-width:720px){.report-print-meta{grid-template-columns:repeat(2,minmax(0,1fr))}}
