@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-primary:#f5f7fb;--bg-gradient:radial-gradient(ellipse 1200px 600px at 15% -10%, #6366f124, transparent 60%), radial-gradient(ellipse 900px 500px at 100% 10%, #8b5cf61a, transparent 60%), radial-gradient(ellipse 800px 400px at 50% 110%, #10b9810f, transparent 60%), linear-gradient(180deg, #f5f7fb 0%, #fff 100%);--panel-bg:#ffffffb8;--panel-bg-solid:#fff;--panel-border:#0f172a14;--panel-border-hover:#6366f147;--panel-glow:#6366f126;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--color-primary:#6366f1;--color-primary-glow:#6366f126;--color-present:#10b981;--color-present-glow:#10b98121;--color-absent-cl:#0ea5e9;--color-absent-cl-glow:#0ea5e921;--color-absent-sl:#ef4444;--color-absent-sl-glow:#ef44441f;--color-wfh:#f59e0b;--color-wfh-glow:#f59e0b24;--color-field:#8b5cf6;--color-field-glow:#8b5cf624;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 3px #0f172a0f;--shadow-md:0 4px 6px #0f172a0a, 0 10px 25px #0f172a0f;--shadow-lg:0 10px 25px #0f172a14, 0 20px 50px #0f172a1a;--shadow-glow:0 8px 30px #6366f138;--font-main:"Plus Jakarta Sans", "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--sidebar-width:260px;--header-height:80px;--border-radius-lg:18px;--border-radius-md:12px;--border-radius-sm:8px;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;font-family:var(--font-main);scrollbar-width:thin;scrollbar-color:#0f172a26 transparent;margin:0;padding:0}body{background:var(--bg-primary);background-image:var(--bg-gradient);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;min-height:100vh;overflow-x:hidden}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);transition:var(--transition-smooth)}.glass-panel:hover{border-color:var(--panel-border-hover);box-shadow:var(--shadow-lg)}.app-container{max-width:100%;min-height:100vh;display:flex;overflow-x:hidden}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--panel-border);-webkit-backdrop-filter:blur(24px)saturate(180%);z-index:100;background:linear-gradient(#ffffffeb 0%,#f8fafceb 100%);flex-direction:column;height:100vh;padding:28px 20px;display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 40px #0f172a0d}.logo-section{align-items:center;gap:12px;margin-bottom:36px;padding:0 6px;display:flex}.logo-icon{border-radius:var(--border-radius-md);background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;font-weight:800;display:flex;box-shadow:0 8px 20px #6366f166}.logo-text{letter-spacing:-.01em;background:linear-gradient(135deg, var(--color-primary), var(--color-field));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800}.nav-links{flex-direction:column;gap:4px;list-style:none;display:flex}.nav-item{appearance:none;width:100%;color:var(--text-secondary);text-align:left;white-space:nowrap;border-radius:var(--border-radius-md);letter-spacing:-.005em;cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;outline:none;align-items:center;gap:12px;padding:11px 14px;font-family:inherit;font-size:.92rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item-icon{stroke-width:2px;width:18px;height:18px;transition:var(--transition-smooth);flex-shrink:0}.nav-item:hover{color:var(--color-primary);background:#6366f112}.nav-item:hover .nav-item-icon{transform:scale(1.08)}.nav-item.active{color:var(--color-primary);background:linear-gradient(90deg,#6366f124 0%,#8b5cf60f 100%);font-weight:700;box-shadow:inset 0 0 0 1px #6366f12e,0 4px 12px #6366f11f}.nav-item.active:before{content:"";background:linear-gradient(180deg, var(--color-primary), var(--color-field));border-radius:0 4px 4px 0;width:4px;height:22px;position:absolute;top:50%;left:-20px;transform:translateY(-50%);box-shadow:0 0 12px #6366f180}.nav-item:focus-visible{box-shadow:0 0 0 3px #6366f140}.sidebar-footer{border-top:1px solid var(--panel-border);flex-direction:column;gap:12px;margin-top:auto;padding-top:16px;display:flex}.user-chip{border-radius:var(--border-radius-md);background:linear-gradient(135deg,#6366f10f,#8b5cf60a);border:1px solid #6366f11f;align-items:center;gap:12px;padding:10px 12px;display:flex}.user-chip-avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex;box-shadow:0 4px 12px #6366f14d}.user-chip-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.user-chip-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.user-chip-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.btn-signout{appearance:none;width:100%;color:var(--color-absent-sl);border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-smooth);background:#ef44440d;border:1px solid #ef44442e;justify-content:center;align-items:center;gap:8px;padding:10px 14px;font-family:inherit;font-size:.88rem;font-weight:600;display:flex}.btn-signout:hover{background:#ef44441a;border-color:#ef444459;transform:translateY(-1px);box-shadow:0 6px 16px #ef444426}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex-grow:1;flex-shrink:1;gap:32px;min-width:0;max-width:100%;min-height:100vh;padding:40px;display:flex}.main-content>*{min-width:0;max-width:100%}.top-header{justify-content:space-between;align-items:center;display:flex}.header-title h1{background:linear-gradient(135deg,#0f172a 0%,#6366f1 100%);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:2rem;font-weight:800}.header-title p{color:var(--text-secondary);font-size:.95rem}.date-selector{align-items:center;gap:12px;padding:8px 16px;display:flex}.date-input{border:1px solid var(--panel-border);color:var(--text-primary);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);box-shadow:var(--shadow-sm);background:#fff;outline:none;padding:10px 14px;font-size:.95rem;font-weight:500}.date-input:focus,.date-input:hover{border-color:var(--color-primary);box-shadow:0 0 0 4px #6366f11a}.tiles-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;display:grid}.tile{cursor:pointer;background:#fff;flex-direction:column;gap:16px;padding:24px;display:flex;position:relative;overflow:hidden}.tile:before{content:"";width:100%;height:4px;position:absolute;top:0;left:0}.tile-present:before{background:linear-gradient(90deg, var(--color-present), #34d399)}.tile-absent:before{background:linear-gradient(90deg, var(--color-absent-sl), #f87171)}.tile-wfh:before{background:linear-gradient(90deg, var(--color-wfh), #fbbf24)}.tile-field:before{background:linear-gradient(90deg, var(--color-field), #a78bfa)}.tile:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.tile-present:hover{border-color:#10b98166}.tile-absent:hover{border-color:#ef444466}.tile-wfh:hover{border-color:#f59e0b66}.tile-field:hover{border-color:#8b5cf666}.tile-header{justify-content:space-between;align-items:center;display:flex}.tile-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:700}.tile-icon{border-radius:var(--border-radius-sm);justify-content:center;align-items:center;width:44px;height:44px;display:flex}.tile-present .tile-icon{background:var(--color-present-glow);color:var(--color-present)}.tile-absent .tile-icon{background:var(--color-absent-sl-glow);color:var(--color-absent-sl)}.tile-wfh .tile-icon{background:var(--color-wfh-glow);color:var(--color-wfh)}.tile-field .tile-icon{background:var(--color-field-glow);color:var(--color-field)}.tile-value{color:var(--text-primary);letter-spacing:-.03em;font-size:2.4rem;font-weight:800;line-height:1.1}.tile-subsections{border-top:1px solid var(--panel-border);gap:16px;margin-top:4px;padding-top:14px;display:flex}.tile-sub-item{flex-direction:column;gap:2px;display:flex}.tile-sub-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.tile-sub-val{font-size:1rem;font-weight:700}.tile-sub-val.cl{color:var(--color-absent-cl)}.tile-sub-val.sl{color:var(--color-absent-sl)}.dashboard-sections{grid-template-columns:2fr 1fr;gap:32px;display:grid}@media (width<=1024px){.dashboard-sections{grid-template-columns:1fr}}.attendance-panel{flex-direction:column;gap:24px;padding:28px;display:flex}.panel-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.panel-title{color:var(--text-primary);align-items:center;gap:10px;font-size:1.2rem;font-weight:700;display:flex}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-smooth);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #6366f14d}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff40,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.btn-primary:hover:before{left:100%}.btn-primary:disabled{color:var(--text-muted);box-shadow:none;cursor:not-allowed;background:#0f172a0f;transform:none}.btn-primary:disabled:before{display:none}.roster-list{flex-direction:column;gap:10px;max-height:480px;padding-right:4px;display:flex;overflow-y:auto}.roster-row{border-radius:var(--border-radius-md);border:1px solid var(--panel-border);transition:var(--transition-smooth);background:#fff;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.roster-row:hover{background:#6366f108;border-color:#6366f133;transform:translate(2px)}.employee-info{flex-direction:column;gap:4px;display:flex}.emp-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.emp-dept{color:var(--text-secondary);font-size:.8rem}.status-selector{gap:6px;display:flex}.status-btn{color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);background:#0f172a0a;border:1px solid #0f172a0f;padding:7px 14px;font-size:.78rem;font-weight:600}.status-btn:hover{color:var(--text-primary);background:#0f172a12;transform:translateY(-1px)}.status-btn.active-Present{background:var(--color-present-glow);border-color:var(--color-present);color:var(--color-present)}.status-btn.active-CL{background:var(--color-absent-cl-glow);border-color:var(--color-absent-cl);color:var(--color-absent-cl)}.status-btn.active-SL{background:var(--color-absent-sl-glow);border-color:var(--color-absent-sl);color:var(--color-absent-sl)}.status-btn.active-WFH{background:var(--color-wfh-glow);border-color:var(--color-wfh);color:var(--color-wfh)}.status-btn.active-Field{background:var(--color-field-glow);border-color:var(--color-field);color:var(--color-field)}.charts-panel{flex-direction:column;gap:24px;padding:28px;display:flex}.dir-container{flex-direction:column;gap:24px;min-width:0;display:flex}.dir-header{justify-content:space-between;align-items:center;display:flex}.btn-secondary{border:1px solid var(--panel-border);color:var(--text-primary);border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-smooth);box-shadow:var(--shadow-sm);background:#fff;align-items:center;gap:8px;padding:10px 18px;font-size:.88rem;font-weight:600;display:flex}.btn-secondary:hover{color:var(--color-primary);box-shadow:var(--shadow-md);border-color:#6366f166;transform:translateY(-1px)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.employees-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.emp-card{background:#fff;flex-direction:column;gap:16px;padding:24px;display:flex;position:relative}.emp-card-header{justify-content:space-between;align-items:flex-start;display:flex}.emp-card-avatar{width:48px;height:48px;color:var(--color-primary);background:linear-gradient(135deg,#6366f12e,#8b5cf62e);border:1px solid #6366f138;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex}.emp-card-details{flex-direction:column;gap:4px;margin-top:8px;display:flex}.emp-card-role{color:var(--text-secondary);font-size:.85rem}.emp-card-dept{color:var(--text-muted);align-items:center;gap:6px;font-size:.8rem;display:flex}.btn-delete{color:var(--text-muted);cursor:pointer;border-radius:var(--border-radius-sm);transition:var(--transition-smooth);background:0 0;border:none;padding:6px}.btn-delete:hover{color:var(--color-absent-sl);background:#ef44441a}.modal-overlay{-webkit-backdrop-filter:blur(10px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;padding:24px;animation:.2s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);background:#fff;flex-direction:column;gap:24px;width:100%;max-width:480px;max-height:calc(100vh - 48px);padding:32px;animation:.3s cubic-bezier(.4,0,.2,1) slide-up;display:flex;overflow-y:auto;box-shadow:0 30px 80px #0f172a38}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{color:var(--text-primary);border-bottom:1px solid var(--panel-border);letter-spacing:-.01em;padding-bottom:14px;font-size:1.35rem;font-weight:800}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.01em;font-size:.82rem;font-weight:600}.form-input{border:1.5px solid var(--panel-border);color:var(--text-primary);border-radius:var(--border-radius-md);transition:var(--transition-smooth);background:#fff;outline:none;padding:12px 14px;font-size:.95rem;font-weight:500}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #6366f11f}.modal-actions{justify-content:flex-end;gap:12px;display:flex}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;cursor:pointer;font-family:inherit}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(40%)sepia(60%)saturate(2500%)hue-rotate(225deg)brightness(95%);padding:4px;transition:opacity .2s}input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(40%)sepia(60%)saturate(2500%)hue-rotate(225deg)brightness(95%);padding:4px;transition:opacity .2s}input[type=datetime-local]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(40%)sepia(60%)saturate(2500%)hue-rotate(225deg)brightness(95%);padding:4px;transition:opacity .2s}input[type=month]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(40%)sepia(60%)saturate(2500%)hue-rotate(225deg)brightness(95%);padding:4px;transition:opacity .2s}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}select.form-input{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23475569' viewBox='0 0 16 16'%3e%3cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506.001z'/%3e%3c/svg%3e");background-position:right 14px center;background-repeat:no-repeat;background-size:12px;padding-right:36px}.history-controls{justify-content:space-between;align-items:center;display:flex}.history-filters{align-items:center;gap:16px;display:flex}.history-grid-layout{grid-template-columns:1fr;gap:32px;display:grid}.history-table-container{background:#fff;padding:24px;overflow-x:auto}.history-table-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.history-table-title{color:var(--text-primary);font-size:1.15rem;font-weight:700}.history-table{border-collapse:collapse;text-align:left;width:100%}.history-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--panel-border);background:#0f172a05;padding:14px 16px;font-size:.76rem;font-weight:700}.history-table td{color:var(--text-primary);border-bottom:1px solid #0f172a0d;padding:16px;font-size:.93rem}.history-table tr:hover td{background:#6366f108}.badge{border-radius:999px;align-items:center;gap:4px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.badge-present{background:var(--color-present-glow);color:var(--color-present)}.badge-wfh{background:var(--color-wfh-glow);color:var(--color-wfh)}.badge-field{background:var(--color-field-glow);color:var(--color-field)}.badge-absent{background:var(--color-absent-sl-glow);color:var(--color-absent-sl)}.trend-card{padding:24px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;display:flex}.empty-state-icon{width:48px;height:48px;color:var(--text-muted)}.loading-spinner{border:3px solid #6366f126;border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:1s ease-in-out infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0f172a24 padding-box padding-box;border:2px solid #0000;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f173 padding-box padding-box}.input-icon-wrapper{align-items:center;width:100%;display:flex;position:relative}.input-icon-wrapper svg{color:var(--color-primary);pointer-events:none;opacity:.85;position:absolute;left:14px}.input-icon-wrapper .form-input{width:100%;padding-left:42px!important}::selection{color:var(--text-primary);background:#6366f138}.csv-info-btn{appearance:none;width:22px;height:22px;color:var(--color-primary);cursor:pointer;transition:var(--transition-smooth);background:#6366f11a;border:1px solid #6366f138;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.csv-info-btn:hover{background:#6366f12e;border-color:#6366f166;transform:scale(1.08)}.csv-format-modal{max-width:600px}.csv-format-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:14px;display:flex}.csv-format-table-wrap{border:1px solid var(--panel-border);border-radius:var(--border-radius-md);max-height:280px;overflow:auto}.csv-format-table{margin:0}.csv-format-table th{background:#6366f10f;padding:12px 14px}.csv-format-table td{padding:10px 14px;font-size:.88rem}.csv-format-colname{color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:700}.csv-format-colhint{color:var(--text-muted);text-transform:none;letter-spacing:0;margin-top:2px;font-size:.68rem;font-weight:500}.pagination{border-top:1px solid var(--panel-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:6px;padding:14px 8px 6px;display:flex}.pagination-info{color:var(--text-secondary);align-items:center;gap:12px;font-size:.85rem;display:inline-flex}.pagination-range strong{color:var(--text-primary);font-weight:700}.pagination-size{appearance:none;border:1px solid var(--panel-border);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);background:#fff url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23475569' viewBox='0 0 16 16'%3e%3cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506.001z'/%3e%3c/svg%3e") right 10px center no-repeat;border-radius:8px;padding:6px 30px 6px 12px;font-size:.82rem;font-weight:600}.pagination-size:hover{border-color:#6366f166}.pagination-controls{align-items:center;gap:4px;display:inline-flex}.pagination-btn{appearance:none;border:1px solid var(--panel-border);min-width:34px;height:34px;color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#fff;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-family:inherit;font-size:.85rem;font-weight:600;display:inline-flex}.pagination-btn:hover:not(:disabled){color:var(--color-primary);background:#6366f10a;border-color:#6366f166}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.is-active{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;border-color:#0000;box-shadow:0 4px 12px #6366f14d}.pagination-btn.is-active:hover{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff}.pagination-gap{min-width:24px;color:var(--text-muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-weight:700;display:inline-flex}@media (width<=640px){.pagination{flex-direction:column;align-items:stretch}.pagination-info{justify-content:space-between}.pagination-controls{flex-wrap:wrap;justify-content:center}}.form-grid-2col{grid-template-columns:1fr 1fr;gap:20px;display:grid}.split-layout{grid-template-columns:1.2fr 2fr;gap:24px;display:grid}@media (width<=900px){.split-layout{grid-template-columns:1fr}}.mobile-header{z-index:90;-webkit-backdrop-filter:blur(16px)saturate(180%);border-bottom:1px solid var(--panel-border);background:#ffffffeb;justify-content:space-between;align-items:center;margin:-40px -40px 16px;padding:12px 16px;display:none;position:sticky;top:0}.mobile-header-brand{align-items:center;gap:10px;display:flex}.mobile-header-brand .logo-icon{width:34px;height:34px;font-size:1rem}.mobile-header-brand .logo-text{font-size:1.1rem}.hamburger-btn{appearance:none;width:40px;height:40px;color:var(--color-primary);cursor:pointer;transition:var(--transition-smooth);background:#6366f114;border:1px solid #6366f12e;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.hamburger-btn:hover,.hamburger-btn:focus-visible{background:#6366f124;outline:none}.sidebar-scrim{-webkit-backdrop-filter:blur(6px);z-index:99;background:#0f172a66;animation:.2s ease-out fade-in;display:none;position:fixed;inset:0}.sidebar-close-btn{appearance:none;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;margin-left:auto;padding:6px;display:none}.sidebar-close-btn:hover{color:var(--text-primary);background:#0f172a0d}@media (width<=1024px){.main-content{gap:24px;padding:32px 28px}.top-header{flex-wrap:wrap;gap:16px}.header-title h1{font-size:1.6rem}.dir-header{flex-wrap:wrap;gap:12px}.live-clock-time{font-size:2.4rem}}@media (width<=768px){:root{--sidebar-width:78vw}body{background-attachment:scroll}.sidebar{will-change:transform;max-width:320px;padding:22px 18px;transition:transform .32s cubic-bezier(.4,0,.2,1);transform:translate(-105%);box-shadow:12px 0 40px #0f172a26}.sidebar.open{transform:translate(0)}.sidebar-scrim.open{display:block}.sidebar-close-btn{display:inline-flex}.logo-section{margin-bottom:24px}.nav-item.active:before{left:-18px}.main-content{gap:20px;margin-left:0;padding:20px 16px}.mobile-header{margin:-20px -16px 8px;display:flex}.top-header{align-items:flex-start}.header-title h1{letter-spacing:-.01em;font-size:1.4rem}.header-title p{font-size:.88rem}.date-selector{width:100%}.tiles-grid{grid-template-columns:repeat(2,1fr);gap:14px}.tile{gap:12px;padding:18px}.tile-value{font-size:1.6rem}.tile-title{font-size:.72rem}.tile-icon{width:36px;height:36px}.attendance-panel,.charts-panel{padding:20px}.panel-header{flex-wrap:wrap;gap:12px}.roster-row{flex-direction:column;align-items:flex-start;gap:12px;padding:14px}.roster-row .status-selector{scrollbar-width:none;width:100%;padding-bottom:2px;overflow-x:auto}.roster-row .status-selector::-webkit-scrollbar{display:none}.history-table-container{border-radius:var(--border-radius-md);padding:14px}.history-table th,.history-table td{white-space:nowrap;padding:12px 10px;font-size:.85rem}.modal-content{border-radius:var(--border-radius-lg);max-width:100%;max-height:calc(100vh - 32px);padding:24px 20px}.modal-overlay{padding:16px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn-primary,.modal-actions .btn-secondary{justify-content:center;width:100%}.confirm-dialog{border-radius:18px;padding:28px 20px 20px}.confirm-title{font-size:1.1rem}.confirm-message{font-size:.88rem}.confirm-actions{flex-direction:column-reverse}.form-grid-2col{grid-template-columns:1fr;gap:16px}.live-clock-panel{padding:28px 20px 22px}.live-clock-time{letter-spacing:-.01em;font-size:2rem}.live-clock-date{font-size:.82rem}.live-clock-icon-wrap{width:56px;height:56px}.history-controls{flex-direction:column;align-items:stretch;gap:12px}.history-controls>.btn-secondary,.history-controls>.btn-primary{align-self:flex-end;width:auto}.history-controls>.history-filters>.btn-secondary,.history-controls>.history-filters>.btn-primary{align-self:auto}.history-filters{flex-wrap:wrap;gap:10px;width:100%}.history-filters>.glass-panel,.history-filters>.date-selector{flex:100%;width:100%}.history-filters>.btn-primary{white-space:nowrap;flex:calc(100% - 58px);justify-content:center}.history-filters>.btn-secondary{flex:0 0 48px;justify-content:center;padding:10px}.dir-header>div:last-child{flex-wrap:wrap;gap:10px;width:100%}.dir-header>div:last-child>.date-selector,.dir-header>div:last-child>.glass-panel{flex:100%;width:100%}}@media (width<=480px){.main-content{gap:16px;padding:16px 12px}.mobile-header{margin:-16px -12px 4px;padding:10px 12px}.header-title h1{font-size:1.25rem}.header-title p{font-size:.82rem}.tiles-grid{grid-template-columns:1fr}.tile-value{font-size:1.9rem}.tile-icon{width:40px;height:40px}.btn-primary,.btn-secondary{padding:10px 14px;font-size:.85rem}.dir-header>div:last-child{flex-wrap:wrap;gap:10px;width:100%}.dir-header>div:last-child>button{flex:calc(50% - 5px);justify-content:center}.dir-header>div:last-child>.date-selector,.dir-header>div:last-child>.glass-panel{flex:100%;width:100%}.live-clock-time{letter-spacing:0;font-size:1.8rem}.live-clock-pill{padding:3px 8px 3px 6px;font-size:.62rem;top:12px;right:12px}}.confirm-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0f172a73;justify-content:center;align-items:center;padding:24px;animation:.18s ease-out fade-in;display:flex;position:fixed;inset:0}.confirm-dialog{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:420px;padding:36px 28px 24px;animation:.28s cubic-bezier(.34,1.56,.64,1) confirm-pop;position:relative;overflow:hidden;box-shadow:0 30px 80px #0f172a40,0 0 0 1px #0f172a0d}.confirm-dialog:before{content:"";pointer-events:none;background:radial-gradient(at top,#6366f11a,#0000 70%);height:80px;position:absolute;top:0;left:0;right:0}.confirm-danger:before{background:radial-gradient(at top,#ef44441f,#0000 70%)}.confirm-warning:before{background:radial-gradient(at top,#f59e0b1f,#0000 70%)}.confirm-logout:before{background:radial-gradient(at top,#ef44441a,#0000 70%)}@keyframes confirm-pop{0%{opacity:0;transform:translateY(12px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.confirm-close{width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px}.confirm-close:hover{color:var(--text-primary);background:#0f172a0f}.confirm-icon-ring{z-index:1;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 18px;display:flex;position:relative}.confirm-icon-ring:before{content:"";background:#6366f11a;border-radius:50%;animation:1.8s ease-out infinite ring-pulse;position:absolute;inset:0}.confirm-danger .confirm-icon-ring:before{background:#ef44441f}.confirm-warning .confirm-icon-ring:before{background:#f59e0b1f}.confirm-logout .confirm-icon-ring:before{background:#ef44441a}@keyframes ring-pulse{0%{opacity:.8;transform:scale(.85)}70%{opacity:0;transform:scale(1.25)}to{opacity:0;transform:scale(1.25)}}.confirm-icon-bg{z-index:1;width:56px;height:56px;color:var(--color-primary);background:linear-gradient(135deg,#6366f12e,#8b5cf62e);border:1px solid #6366f140;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative;box-shadow:0 8px 20px #6366f12e}.confirm-danger .confirm-icon-bg,.confirm-logout .confirm-icon-bg{color:var(--color-absent-sl);background:linear-gradient(135deg,#ef44442e,#ef444414);border-color:#ef44444d;box-shadow:0 8px 20px #ef44442e}.confirm-warning .confirm-icon-bg{color:var(--color-wfh);background:linear-gradient(135deg,#f59e0b33,#f59e0b14);border-color:#f59e0b4d;box-shadow:0 8px 20px #f59e0b33}.confirm-title{z-index:1;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:8px;font-size:1.25rem;font-weight:800;position:relative}.confirm-message{z-index:1;color:var(--text-secondary);margin-bottom:24px;padding:0 8px;font-size:.92rem;line-height:1.55;position:relative}.confirm-actions{z-index:1;justify-content:stretch;gap:10px;display:flex;position:relative}.btn-confirm-cancel,.btn-confirm-primary,.btn-confirm-danger,.btn-confirm-logout{appearance:none;border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-smooth);border:1px solid #0000;flex:1;padding:11px 16px;font-family:inherit;font-size:.92rem;font-weight:700}.btn-confirm-cancel{color:var(--text-secondary);background:#0f172a0a;border-color:#0f172a0f}.btn-confirm-cancel:hover{color:var(--text-primary);background:#0f172a12}.btn-confirm-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;box-shadow:0 6px 18px #6366f159}.btn-confirm-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px #6366f173}.btn-confirm-danger,.btn-confirm-logout{color:#fff;background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:0 6px 18px #ef444459}.btn-confirm-danger:hover,.btn-confirm-logout:hover{transform:translateY(-1px);box-shadow:0 10px 24px #ef444473}.calendar-panel{flex-direction:column;gap:16px;padding:24px;display:flex}.calendar-header{border-bottom:1px solid var(--panel-border);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;padding-bottom:14px;display:flex}.calendar-title-block{flex-direction:column;gap:4px;display:flex}.calendar-title{color:var(--text-primary);align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:inline-flex}.calendar-title svg{color:var(--color-primary)}.calendar-holiday-count{color:var(--color-absent-sl);font-size:.78rem;font-weight:600}.calendar-nav{align-items:center;gap:6px;display:inline-flex}.calendar-nav-btn{appearance:none;color:var(--color-primary);cursor:pointer;width:34px;height:34px;transition:var(--transition-smooth);background:#6366f10f;border:1px solid #6366f126;border-radius:10px;justify-content:center;align-items:center;font-family:inherit;font-weight:600;display:inline-flex}.calendar-nav-btn:hover{background:#6366f121;border-color:#6366f152;transform:translateY(-1px)}.calendar-today-btn{letter-spacing:.02em;width:auto;padding:0 14px;font-size:.78rem}.calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calendar-weekday{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:6px 0;font-size:.7rem;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calendar-cell{aspect-ratio:1;color:var(--text-primary);text-align:center;transition:var(--transition-smooth);background:#0f172a06;border:1px solid #0000;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;padding:4px;font-size:.92rem;font-weight:600;display:flex;position:relative;overflow:hidden}.calendar-cell-empty{pointer-events:none;background:0 0}.calendar-cell:not(.calendar-cell-empty):hover{background:#6366f114;border-color:#6366f12e;transform:translateY(-1px)}.calendar-day-num{line-height:1}.calendar-day-label{text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin-top:3px;padding:0 2px;font-size:.6rem;font-weight:600;line-height:1.1;display:block;overflow:hidden}.calendar-holiday{color:var(--color-absent-sl);background:linear-gradient(135deg,#ef444433,#ef444414);border-color:#ef444452;box-shadow:0 2px 8px #ef44441f}.calendar-holiday:hover{background:linear-gradient(135deg,#ef444447,#ef444424);border-color:#ef444473;transform:translateY(-1px)}.calendar-weekend{color:#b45309;background:#f59e0b17;border-color:#f59e0b38}.calendar-weekend:hover{background:#f59e0b29;border-color:#f59e0b66}.calendar-today{box-shadow:0 0 0 2px var(--color-primary), 0 6px 16px #6366f147;font-weight:800}.calendar-today:not(.calendar-holiday):not(.calendar-weekend){background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff;border-color:#0000}.calendar-today:not(.calendar-holiday):not(.calendar-weekend):hover{background:linear-gradient(135deg, var(--color-primary), var(--color-field));color:#fff}.calendar-legend{border-top:1px solid var(--panel-border);color:var(--text-secondary);flex-wrap:wrap;gap:16px;padding-top:14px;font-size:.78rem;font-weight:500;display:flex}.calendar-legend-item{align-items:center;gap:6px;display:inline-flex}.calendar-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.calendar-dot-holiday{background:var(--color-absent-sl);box-shadow:0 0 0 3px #ef444426}.calendar-dot-weekend{background:var(--color-wfh);box-shadow:0 0 0 3px #f59e0b26}.calendar-dot-today{background:linear-gradient(135deg, var(--color-primary), var(--color-field));box-shadow:0 0 0 3px #6366f12e}@media (width<=768px){.calendar-panel{padding:18px}.calendar-cell{border-radius:8px;font-size:.82rem}.calendar-day-label{font-size:.55rem}.calendar-grid,.calendar-weekdays{gap:4px}}.live-clock-panel{text-align:center;-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);background:#ffffffb3;flex-direction:column;align-items:center;gap:8px;padding:36px 32px 32px;display:flex;position:relative;overflow:hidden}.live-clock-bg{pointer-events:none;z-index:0;background:radial-gradient(circle at 20% 20%,#6366f124,#0000 55%),radial-gradient(circle at 80% 30%,#8b5cf61f,#0000 55%),radial-gradient(circle at 50% 100%,#10b98114,#0000 60%);position:absolute;inset:0}.live-clock-pill{color:var(--color-present);letter-spacing:.1em;z-index:2;background:#10b9811a;border:1px solid #10b98140;border-radius:999px;align-items:center;gap:6px;padding:4px 10px 4px 8px;font-size:.68rem;font-weight:800;display:inline-flex;position:absolute;top:16px;right:16px}.live-clock-dot{background:var(--color-present);border-radius:50%;width:7px;height:7px;animation:1.6s cubic-bezier(.4,0,.6,1) infinite live-pulse;box-shadow:0 0 #10b98199}@keyframes live-pulse{0%{box-shadow:0 0 #10b9818c}70%{box-shadow:0 0 0 9px #10b98100}to{box-shadow:0 0 #10b98100}}.live-clock-icon-wrap{z-index:1;width:64px;height:64px;color:var(--color-primary);background:linear-gradient(135deg,#6366f126,#8b5cf626);border:1px solid #6366f140;border-radius:50%;justify-content:center;align-items:center;margin-bottom:8px;display:flex;position:relative}.live-clock-icon-wrap:before{content:"";border:2px solid #6366f14d;border-radius:50%;animation:2.4s ease-out infinite halo-pulse;position:absolute;inset:-6px}@keyframes halo-pulse{0%{opacity:.7;transform:scale(.92)}70%{opacity:0;transform:scale(1.2)}to{opacity:0;transform:scale(1.2)}}.live-clock-time{z-index:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em;background:linear-gradient(135deg, var(--text-primary) 0%, var(--color-primary) 60%, var(--color-field) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800;line-height:1.1;position:relative}.live-clock-date{z-index:1;color:var(--text-secondary);letter-spacing:.01em;font-size:.95rem;font-weight:600;position:relative}
