:root{--bg-base:#0f1117;--bg-surface:#1a1d27;--bg-elevated:#22263a;--bg-hover:#2a2f47;--border:#2e3350;--border-light:#3a3f5c;--text-primary:#e8eaf0;--text-secondary:#8b90a7;--text-muted:#5a5f7a;--accent:#6366f1;--accent-hover:#4f52d3;--accent-light:#6366f126;--success:#10b981;--success-light:#10b98126;--warning:#f59e0b;--warning-light:#f59e0b26;--danger:#ef4444;--danger-light:#ef444426;--info:#06b6d4;--info-light:#06b6d426;--sidebar-width:240px;--topbar-height:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--transition:.2s ease;--font:"Inter", -apple-system, sans-serif}[data-theme=light]{--bg-base:#f0f2f9;--bg-surface:#fff;--bg-elevated:#f7f8fc;--bg-hover:#eef0f8;--border:#e2e5f1;--border-light:#ced3e8;--text-primary:#1a1d2e;--text-secondary:#5a5f7a;--text-muted:#9097b5;--accent-light:#6366f114;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #00000026}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);min-height:100vh;transition:background var(--transition), color var(--transition);font-size:14px;line-height:1.6;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;height:100vh;transition:transform var(--transition), background var(--transition);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.brand-icon{background:var(--accent);border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.brand-icon .material-symbols-rounded{font-variation-settings:"FILL" 1;font-size:20px}.brand-name{color:var(--text-primary);letter-spacing:-.3px;font-size:16px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-light);color:var(--accent)}.nav-item .material-symbols-rounded{font-variation-settings:"FILL" 0;flex-shrink:0;font-size:20px}.nav-item.active .material-symbols-rounded{font-variation-settings:"FILL" 1}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;padding:12px 10px}.theme-toggle{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;font-weight:500;display:flex}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.theme-toggle .material-symbols-rounded{font-size:20px}.main-wrapper{margin-left:var(--sidebar-width);min-height:100vh;transition:margin var(--transition);flex-direction:column;flex:1;display:flex}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;transition:background var(--transition);align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.sidebar-toggle{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;padding:6px;display:none}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-toggle .material-symbols-rounded{font-size:22px;display:block}.topbar-title h1{color:var(--text-primary);margin:0;font-size:17px;font-weight:600}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.page-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:28px 24px}.btn{border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);transition:all var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;align-items:center;gap:6px;padding:9px 16px;font-size:13.5px;font-weight:500;text-decoration:none;display:inline-flex}.btn .material-symbols-rounded{font-size:18px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid #0000}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success-light);color:var(--success);border:1px solid #0000}.btn-success:hover{background:var(--success);color:#fff}.btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-sm .material-symbols-rounded{font-size:16px}.btn-icon{border-radius:var(--radius-sm);padding:8px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:background var(--transition), border-color var(--transition);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:14px;font-weight:600}.card-subtitle{color:var(--text-secondary);margin-top:2px;font-size:12px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:20px;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card:before{content:"";background:var(--kpi-color,var(--accent));width:100%;height:3px;position:absolute;top:0;left:0}.kpi-icon{border-radius:var(--radius-sm);background:var(--kpi-color-light,var(--accent-light));justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;display:flex}.kpi-icon .material-symbols-rounded{color:var(--kpi-color,var(--accent));font-variation-settings:"FILL" 1;font-size:22px}.kpi-value{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:800;line-height:1.1}.kpi-label{color:var(--text-secondary);font-size:12.5px;font-weight:500}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}.form-control{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);transition:all var(--transition);outline:none;padding:10px 12px;font-size:13.5px}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.form-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));align-items:end;gap:12px;display:grid}.table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--bg-elevated);text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 14px;font-size:11.5px;font-weight:600}tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}tbody td{color:var(--text-primary);vertical-align:middle;padding:12px 14px;font-size:13.5px}.td-muted{color:var(--text-secondary);font-size:12.5px}.action-btns{align-items:center;gap:6px;display:flex}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-muted{background:var(--bg-elevated);color:var(--text-secondary)}.tabs{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.tab-btn{color:var(--text-secondary);font-family:var(--font);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.tab-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.tab-btn.active{background:var(--accent);color:#fff}.tab-panel{display:none}.tab-panel.active{display:block}.filter-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;padding:14px 16px;display:flex}.filter-bar .form-group{flex:1;min-width:140px;margin-bottom:0}.date-presets{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.date-preset-btn{border:1px solid var(--border);color:var(--text-secondary);font-size:12px;font-family:var(--font);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:20px;padding:5px 12px}.date-preset-btn:hover{border-color:var(--accent);color:var(--accent)}.date-preset-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:24px;display:grid}.chart-container{height:260px;position:relative}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .material-symbols-rounded{font-variation-settings:"FILL" 1;opacity:.4;margin-bottom:12px;font-size:48px;display:block}.empty-state p{font-size:14px}.color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.section-title{color:var(--text-primary);font-size:15px;font-weight:600}.hours-chip{color:var(--accent);align-items:center;gap:4px;font-size:13.5px;font-weight:600;display:inline-flex}.progress-bar{background:var(--bg-elevated);border-radius:3px;height:6px;margin-top:4px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:var(--shadow-lg);transition:transform var(--transition);transform:scale(.95)}.modal-overlay.open .modal{transform:scale(1)}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{font-size:15px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;padding:4px;display:flex}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:18px 20px}.modal-footer{justify-content:flex-end;gap:8px;padding:12px 20px 18px;display:flex}.toast-container{z-index:2000;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:all;align-items:center;gap:10px;min-width:260px;max-width:360px;padding:12px 16px;font-size:13.5px;font-weight:500;animation:.3s slideInToast;display:flex}.toast .material-symbols-rounded{font-variation-settings:"FILL" 1;flex-shrink:0;font-size:20px}.toast-success{border-left:3px solid var(--success)}.toast-success .material-symbols-rounded{color:var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-error .material-symbols-rounded{color:var(--danger)}.toast-info{border-left:3px solid var(--accent)}.toast-info .material-symbols-rounded{color:var(--accent)}@keyframes slideInToast{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-right{text-align:right}.text-center{text-align:center}.font-bold{font-weight:700}.text-sm{font-size:12.5px}.text-muted{color:var(--text-secondary)}.w-full{width:100%}hr.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));align-items:start;gap:20px;display:grid}.report-summary-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px;display:grid}.summary-stat{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;padding:14px 16px}.summary-stat-value{color:var(--text-primary);font-size:20px;font-weight:800;line-height:1.2}.summary-stat-label{color:var(--text-secondary);margin-top:2px;font-size:11.5px;font-weight:500}.color-swatch-list{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.color-swatch{cursor:pointer;width:24px;height:24px;transition:all var(--transition);border:2px solid #0000;border-radius:50%}.color-swatch:hover,.color-swatch.selected{border-color:var(--text-primary);transform:scale(1.2)}.ts-wrapper.form-control{background:0 0;border:none;padding:0}.ts-control{font-family:var(--font);align-items:center;min-height:40px;font-size:13.5px;display:flex;background:var(--bg-elevated)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;color:var(--text-primary)!important;padding:6px 12px!important}.ts-control.focus{box-shadow:0 0 0 3px var(--accent-light)!important;border-color:var(--accent)!important}.ts-control>input{font-family:var(--font);font-size:13.5px;color:var(--text-primary)!important}.ts-dropdown{font-family:var(--font);margin-top:4px;font-size:13.5px;background:var(--bg-elevated)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;color:var(--text-primary)!important;box-shadow:var(--shadow-md)!important}.ts-dropdown .option{cursor:pointer;padding:8px 12px}.ts-dropdown .active{background:var(--bg-hover)!important;color:var(--text-primary)!important}.ts-control .item{align-items:center;display:inline-flex;background:var(--bg-surface)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;border-radius:4px!important;margin:2px!important;padding:2px 8px!important}.ts-wrapper.plugin-remove_button .item .remove{border-left:1px solid var(--border)!important;color:var(--text-muted)!important;padding:0 6px!important}.ts-wrapper.plugin-remove_button .item .remove:hover{background:var(--danger-light)!important;color:var(--danger)!important}.sidebar-user{border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);align-items:center;gap:9px;margin-bottom:4px;padding:10px 12px;display:flex}.sidebar-user-dot{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.logout-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;display:flex}.logout-btn:hover{background:var(--danger-light);color:var(--danger)}.logout-btn .material-symbols-rounded{font-size:18px}.role-badge{border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.role-badge.admin{color:#6366f1;background:#6366f126}.role-badge.employee{color:#10b981;background:#10b9811f}.dept-hours-widget{grid-template-columns:auto 1fr;align-items:center;gap:24px;display:grid}.dept-ring-wrap{flex-shrink:0;width:120px;height:120px;position:relative}.dept-ring-wrap svg{width:120px;height:120px;transform:rotate(-90deg)}.dept-ring-bg{fill:none;stroke:var(--bg-elevated);stroke-width:10px}.dept-ring-fill{fill:none;stroke-width:10px;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1),stroke .4s}.dept-ring-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.dept-ring-pct{color:var(--text-primary);letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1}.dept-ring-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-top:2px;font-size:10px;font-weight:500}.dept-stats-side{flex-direction:column;gap:10px;display:flex}.dept-widget-header{margin-bottom:4px}.dept-widget-title{color:var(--text-primary);font-size:13px;font-weight:600}.dept-widget-meta{color:var(--text-muted);margin-top:1px;font-size:11.5px}.dept-stat-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.dept-stat-label{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;display:flex}.dept-stat-label .material-symbols-rounded{opacity:.7;font-size:14px}.dept-stat-value{color:var(--text-primary);white-space:nowrap;font-size:13px;font-weight:700}.dept-progress-wrap{margin-top:4px}.dept-progress-labels{color:var(--text-muted);justify-content:space-between;margin-bottom:5px;font-size:11px;display:flex}.dept-progress-track{background:var(--bg-elevated);border-radius:4px;height:7px;overflow:hidden}.dept-progress-fill{border-radius:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1),background .4s}.dept-color-good{stroke:#10b981}.dept-color-warn{stroke:#f59e0b}.dept-color-low{stroke:#ef4444}.dept-color-over{stroke:#6366f1}.dept-bar-good{background:#10b981}.dept-bar-warn{background:#f59e0b}.dept-bar-low{background:#ef4444}.dept-bar-over{background:var(--accent)}.dept-skeleton{grid-template-columns:120px 1fr;align-items:center;gap:24px;display:grid}.skeleton-circle{background:var(--bg-elevated);border-radius:50%;width:120px;height:120px;animation:1.4s ease-in-out infinite skeletonPulse}.skeleton-lines{flex-direction:column;gap:10px;display:flex}.skeleton-line{background:var(--bg-elevated);border-radius:6px;height:12px;animation:1.4s ease-in-out infinite skeletonPulse}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.4}}@media (width<=480px){.dept-hours-widget{text-align:center;grid-template-columns:1fr;justify-items:center}.dept-stat-row{justify-content:center}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-wrapper{margin-left:0}.sidebar-toggle{display:flex}.page-content{padding:16px}.kpi-grid{grid-template-columns:1fr 1fr}.charts-grid,.settings-grid,.form-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .form-group{min-width:100%;margin-bottom:12px}.filter-bar>div{width:100%}.filter-bar .btn{justify-content:center;width:100%;margin-top:8px}.date-presets{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:6px;overflow-x:auto}.date-preset-btn{flex-shrink:0}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.section-header>div{flex-wrap:wrap;gap:8px;width:100%;display:flex}.section-header>div>.btn{flex:1;justify-content:center;min-width:120px}.tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;width:100%;overflow-x:auto}.tab-btn{flex-shrink:0}}@media (width<=480px){.kpi-grid{grid-template-columns:1fr}.report-summary-row{grid-template-columns:1fr 1fr}.topbar{padding:0 16px}.topbar-title h1{font-size:15px}.modal{width:95%}.modal-body{padding:16px}.modal-footer{flex-direction:column;gap:10px}.modal-footer .btn{justify-content:center;width:100%}.form-row{grid-template-columns:1fr}}.notif-wrapper{align-items:center;display:flex;position:relative}.notif-btn{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.notif-btn:hover,.notif-btn--active{background:var(--bg-hover);color:var(--text-primary)}.notif-btn .material-symbols-rounded{font-variation-settings:"FILL" 0;transition:font-variation-settings var(--transition);font-size:22px}.notif-btn--active .material-symbols-rounded{font-variation-settings:"FILL" 1;color:var(--accent)}.notif-badge{background:var(--danger);color:#fff;border:2px solid var(--bg-surface);pointer-events:none;border-radius:10px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;animation:.25s cubic-bezier(.34,1.56,.64,1) badgePop;display:none;position:absolute;top:4px;right:4px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.notif-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:360px;box-shadow:var(--shadow-lg);z-index:500;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;transform:translateY(-8px)scale(.97)}.notif-panel--open{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.notif-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.notif-panel-title{color:var(--text-primary);letter-spacing:-.2px;font-size:13.5px;font-weight:700}.notif-mark-all{color:var(--accent);font-family:var(--font);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition);background:0 0;border:none;padding:4px 8px;font-size:12px;font-weight:500}.notif-mark-all:hover{background:var(--accent-light)}.notif-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:380px;overflow-y:auto}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-track{background:0 0}.notif-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.notif-empty{color:var(--text-muted);text-align:center;justify-content:center;align-items:center;gap:8px;padding:36px 20px;font-size:13px;display:flex}.notif-item{cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--transition);align-items:flex-start;gap:12px;padding:12px 16px;display:flex;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-hover)}.notif-item--unread{background:color-mix(in srgb, var(--accent) 5%, transparent);border-left:3px solid var(--accent)}.notif-item--unread:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.notif-icon{border-radius:var(--radius-sm);background:var(--bg-elevated);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-top:1px;display:flex}.notif-icon .material-symbols-rounded{font-variation-settings:"FILL" 1;font-size:18px}.notif-icon--pending{background:var(--warning-light)}.notif-icon--pending .material-symbols-rounded{color:var(--warning)}.notif-icon--approved{background:var(--success-light)}.notif-icon--approved .material-symbols-rounded{color:var(--success)}.notif-icon--rejected{background:var(--danger-light)}.notif-icon--rejected .material-symbols-rounded{color:var(--danger)}.notif-content{flex:1;min-width:0}.notif-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:13px;font-weight:600;line-height:1.3;overflow:hidden}.notif-body{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.notif-time{color:var(--text-muted);font-size:11px;font-weight:500}.notif-delete{width:24px;height:24px;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.notif-item:hover .notif-delete{opacity:1}.notif-delete:hover{background:var(--danger-light);color:var(--danger)}.notif-delete .material-symbols-rounded{font-size:15px}@media (width<=480px){.notif-panel{width:calc(100vw - 24px);right:-8px}}
