:root{--c-primary:#264370;--c-primary-dark:#1c3256;--c-primary-light:#e8eef6;--c-primary-ring:#26437033;--c-blue:#2470a7;--c-teal:#41abb4;--c-green:#55a93d;--c-lime:#bac823;--c-yellow:#fae91c;--c-bg:#f4f6f9;--c-surface:#fff;--c-border:#dde3ee;--c-border-light:#edf1f7;--c-text:#1a2642;--c-text-secondary:#5a6a8a;--c-text-muted:#9aa5c0;--c-success:#55a93d;--c-warning:#bac823;--c-danger:#dc2626;--c-info:#41abb4;--c-sidebar-bg:#264370;--c-sidebar-link:#ffffff9e;--c-sidebar-active:#ffffff1f;--c-sidebar-border:#ffffff1a;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:14px;--r-full:999px;--shadow-sm:0 1px 3px #26437014;--shadow-md:0 4px 12px #2643701a;--shadow-lg:0 8px 24px #2643701f;--shadow-xl:0 20px 60px #26437033;--ease-out:cubic-bezier(.16, 1, .3, 1);--duration:.18s;--t-xs:.75rem;--t-sm:.833rem;--t-base:.9rem;--t-md:1rem;--t-lg:1.2rem;--t-xl:1.5rem;--t-kpi:2.2rem;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"SF Mono", "Cascadia Code", "Fira Code", "Courier New", monospace}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-sans);background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;font-feature-settings:"cv02", "cv03", "cv04", "cv11";margin:0;font-size:15px;line-height:1.6}h1,h2,h3,h4{margin:0;line-height:1.25}p{margin:0}a{color:var(--c-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit}:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--r-full);background:#d1d5db}::-webkit-scrollbar-thumb:hover{background:#9ca3af}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.auth-layout{align-items:stretch;min-height:100vh;display:flex}.login-split{width:100%;min-height:100vh;display:flex}.login-brand-panel{background:#264370;flex-direction:column;flex:0 0 52%;padding:48px 56px;display:flex;position:relative;overflow:hidden}.login-brand-logo{align-items:center;gap:14px;margin-bottom:auto;display:flex}.login-card-logo{border-bottom:1px solid #e5e7eb;justify-content:center;margin-bottom:24px;padding-bottom:24px;display:flex}.login-logo-img{object-fit:contain;width:auto;max-height:60px}.login-brand-name{letter-spacing:.2em;text-transform:uppercase;background:linear-gradient(120deg,#fff 0%,#41abb4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-style:italic;font-weight:900;display:block}.login-brand-product{color:#ffffff73;letter-spacing:.28em;text-transform:uppercase;margin-top:5px;font-family:SF Mono,Cascadia Code,Fira Code,Courier New,monospace;font-size:.62rem;font-weight:400;display:block}.login-brand-content{margin:auto 0 40px}.login-brand-headline{letter-spacing:.01em;background:linear-gradient(135deg,#fff 0%,#b8d4e8 55%,#41abb4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:20px;font-size:2.7rem;font-weight:800;line-height:1.1}.login-brand-sub{color:#fff6;letter-spacing:.03em;max-width:380px;font-size:.85rem;line-height:1.75}.login-brand-features{flex-direction:column;gap:14px;margin-bottom:56px;display:flex}.login-feature{color:#ffffff8c;letter-spacing:.16em;text-transform:uppercase;align-items:center;gap:14px;font-size:.68rem;font-weight:500;display:flex}.login-feature-dot{background:linear-gradient(90deg,#41abb4,#2470a7);border-radius:2px;flex-shrink:0;width:22px;height:2px}.login-deco-svg{pointer-events:none;opacity:1;width:500px;height:540px;position:absolute;bottom:-60px;right:-60px}.login-form-panel{background:#f5f7fb;flex:1;justify-content:center;align-items:center;padding:40px 32px;display:flex}.login-card{width:100%;max-width:400px;animation:scaleIn .22s var(--ease-out);background:#fff;border-radius:16px;padding:40px 36px;box-shadow:0 4px 32px #00000014,0 1px 4px #0000000a}.login-card-header{margin-bottom:28px}.login-card-title{color:#12172a;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;font-size:1.3rem;font-weight:900}.login-card-subtitle{color:#9ca3af;letter-spacing:.18em;text-transform:uppercase;font-family:SF Mono,Cascadia Code,Fira Code,Courier New,monospace;font-size:.65rem}.login-error{color:#dc2626;border-radius:var(--r-md);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:.85rem}@keyframes login-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-error--shake{animation:.4s login-shake}.login-form{gap:18px}.login-submit{letter-spacing:.22em;text-transform:uppercase;height:46px;margin-top:4px;font-size:.72rem;font-weight:700;background:#264370!important;border-color:#264370!important}.login-submit:hover:not(:disabled){background:#1c3256!important;border-color:#1c3256!important}.login-card-footer{text-align:center;color:#c4c9d4;letter-spacing:.22em;text-transform:uppercase;margin-top:24px;font-family:SF Mono,Cascadia Code,Fira Code,Courier New,monospace;font-size:.6rem}.login-forgot{text-align:center;margin-top:12px}.login-forgot-link{color:var(--c-text-secondary);font-size:.82rem;text-decoration:none;transition:color .15s}.login-forgot-link:hover{color:var(--c-teal);text-decoration:underline}@media (width<=768px){.login-split{flex-direction:column}.login-brand-panel{flex:none;min-height:auto;padding:32px 28px 28px}.login-brand-headline{font-size:1.8rem}.login-brand-features,.login-deco-svg{display:none}.login-form-panel{padding:32px 20px}.login-card{padding:28px 22px}}.form{flex-direction:column;gap:16px;display:flex}.form label{font-size:var(--t-sm);color:#374151;letter-spacing:.01em;flex-direction:column;gap:5px;font-weight:600;display:flex}.label--inline{cursor:pointer;align-items:center;flex-direction:row!important;gap:8px!important;font-weight:400!important}.form input,.form select,.form textarea{border:1px solid var(--c-border);border-radius:var(--r-md);color:var(--c-text);background:var(--c-surface);transition:border-color var(--duration), box-shadow var(--duration);padding:9px 12px;font-size:.9rem}.form input::placeholder,.form textarea::placeholder{color:var(--c-text-muted)}.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-ring);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-error{color:var(--c-danger);font-size:.78rem}.form-hint{color:var(--c-text-3,#94a3b8);font-size:.78rem;font-style:italic}.form-duration{background:var(--c-surface-2,#f1f5f9);border-radius:var(--r-md);align-items:center;gap:8px;padding:6px 12px;font-size:.85rem;display:flex}.form-duration-label{color:var(--c-text-2)}.form-duration-value{color:var(--c-primary);font-weight:600}.form-error--banner{border-radius:var(--r-md);background:#fef2f2;border:1px solid #fecaca;align-items:flex-start;gap:8px;padding:10px 14px;font-size:.875rem;display:flex}.form-group{flex-direction:column;gap:5px;width:100%;display:flex}.form-label{font-size:var(--t-sm);color:#374151;letter-spacing:.01em;font-weight:600}.form-input{border:1px solid var(--c-border);border-radius:var(--r-md);color:var(--c-text);background:var(--c-surface);width:100%;transition:border-color var(--duration), box-shadow var(--duration);padding:9px 40px 9px 12px;font-family:inherit;font-size:.9rem}.form-input::placeholder{color:var(--c-text-muted)}.form-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-ring);outline:none}.form-input--error{border-color:var(--c-danger)!important;box-shadow:0 0 0 3px #dc26261f!important}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper .form-input{padding-right:40px}.input-eye-btn{cursor:pointer;color:var(--c-text-muted);border-radius:var(--r-sm);transition:color var(--duration);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.input-eye-btn:hover{color:var(--c-text)}.btn{border-radius:var(--r-md);font-size:var(--t-base);letter-spacing:.01em;cursor:pointer;transition:background var(--duration), color var(--duration), border-color var(--duration), box-shadow var(--duration), opacity var(--duration);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.btn--primary{background:var(--c-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--c-primary-dark);box-shadow:0 2px 8px #284fd640}.btn--ghost{border-color:var(--c-border);color:#4b5563;background:0 0}.btn--ghost:hover:not(:disabled){background:#f9fafb}.btn--active{background:var(--c-primary-light);border-color:var(--c-primary);color:var(--c-primary)}.btn-group{gap:2px;display:flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--r-md) 0 0 var(--r-md)}.btn-group .btn:last-child{border-radius:0 var(--r-md) var(--r-md) 0}.btn--danger{background:var(--c-danger);color:#fff}.btn--danger:hover:not(:disabled){background:#b91c1c}.btn--danger-ghost{color:var(--c-danger);background:0 0}.btn--danger-ghost:hover:not(:disabled){color:#b91c1c;background:#fef2f2}.btn--success{background:var(--c-success);color:#fff}.btn--success:hover:not(:disabled){background:#047857}.btn--icon{color:var(--c-text-secondary);border-radius:var(--r-sm);background:0 0;border-color:#0000;flex-shrink:0;padding:6px}.btn--icon:hover:not(:disabled){color:var(--c-text);background:#f3f4f6}.btn--sm{font-size:var(--t-sm);border-radius:var(--r-sm);padding:5px 12px}.btn--full{width:100%}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--c-sidebar-bg);color:#fff;flex-direction:column;flex-shrink:0;gap:28px;width:232px;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0;overflow:hidden}.report-submenu{border-right:1px solid var(--c-border);background:#eef1f8;flex-direction:column;flex-shrink:0;gap:20px;width:196px;height:100vh;padding:20px 12px;display:flex;position:sticky;top:0;overflow-y:auto}.report-submenu-group{flex-direction:column;gap:2px;display:flex}.report-submenu-label{text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-muted);margin-bottom:4px;padding:0 10px;font-size:.68rem;font-weight:700}.report-submenu-item{text-align:left;border-radius:var(--r-md);width:100%;font-size:var(--t-base);color:var(--c-text-secondary);cursor:pointer;transition:background var(--duration), color var(--duration);background:0 0;border:none;align-items:center;gap:8px;padding:8px 10px;font-weight:500;display:flex}.report-submenu-item:hover{color:var(--c-primary);background:#26437012}.report-submenu-item--active{background:var(--c-primary);color:#fff;font-weight:600}.report-submenu-item--active:hover{background:var(--c-primary-dark);color:#fff}.report-submenu-inline-select{padding:6px 10px 4px}.report-submenu-select{border-radius:var(--r-md);border:1.5px solid var(--c-border);width:100%;color:var(--c-text);cursor:pointer;transition:border-color var(--duration);background:#fff;outline:none;padding:6px 8px;font-size:.78rem}.report-submenu-select:focus{border-color:var(--c-primary)}.report-submenu-select--required{border-color:var(--c-warning,#f59e0b);background:#fffbeb}.sidebar-brand{border-bottom:1px solid var(--c-sidebar-border);flex-shrink:0;align-items:center;gap:10px;padding-bottom:18px;display:flex}.sidebar-brand-text-wrap{flex-direction:column;gap:1px;display:flex}.sidebar-brand-name{letter-spacing:.18em;text-transform:uppercase;background:linear-gradient(120deg,#fff 0%,#41abb4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1rem;font-style:italic;font-weight:900;line-height:1}.sidebar-brand-sub{letter-spacing:.22em;text-transform:uppercase;color:#fff6;font-size:.55rem;font-weight:400;line-height:1;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-nav{flex-direction:column;gap:3px;display:flex}.sidebar-link{border-radius:var(--r-md);color:var(--c-sidebar-link);font-size:var(--t-sm);letter-spacing:.01em;transition:background var(--duration), color var(--duration);align-items:center;gap:8px;padding:9px 12px;font-weight:500;display:flex;position:relative}.sidebar-link:hover{color:#fff;background:#ffffff14;text-decoration:none}.sidebar-link--active{color:#fff;background:#ffffff24}.sidebar-link--active svg{color:#41abb4}.sidebar-link-label{flex:1}.sidebar-badge{color:#fff;background:#ef4444;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.68rem;font-weight:700;line-height:1;display:flex}.sidebar-profile-switcher{border-top:1px solid #ffffff14;padding:10px 8px 4px}.sidebar-profile-switch-btn{border-radius:var(--r-md);cursor:pointer;width:100%;font-size:var(--t-sm);transition:background var(--duration), opacity var(--duration);text-align:left;border:none;align-items:center;gap:8px;padding:8px 10px;font-weight:500;display:flex}.sidebar-profile-switch-btn span{flex:1}.sidebar-profile-switch-icon{opacity:.5;flex-shrink:0}.sidebar-profile-switch-btn--collab{color:#a8e6eb;background:#41abb426}.sidebar-profile-switch-btn--collab:hover{background:#41abb447}.sidebar-profile-switch-btn--admin{color:#fae91c;background:#fae91c26}.sidebar-profile-switch-btn--admin:hover{background:#fae91c47}.sidebar-footer{border-top:1px solid var(--c-sidebar-border);align-items:center;gap:10px;margin-top:auto;padding-top:14px;display:flex}.sidebar-footer--link{border-radius:var(--r-md);transition:background var(--duration);margin:0 -8px;padding:6px 8px;text-decoration:none}.sidebar-footer--link:hover{background:var(--c-sidebar-active);text-decoration:none}.sidebar-footer-text{flex-direction:column;gap:2px;min-width:0;display:flex}.sidebar-user-name{font-size:var(--t-sm);color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.01em;font-weight:600;overflow:hidden}.sidebar-user-dept{font-size:var(--t-xs);color:#41abb4;white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.sidebar-role-badge{color:#ffffff59;text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;font-weight:500;font-family:var(--font-mono);margin-top:2px}.content{flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex;overflow:hidden}.topbar{background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:52px;padding:0 24px;display:flex}.topbar-page{font-size:var(--t-base);color:var(--c-text-secondary);letter-spacing:.01em;flex:1;font-weight:600}.topbar-actions{align-items:center;gap:4px;display:flex}.topbar-user-link{border-radius:var(--r-md);transition:background var(--duration);align-items:center;gap:8px;padding:4px 8px;text-decoration:none;display:flex}.topbar-user-link:hover{background:var(--c-primary-light);text-decoration:none}.topbar-user{color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.8rem;font-weight:500;overflow:hidden}.topbar-logout{border-radius:var(--r-md);color:var(--c-text-muted);cursor:pointer;transition:background var(--duration), color var(--duration);background:0 0;border:none;align-items:center;gap:5px;padding:6px 10px;font-size:.8rem;display:flex}.topbar-logout:hover{background:var(--c-bg);color:var(--c-danger)}.tum-wrap{position:relative}.tum-trigger{border-radius:var(--r-md);cursor:pointer;transition:background var(--duration);background:0 0;border:none;align-items:center;gap:8px;padding:4px 8px;display:flex}.tum-trigger:hover{background:var(--c-primary-light)}.tum-trigger-info{flex-direction:column;align-items:flex-start;line-height:1.25;display:flex}.tum-trigger-name{color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.8rem;font-weight:600;overflow:hidden}.tum-trigger-role{color:var(--c-text-muted);font-size:.68rem}.tum-chevron{color:var(--c-text-muted);transition:transform var(--duration);flex-shrink:0}.tum-chevron--open{transform:rotate(180deg)}.tum-dropdown{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);z-index:300;min-width:230px;padding:6px;animation:.12s fadeIn;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001f}.tum-section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--c-text-muted);padding:6px 10px 4px;font-size:.68rem;font-weight:700}.tum-role-item{border-radius:var(--r-md);width:100%;font-size:var(--t-base);color:var(--c-text);cursor:pointer;text-align:left;transition:background var(--duration);background:0 0;border:none;align-items:center;gap:10px;padding:9px 10px;font-weight:500;display:flex}.tum-role-item:hover{background:var(--c-bg)}.tum-radio{border:2px solid var(--c-border);width:17px;height:17px;transition:border-color var(--duration);border-radius:50%;flex-shrink:0;position:relative}.tum-radio--on{border-color:var(--c-primary);background:var(--c-primary);box-shadow:inset 0 0 0 3.5px #fff}.tum-sep{background:var(--c-border-light);height:1px;margin:5px 0}.tum-item{border-radius:var(--r-md);width:100%;font-size:var(--t-base);color:var(--c-text-secondary);cursor:pointer;text-align:left;transition:background var(--duration), color var(--duration);background:0 0;border:none;align-items:center;gap:10px;padding:9px 10px;font-weight:500;text-decoration:none;display:flex}.tum-item:hover{background:var(--c-bg);color:var(--c-text);text-decoration:none}.tum-item--danger{color:#dc2626}.tum-item--danger:hover{color:#dc2626;background:#fef2f2}.page{flex-direction:column;flex:1;gap:24px;padding:28px 28px 40px;display:flex;overflow-y:auto}.page-title{color:var(--c-text);letter-spacing:-.01em;font-size:1.1rem;font-weight:700;line-height:1.3}.page-loading{flex:1;justify-content:center;align-items:center;padding:80px;display:flex}.error-page{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:80px 24px;display:flex}.error-page-icon{opacity:.35}.error-page-icon--warn{color:var(--c-warning,#f59e0b);opacity:.6}.error-page-icon--muted{color:var(--c-text-2)}.error-page-code{color:var(--c-text-2);margin:0;font-size:4rem;font-weight:800;line-height:1}.error-page-title{margin:0;font-size:1.3rem;font-weight:600}.error-page-body{color:var(--c-text-2);max-width:360px;margin:0 0 8px;font-size:.95rem}.error-boundary{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;display:flex}.error-boundary-icon{color:var(--c-danger);opacity:.75}.error-boundary-title{margin:0;font-size:1rem;font-weight:600}.error-boundary-body{color:var(--c-text-2);max-width:400px;margin:0;font-size:.875rem}.modal-dialog{border-radius:var(--r-xl);box-shadow:var(--shadow-xl);max-width:90vw;max-height:88vh;animation:scaleIn .2s var(--ease-out);border:none;flex-direction:column;padding:0;display:flex}.modal-dialog::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0a0f238c;animation:.2s fadeIn}.modal-header{border-bottom:1px solid var(--c-border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{color:var(--c-text);font-size:1rem;font-weight:700}.modal-close{cursor:pointer;color:var(--c-text-muted);border-radius:var(--r-sm);transition:background var(--duration), color var(--duration);background:0 0;border:none;align-items:center;padding:4px;display:flex}.modal-close:hover{color:var(--c-text);background:#f3f4f6}.modal-body{flex-direction:column;flex:1;gap:14px;padding:18px 20px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--c-border-light);border-radius:0 0 var(--r-xl) var(--r-xl);background:#fafbff;flex-shrink:0;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.modal-meta{background:var(--c-primary-light);border-radius:var(--r-md);align-items:center;gap:10px;padding:10px 14px;display:flex}.modal-meta-type{color:var(--c-primary);font-size:.9rem;font-weight:600}.modal-meta-date{color:var(--c-text-secondary);font-size:.85rem}.modal-desc{color:var(--c-text-secondary);font-size:.875rem}.badge{border-radius:var(--r-full);font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:600;font-family:var(--font-sans);border:1px solid #0000;align-items:center;padding:3px 10px;display:inline-flex}.badge--draft{color:#6b7280;background:#f3f4f6;border-color:#e5e7eb}.badge--submitted{color:var(--c-warning);background:#fffbeb;border-color:#fde68a}.badge--approved{color:var(--c-success);background:#ecfdf5;border-color:#a7f3d0}.badge--rejected{color:var(--c-danger);background:#fef2f2;border-color:#fecaca}.badge--global{color:#0369a1;background:#f0f9ff;border-color:#bae6fd;align-items:center;gap:4px;display:inline-flex}.badge--personal{color:#7c3aed;background:#fdf4ff;border-color:#e9d5ff;align-items:center;gap:4px;display:inline-flex}.badge--dept{color:#c2410c;background:#fff7ed;border-color:#fed7aa;align-items:center;gap:4px;display:inline-flex}.scope-badges{flex-wrap:wrap;gap:4px;display:flex}.ml-8{margin-left:8px}.form-divider{border:none;border-top:1px solid var(--c-border);margin:16px 0}.form-section-label{color:var(--c-text);align-items:center;margin-bottom:4px;font-size:.8rem;font-weight:600;display:flex}.form-section{border:1px solid var(--c-border);border-radius:var(--r-md);margin-bottom:12px;padding:12px}.form-section-header{color:var(--c-text-secondary);align-items:center;gap:6px;margin-bottom:10px;font-size:.82rem;font-weight:600;display:flex}.form-section-count{background:var(--c-primary-light);color:var(--c-primary);border-radius:var(--r-full);margin-left:auto;padding:1px 7px;font-size:.72rem}.checklist{flex-direction:column;gap:4px;max-height:160px;padding-right:4px;display:flex;overflow-y:auto}.checklist-item{color:var(--c-text);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:8px;padding:4px 6px;font-size:.83rem;transition:background .1s;display:flex}.checklist-item:hover{background:var(--c-bg)}.checklist-item input[type=checkbox]{cursor:pointer;width:14px;height:14px;margin:0}.td--muted{color:var(--c-text-secondary);font-size:.82rem}.btn--xs{height:auto;padding:2px 8px;font-size:.72rem}.row--clickable{cursor:pointer}.row--clickable:hover td{background:var(--c-bg)}.table-legend{color:var(--c-text-muted);align-items:center;gap:4px;margin-top:8px;padding:0 4px;font-size:.72rem;display:flex}.table-legend svg{vertical-align:middle}.scope-modal-body{flex-direction:column;gap:12px;display:flex}.scope-current{background:var(--c-bg);border-radius:var(--r-md);align-items:center;gap:8px;padding:10px 12px;font-size:.82rem;display:flex}.scope-current-label{color:var(--c-text-secondary);font-weight:500}.scope-reset-btn{align-self:flex-start}.scope-section{border:1px solid var(--c-border);border-radius:var(--r-md);padding:12px}.scope-section-header{color:var(--c-text-secondary);align-items:center;gap:6px;margin-bottom:10px;font-size:.82rem;font-weight:600;display:flex}.checklist-item-sub{color:var(--c-text-muted);margin-left:auto;font-size:.72rem}.activity-type-personal-badge{letter-spacing:.04em;text-transform:uppercase;color:#7c3aed;border-radius:var(--r-full);white-space:nowrap;background:#fdf4ff;border:1px solid #e9d5ff;margin-left:auto;padding:1px 6px;font-size:.6rem;font-weight:600}.spinner-wrap{justify-content:center;align-items:center;display:flex}.spinner-wrap--sm{padding:8px}.spinner-wrap--md{padding:20px}.spinner-wrap--lg{padding:48px}.spinner{border:3px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;width:28px;height:28px;animation:.65s linear infinite spin}.spinner-wrap--sm .spinner{border-width:2px;width:18px;height:18px}.spinner-wrap--lg .spinner{border-width:4px;width:40px;height:40px}.skeleton{border-radius:var(--r-md);background:linear-gradient(90deg,#f0f2f8 25%,#e5e7ef 50%,#f0f2f8 75%) 0 0/200% 100%;animation:1.4s ease-in-out infinite pulse}.tabs{border-bottom:2px solid var(--c-border);gap:0;display:flex}.tab{font-size:var(--t-base);color:var(--c-text-secondary);cursor:pointer;border-radius:var(--r-sm) var(--r-sm) 0 0;transition:color var(--duration);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:9px 18px;font-weight:500;display:inline-flex}.tab:hover{color:var(--c-text);background:#00000005}.tab--active{color:var(--c-primary);border-bottom-color:var(--c-primary);font-weight:600}.table-wrap{border-radius:var(--r-lg);border:1px solid var(--c-border);background:var(--c-surface);overflow-x:auto}.table-toolbar{color:var(--c-text-secondary);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;font-size:.875rem;display:flex}.table-toolbar>.btn{margin-left:auto}.table-count{color:var(--c-text-2);white-space:nowrap;font-size:.82rem}.table-search{align-items:center;display:flex;position:relative}.table-search-icon{color:var(--c-text-2);pointer-events:none;position:absolute;left:10px}.table-search-input{border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-bg);width:240px;color:var(--c-text);outline:none;padding:6px 12px 6px 32px;font-size:.85rem;transition:border-color .15s}.table-search-input:focus{border-color:var(--c-primary)}.table-empty{text-align:center;color:var(--c-text-2);padding:32px 16px;font-size:.9rem;font-style:italic}.data-table{border-collapse:collapse;width:100%;font-size:var(--t-base)}.data-table th{text-align:left;color:var(--c-primary);border-bottom:1px solid var(--c-border);white-space:nowrap;font-weight:600;font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.08em;background:#f4f6fa;padding:11px 16px}.data-table td{border-bottom:1px solid var(--c-border-light);color:var(--c-text);vertical-align:middle;font-size:var(--t-base);padding:12px 16px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--duration)}.data-table tbody tr:hover td{background:#fafbff}.data-table .table-actions{justify-content:flex-end;gap:4px;display:flex}.row--inactive td{color:var(--c-text-muted)}.row--inactive td:first-child{-webkit-text-decoration:line-through #d1d5db;text-decoration:line-through #d1d5db}.confirm-delete-body{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:8px 0 4px;display:flex}.confirm-delete-icon{color:#d97706}.confirm-delete-body p{font-size:var(--t-base);margin:0}.confirm-delete-note{font-size:var(--t-sm);color:var(--c-text-muted);max-width:320px}.role-chip{border-radius:var(--r-sm);color:#3730a3;letter-spacing:.02em;background:#e0e7ff;padding:2px 9px;font-size:.73rem;font-weight:600;display:inline-block}.status-dot{align-items:center;gap:6px;font-size:.8rem;font-weight:500;display:inline-flex}.status-dot:before{content:"";border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.status-dot--active{color:#065f46}.status-dot--active:before{background:var(--c-success);box-shadow:0 0 0 2px #d1fae5}.status-dot--inactive{color:var(--c-text-muted)}.status-dot--inactive:before{background:#d1d5db}.empty-state{color:var(--c-text-muted);text-align:center;padding:20px;font-size:.875rem}.empty-state-block{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);text-align:center;color:var(--c-text-muted);padding:56px 40px}.empty-state-block p{font-size:.875rem;line-height:1.6}.drawer-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a0f2373;animation:.2s fadeIn;position:fixed;inset:0}.drawer{background:var(--c-surface);z-index:101;width:500px;max-width:95vw;animation:slideInRight .25s var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;box-shadow:-12px 0 48px #00000024}.drawer-header{border-bottom:1px solid var(--c-border-light);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.drawer-title{margin-bottom:3px;font-size:1.05rem;font-weight:700}.drawer-subtitle{color:var(--c-text-secondary);font-size:.85rem}.drawer-meta{border-bottom:1px solid var(--c-border-light);background:#f9fafb;flex-shrink:0;align-items:center;gap:12px;padding:12px 20px;display:flex}.drawer-total{color:var(--c-text);font-size:.9rem;font-weight:600}.drawer-rejection{border-radius:var(--r-md);color:#7f1d1d;background:#fef2f2;border:1px solid #fecaca;flex-shrink:0;margin:12px 20px 0;padding:10px 14px;font-size:.85rem}.drawer-activities{flex-direction:column;flex:1;gap:20px;padding:16px 20px;display:flex;overflow-y:auto}.drawer-day{flex-direction:column;gap:6px;display:flex}.drawer-day-title{text-transform:capitalize;color:var(--c-text-secondary);border-bottom:1px solid var(--c-border-light);padding-bottom:4px;font-size:.78rem;font-weight:700}.drawer-activity{border:1px solid var(--c-border-light);border-radius:var(--r-md);transition:background var(--duration);background:#fafbff;grid-template-columns:110px 1fr auto;align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;display:grid}.drawer-activity:hover{background:var(--c-primary-light)}.drawer-activity-type{color:#4f46e5;font-size:.8rem;font-weight:600}.drawer-activity-desc{color:var(--c-text)}.drawer-activity-time{color:var(--c-text-secondary);white-space:nowrap;font-size:.82rem}.drawer-activity-time strong{color:var(--c-text)}.drawer-actions{border-top:1px solid var(--c-border-light);background:#fafbff;flex-shrink:0;gap:10px;padding:16px 20px;display:flex}.drawer-loading{justify-content:center;padding:60px;display:flex}.calendar-shell{flex-direction:column;height:calc(100vh - 52px);display:flex;overflow:hidden}.calendar-header{background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.calendar-nav{align-items:center;gap:6px;display:flex}.calendar-nav-btn{position:relative}.week-status-dot{border:1.5px solid var(--c-surface);border-radius:50%;width:7px;height:7px;position:absolute;bottom:2px;right:2px}.calendar-week-label{color:var(--c-text);justify-content:center;align-items:center;gap:7px;min-width:210px;font-size:.9rem;font-weight:600;display:flex}.calendar-summary{align-items:center;gap:10px;display:flex}.calendar-total{color:var(--c-text-secondary);background:var(--c-bg);border-radius:var(--r-full);border:1px solid var(--c-border);padding:4px 10px;font-size:.85rem;font-weight:500}.week-progress{background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:12px;padding:6px 16px;display:flex}.week-progress-track{background:var(--c-border);border-radius:99px;flex:1;height:6px;overflow:hidden}.week-progress-fill{border-radius:99px;height:100%;transition:width .4s}.week-progress-fill--default{background:var(--c-primary)}.week-progress-fill--good{background:#22c55e}.week-progress-fill--over{background:#ef4444}.week-progress-fill--approved{background:#16a34a}.week-progress-fill--rejected{background:#dc2626}.week-progress-label{white-space:nowrap;color:var(--c-text);font-size:.8rem}.week-progress-norm,.week-progress-pct{color:var(--c-text-2)}.calendar-loading{flex:1;justify-content:center;align-items:center;display:flex}.calendar-body{flex:1;display:flex;overflow:hidden}.calendar-grid{border-left:1px solid var(--c-border);flex:1;grid-template-columns:36px repeat(7,1fr);display:grid;overflow:hidden auto}.calendar-alert-banner{color:#9a3412;font-size:var(--t-sm);background:#fff7ed;border-bottom:1px solid #fed7aa;flex-shrink:0;align-items:center;gap:10px;padding:9px 16px;display:flex}.calendar-alert-icon{flex-shrink:0;font-size:1rem}.calendar-alert-link{color:inherit;cursor:pointer;background:0 0;border:none;margin-left:10px;padding:0;font-weight:600;text-decoration:underline}.calendar-alert-link:hover{opacity:.75}.calendar-locked-banner{font-size:var(--t-sm);letter-spacing:.01em;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-weight:600;display:flex}.calendar-reject-reason{font-style:italic;font-weight:400}.calendar-locked-banner--submitted{color:#92400e;background:#fffbeb;border-bottom:1px solid #fde68a}.calendar-locked-banner--approved{color:#166534;background:#f0fdf4;border-bottom:1px solid #bbf7d0}.calendar-locked-banner--rejected{color:#991b1b;background:#fef2f2;border-bottom:1px solid #fecaca}.calendar-body--locked .calendar-grid{opacity:.6;pointer-events:none}.type-panel{background:var(--c-surface);border-right:1px solid var(--c-border);flex-direction:column;flex-shrink:0;gap:12px;width:164px;padding:14px 10px;display:flex;overflow-y:auto}.type-panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-muted);font-size:.7rem;font-weight:700}.type-panel-hint{color:#c4c9d6;font-size:.73rem;line-height:1.45}.type-panel-list{flex-direction:column;gap:5px;display:flex}.activity-type-item{border-radius:var(--r-md);color:var(--c-text);background:var(--c-bg);cursor:grab;border:1px solid var(--c-border);transition:box-shadow var(--duration), border-color var(--duration), transform var(--duration);-webkit-user-select:none;user-select:none;align-items:center;gap:7px;padding:8px 10px;font-size:.8rem;font-weight:500;display:flex}.activity-type-item:hover{box-shadow:var(--shadow-md);border-color:#c4c9d6}.activity-type-item:active{cursor:grabbing;transform:scale(.97)}.drag-handle{color:#d1d5db;flex-shrink:0}.day-column{border-right:1px solid var(--c-border-light);background:var(--c-surface);transition:background var(--duration);flex-direction:column;display:flex;position:relative;overflow:hidden}.day-column:last-child{border-right:none}.day-column--over{background:var(--c-primary-light);box-shadow:inset 0 0 0 2px #bfdbfe}.day-column--sunday{background:repeating-linear-gradient(-45deg,#fafafa,#fafafa 6px,#f5f6fa 6px 12px)}.day-column--today .day-column-header{border-bottom-color:#c7d7fd}.day-num--today{background:var(--c-primary);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;color:#fff!important;font-size:.9rem!important;display:inline-flex!important}.day-column-header{border-bottom:1px solid var(--c-border-light);z-index:5;background:var(--c-surface);flex-direction:column;flex-shrink:0;align-items:center;gap:3px;min-height:58px;padding:10px 8px 8px;display:flex;position:sticky;top:0}.day-column--today .day-column-header{background:#f0f5ff}.day-name{text-transform:uppercase;letter-spacing:.07em;color:var(--c-text-muted);font-size:.72rem;font-weight:700}.day-num{color:var(--c-text);font-size:.95rem;font-weight:700;line-height:1}.day-column-body{flex-shrink:0;height:780px;position:relative;overflow:hidden}.day-drop-hint{text-align:center;color:#d1d5db;pointer-events:none;white-space:nowrap;font-size:.72rem;line-height:1.5;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.day-column-footer{border-top:1px solid var(--c-border-light);z-index:4;background:#fafbff;flex-shrink:0;padding:5px 8px 6px;position:sticky;bottom:0}.day-progress-bar{background:var(--c-border);border-radius:var(--r-full);height:3px;margin-bottom:4px;overflow:hidden}.day-progress-fill{background:var(--c-primary);border-radius:var(--r-full);height:100%;transition:width .35s var(--ease-out)}.day-progress-fill--over{background:var(--c-danger)}.day-total{color:var(--c-text-muted);text-align:right;font-variant-numeric:tabular-nums;font-size:.72rem;display:block}.day-total--over{color:var(--c-danger);font-weight:700}.time-ruler{border-right:1px solid var(--c-border-light);background:var(--c-surface);flex-direction:column;flex-shrink:0;display:flex}.time-ruler-header{border-bottom:1px solid var(--c-border-light);z-index:6;background:var(--c-surface);flex-shrink:0;min-height:58px;position:sticky;top:0}.time-ruler-body{flex-shrink:0;height:780px;position:relative}.time-ruler-label{color:var(--c-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:.6rem;line-height:1;position:absolute;right:3px;transform:translateY(-50%)}.day-hour-line{border-top:1px solid var(--c-border-light);pointer-events:none;z-index:0;position:absolute;left:0;right:0}.day-halfhour-line{pointer-events:none;z-index:0;border-top:1px dashed #eceef4;position:absolute;left:0;right:0}.activity-block{border-radius:var(--r-sm);cursor:pointer;transition:box-shadow var(--duration), transform .1s;box-sizing:border-box;z-index:2;padding:4px 6px;position:absolute;left:3px;right:3px;overflow:hidden}.activity-block:hover{transform:translateY(-1px);box-shadow:0 3px 10px #0000001f}.activity-block:focus-visible{outline:2px solid var(--c-primary);outline-offset:1px}.activity-block-header{justify-content:space-between;align-items:flex-start;gap:4px;margin-bottom:2px;display:flex}.activity-block-type{font-size:.72rem;font-weight:700;line-height:1.2}.activity-block-delete{cursor:pointer;color:#00000040;opacity:0;transition:opacity var(--duration), color var(--duration);background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:0;line-height:1;display:flex}.activity-block:hover .activity-block-delete{opacity:1}.activity-block-delete:hover{color:var(--c-danger)}.activity-block-label{color:#000000b3;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.75rem;overflow:hidden}.activity-block-time{color:#00000073;font-variant-numeric:tabular-nums;justify-content:space-between;font-size:.72rem;display:flex}.activity-block-duration{font-weight:700}.drag-overlay-pill{background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--r-md);pointer-events:none;padding:8px 14px;font-size:.8rem;font-weight:600;transform:rotate(2deg);box-shadow:0 10px 30px #0000002e,0 2px 6px #00000014}.setting-desc{color:var(--c-text-muted);margin-top:3px;font-size:.78rem}input,select,textarea{color:var(--c-text);font-family:inherit;font-size:.9rem}.rp-page{flex-direction:column;flex:1;gap:16px;min-width:0;padding:28px 28px 40px;display:flex;overflow-y:auto}.rp-nav-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.rp-nav-card-left{align-items:center;gap:14px;display:flex}.rp-nav-icon-box{border-radius:var(--r-md);background:var(--c-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.rp-nav-info{flex-direction:column;gap:5px;display:flex}.rp-nav-title{font-size:var(--t-sm);color:var(--c-text);letter-spacing:.1em;text-transform:uppercase;margin:0;font-weight:800;line-height:1}.rp-nav-links{flex-wrap:wrap;align-items:center;gap:2px;display:flex}.rp-nav-link{font-size:var(--t-sm);color:var(--c-primary);cursor:pointer;border-radius:var(--r-sm);transition:color var(--duration), background var(--duration);background:0 0;border:none;padding:2px 4px;font-weight:500;line-height:1.4}.rp-nav-link:hover{color:var(--c-primary-dark);background:var(--c-primary-light)}.rp-nav-link--active{color:var(--c-primary);text-underline-offset:3px;font-weight:700;text-decoration:underline}.rp-nav-dot{color:var(--c-text-muted);font-size:var(--t-sm);-webkit-user-select:none;user-select:none;padding:0 1px}.rp-nav-sep{background:var(--c-border);vertical-align:middle;width:1px;height:14px;margin:0 6px;display:inline-block}.rp-nav-card-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.rp-subfilter{align-items:center;gap:10px;display:flex}.rp-page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.rp-page-title-wrap{align-items:center;gap:10px;display:flex}.rp-page-title-icon{color:var(--c-primary)}.rp-page-title{font-size:var(--t-xl);color:var(--c-primary);letter-spacing:-.02em;margin:0;font-weight:700}.rp-page-header-actions{align-items:center;gap:10px;display:flex}.rp-period-tabs{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-md);gap:2px;padding:3px;display:flex}.rp-period-tab{border-radius:calc(var(--r-md) - 2px);font-size:var(--t-sm);color:var(--c-text-secondary);cursor:pointer;transition:all var(--duration);white-space:nowrap;background:0 0;border:none;padding:6px 16px;font-weight:500}.rp-period-tab--active{background:var(--c-surface);color:var(--c-primary);font-weight:700;box-shadow:0 1px 4px #2643701f}.rp-period-tab:hover:not(.rp-period-tab--active){color:var(--c-text);background:#ffffffb3}.rp-export-btn{border-radius:var(--r-md);font-size:var(--t-sm);background:var(--c-primary);color:#fff;cursor:pointer;transition:background var(--duration);white-space:nowrap;border:none;align-items:center;gap:7px;padding:7px 16px;font-weight:600;display:inline-flex}.rp-export-btn:hover:not(:disabled){background:var(--c-primary-dark)}.rp-export-btn:disabled{opacity:.45;cursor:not-allowed}.rp-filters{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 18px;display:flex}.rp-scope-tabs{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-md);gap:2px;padding:3px;display:flex}.rp-scope-tab{border-radius:calc(var(--r-md) - 2px);font-size:var(--t-sm);color:var(--c-text-secondary);cursor:pointer;transition:all var(--duration);white-space:nowrap;background:0 0;border:none;padding:5px 14px;font-weight:500}.rp-scope-tab--active{background:var(--c-surface);color:var(--c-primary);font-weight:700;box-shadow:0 1px 4px #2643701f}.rp-scope-tab:hover:not(.rp-scope-tab--active){color:var(--c-text);background:#ffffffb3}.rp-filters-sep{background:var(--c-border);flex-shrink:0;width:1px;height:28px;margin:0 4px}.rp-date-nav{align-items:center;gap:4px;display:flex}.rp-date-btn{border:1px solid var(--c-border);border-radius:var(--r-sm);cursor:pointer;color:var(--c-text-secondary);transition:all var(--duration);background:0 0;align-items:center;padding:4px 6px;display:flex}.rp-date-btn:hover{border-color:var(--c-primary);color:var(--c-primary)}.rp-date-label{font-size:var(--t-sm);color:var(--c-text);text-align:center;min-width:180px;padding:0 4px;font-weight:600}.rp-controls{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 16px;display:flex}.rp-body{flex-direction:column;gap:16px;display:flex}.rp-stats-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=860px){.rp-stats-row{grid-template-columns:1fr}}.rp-stat-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.rp-stat-card-header{border-bottom:1px solid var(--c-border-light);justify-content:space-between;align-items:center;padding:16px 20px 14px;display:flex}.rp-stat-card-title{font-size:var(--t-base);color:var(--c-primary);letter-spacing:-.01em;margin:0;font-weight:700}.rp-stat-card-count{font-size:var(--t-xs);color:var(--c-text-muted);background:var(--c-bg);border-radius:var(--r-full);padding:2px 8px;font-weight:600}.rp-stat-list{flex-direction:column;display:flex}.rp-stat-row{border-bottom:1px solid var(--c-border-light);transition:background var(--duration);justify-content:space-between;align-items:center;gap:12px;padding:13px 20px;display:flex}.rp-stat-row:hover{background:#f9fafc}.rp-stat-row--last{border-bottom:none}.rp-stat-row-left{flex-shrink:0;align-items:center;gap:10px;display:flex}.rp-stat-icon{border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.rp-stat-icon--blue{color:#2563eb;background:#eff4ff}.rp-stat-icon--green{color:#16a34a;background:#f0fdf4}.rp-stat-icon--orange{color:#d97706;background:#fffbeb}.rp-stat-icon--purple{color:#7c3aed;background:#faf5ff}.rp-stat-icon--teal{color:#0d9488;background:#f0fdfa}.rp-stat-label{font-size:var(--t-sm);color:var(--c-text-secondary);font-weight:500}.rp-stat-row-right{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.rp-stat-value{font-size:var(--t-lg);color:var(--c-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-weight:800;line-height:1.2}.rp-stat-value--sm{font-size:var(--t-base)}.rp-stat-value--green{color:#16a34a}.rp-stat-value--red{color:#dc2626}.rp-stat-sub{color:var(--c-text-muted);text-align:right;font-size:.7rem}.rp-breakdown-list{flex-direction:column;gap:0;padding:8px 0;display:flex}.rp-breakdown-row{border-bottom:1px solid var(--c-border-light);transition:background var(--duration);grid-template-columns:170px 1fr 90px;align-items:center;gap:12px;padding:10px 20px;display:grid}.rp-breakdown-row:last-child{border-bottom:none}.rp-breakdown-row:hover{background:#f9fafc}.rp-breakdown-meta{align-items:center;gap:8px;min-width:0;display:flex}.rp-breakdown-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.rp-breakdown-name{font-size:var(--t-sm);color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.rp-breakdown-bar-wrap{background:var(--c-bg);border-radius:var(--r-full);height:7px;overflow:hidden}.rp-breakdown-bar-fill{border-radius:var(--r-full);height:100%;transition:width .5s var(--ease-out);opacity:.85}.rp-breakdown-values{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.rp-breakdown-pct{font-size:var(--t-sm);color:var(--c-text);font-variant-numeric:tabular-nums;font-weight:700}.rp-breakdown-h{color:var(--c-text-muted);font-variant-numeric:tabular-nums;font-size:.7rem}.rp-breakdown-empty{text-align:center;font-size:var(--t-sm);color:var(--c-text-muted);padding:32px 20px}.rp-view-tabs{border-bottom:1px solid var(--c-border-light);gap:4px;margin-bottom:16px;padding:0 2px 10px;display:flex}.rp-view-tab{border-radius:var(--r-full);color:var(--c-text-muted);cursor:pointer;transition:all var(--duration);background:0 0;border:1px solid #0000;padding:6px 18px;font-size:.83rem;font-weight:500}.rp-view-tab:hover{color:var(--c-text);background:var(--c-bg)}.rp-view-tab--active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.rp-section{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.rp-section-header{border-bottom:1px solid var(--c-border-light);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.rp-section-title{font-size:var(--t-base);color:var(--c-primary);letter-spacing:-.01em;margin:0;font-weight:700}.rp-empty{text-align:center;background:var(--c-surface);border:1px dashed var(--c-border);border-radius:var(--r-lg);flex-direction:column;align-items:center;gap:12px;padding:80px 20px;display:flex}.rp-empty-icon{opacity:.3;color:var(--c-primary)}.rp-empty-title{font-size:var(--t-md);color:var(--c-text-secondary);margin:0;font-weight:700}.rp-empty-desc{font-size:var(--t-sm);color:var(--c-text-muted);max-width:340px;margin:0;line-height:1.6}.clist{flex-direction:column;gap:0;display:flex}.clist-header{margin-bottom:16px}.clist-title-row{align-items:center;gap:10px;margin-bottom:4px;display:flex}.clist-title{color:var(--c-text);margin:0;font-size:1.05rem;font-weight:700}.clist-count{background:var(--c-primary);color:#fff;border-radius:99px;justify-content:center;align-items:center;min-width:24px;height:22px;padding:0 7px;font-size:.72rem;font-weight:700;display:inline-flex}.clist-desc{font-size:var(--t-sm);color:var(--c-text-muted);margin:0}.clist-search-wrap{max-width:400px;margin-bottom:16px;position:relative}.clist-search-icon{color:var(--c-text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.clist-search{border:1.5px solid var(--c-border);border-radius:var(--r-md);width:100%;font-size:var(--t-base);color:var(--c-text);background:var(--c-surface);box-sizing:border-box;transition:border-color var(--duration), box-shadow var(--duration);outline:none;padding:9px 12px 9px 36px;font-family:inherit}.clist-search:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-ring)}.clist-table-wrap{border:1px solid var(--c-border);border-radius:var(--r-lg);overflow-x:auto}.clist-table{border-collapse:collapse;table-layout:auto;width:100%}.clist-th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);white-space:nowrap;background:#f4f6fb;padding:11px 16px;font-size:.72rem;font-weight:700}.clist-th--sortable{cursor:pointer;-webkit-user-select:none;user-select:none;display:table-cell}.clist-th--sortable:hover{color:var(--c-primary)}.clist-sort-neutral{color:var(--c-text-muted);opacity:.5;vertical-align:middle;margin-left:4px}.clist-sort-active{color:var(--c-primary);vertical-align:middle;margin-left:4px}.clist-row{cursor:pointer;transition:background var(--duration)}.clist-row:hover{background:#f0f4ff}.clist-row:hover .clist-fullname{color:var(--c-primary)}.clist-row:not(:last-child) td{border-bottom:1px solid var(--c-border)}.clist-td{font-size:var(--t-base);color:var(--c-text-secondary);vertical-align:middle;padding:13px 16px}.clist-td--name{color:var(--c-text)}.clist-td--email{color:var(--c-text-muted);font-size:var(--t-sm)}.clist-name-cell{align-items:center;gap:10px;display:flex}.clist-avatar{color:#fff;letter-spacing:.04em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.78rem;font-weight:700;display:flex}.clist-fullname{font-weight:600;font-size:var(--t-base);color:var(--c-text);transition:color var(--duration)}.clist-status{font-size:var(--t-sm);color:#16a34a;align-items:center;gap:5px;font-weight:500;display:inline-flex}.clist-status--inactive{color:var(--c-text-muted)}.clist-status-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:7px;height:7px}.clist-loading{justify-content:center;padding:48px 0;display:flex}.clist-empty-row{text-align:center;color:var(--c-text-muted);font-size:var(--t-sm);padding:32px 16px}.rp-user-header{margin-bottom:4px}.rp-breadcrumb{align-items:center;gap:4px;margin-bottom:6px;display:flex}.rp-breadcrumb-link{font-size:var(--t-sm);color:var(--c-primary);cursor:pointer;transition:opacity var(--duration);background:0 0;border:none;padding:0;font-weight:500}.rp-breadcrumb-link:hover{opacity:.8;text-decoration:underline}.rp-breadcrumb-sep{color:var(--c-text-muted);flex-shrink:0}.rp-breadcrumb-current{font-size:var(--t-sm);color:var(--c-text-muted)}.rp-user-title{color:var(--c-text);letter-spacing:-.01em;margin:0;font-size:1.35rem;font-weight:800}.kpi-value{font-size:var(--t-kpi);color:var(--c-primary);white-space:nowrap;text-overflow:ellipsis;font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-weight:800;line-height:1.1;overflow:hidden}.report-table-wrap{background:var(--c-surface);overflow-x:auto}.report-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:.82rem}.report-thead-title .report-title-cell{color:#fff;letter-spacing:.08em;text-align:center;text-transform:uppercase;background:#12172a;padding:10px 14px;font-size:.8rem;font-weight:700}.report-thead-week th{color:#c6cfec;background:#1e2a47;padding:6px 14px;font-size:.78rem}.report-week-label-cell{text-align:left;font-weight:600}.report-week-range-cell{text-align:center}.report-thead-cols{border-bottom:2px solid var(--c-border)}.report-th{color:var(--c-text-secondary);text-align:center;border-right:1px solid var(--c-border-light);background:#f8f9fc;padding:8px 10px;font-size:.75rem;font-weight:600}.report-th--num{width:36px}.report-th--name{text-align:left;min-width:140px}.report-th--day{width:58px}.report-th--total{background:#f0f2f8;width:64px}.report-th--taux{width:120px}.report-th-dayname{color:var(--c-text-muted);font-weight:500;display:block}.report-th-daynum{color:var(--c-text);margin-top:1px;font-size:.88rem;font-weight:700;display:block}.report-th--sunday{background:#f1f2f5}.report-cell--sunday{background:#f5f6f9!important}.report-th--today{color:var(--c-primary)!important;background:#eff4ff!important}.report-cell--today{background:#f5f8ff!important}.report-cell{border-right:1px solid var(--c-border-light);border-bottom:1px solid var(--c-border-light);text-align:center;font-variant-numeric:tabular-nums;color:var(--c-text);padding:7px 10px}.report-cell--num{color:var(--c-text-muted);font-size:.75rem}.report-cell--name{text-align:left;font-weight:500}.report-cell--desc{color:var(--c-text-secondary);font-size:.82rem;font-style:italic;font-weight:400}.report-cell--hours{font-size:.8rem}.report-cell--zero{color:var(--c-text-muted)}.report-cell--total{color:var(--c-text);background:#f5f7fb;font-weight:700}.report-row--even .report-cell{background:#fafbfd}.report-row--even .report-cell--total{background:#f0f2f8}.report-row--even .report-cell--sunday{background:#f2f3f7!important}.report-cell--taux{min-width:110px;padding:5px 10px}.report-taux-cell{align-items:center;gap:7px;display:flex}.report-taux-bar-wrap{border-radius:var(--r-full);background:#e9eaf0;flex:1;height:6px;overflow:hidden}.report-taux-bar-fill{background:var(--c-primary);border-radius:var(--r-full);height:100%;transition:width .5s var(--ease-out)}.report-taux-label{color:var(--c-text-secondary);white-space:nowrap;text-align:right;min-width:38px;font-size:.72rem;font-weight:600}.report-tfoot-row{border-top:2px solid #12172a}.report-tfoot-label{color:#fff;text-align:left;background:#12172a;padding:8px 12px;font-size:.75rem;font-weight:600}.report-tfoot-cell{color:#c6cfec;text-align:center;font-variant-numeric:tabular-nums;background:#1e2a47;border-right:1px solid #ffffff14;padding:8px 10px;font-size:.78rem;font-weight:600}.report-tfoot-total{color:#fff;background:#284fd6;font-weight:800}.report-empty{text-align:center;color:var(--c-text-muted);padding:32px;font-size:.85rem}.chart-bar{transition:opacity var(--duration)}.chart-bar:hover{opacity:1!important}.monthly-report-wrap{flex-direction:column;gap:8px;display:flex}.monthly-report-header{justify-content:space-between;align-items:baseline;gap:12px;padding:4px 0;display:flex}.monthly-report-title{color:var(--c-text);text-transform:capitalize;font-size:1rem;font-weight:700}.monthly-report-summary{color:var(--c-text-secondary);flex-wrap:wrap;align-items:center;gap:8px;font-size:.82rem;display:flex}.monthly-report-total{color:var(--c-primary);font-weight:700}.monthly-report-sep{color:var(--c-border)}.monthly-report-norme{color:var(--c-text-muted)}.monthly-report-ecart{font-weight:600}.monthly-ecart--pos{color:#22a663}.monthly-ecart--neg{color:#d94040}.month-week-block{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.month-week-header{cursor:pointer;text-align:left;width:100%;transition:background var(--duration);color:var(--c-text);background:0 0;border:none;align-items:center;gap:10px;padding:12px 16px;display:flex}.month-week-header:hover{background:var(--c-bg)}.month-week-label{flex:1;font-size:.875rem;font-weight:600}.month-week-meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.month-week-total{color:var(--c-primary);font-size:.82rem;font-weight:700}.month-week-norme{color:var(--c-text-muted);font-size:.78rem}.month-week-ecart{font-size:.78rem;font-weight:600}.month-week-ecart--pos{color:#22a663}.month-week-ecart--neg{color:#d94040}.month-taux-badge{border-radius:var(--r-full);padding:2px 8px;font-size:.75rem;font-weight:700}.month-taux--ok{color:#1a7d4a;background:#d4f0e2}.month-taux--mid{color:#8a6400;background:#fff3cc}.month-taux--low{color:#b82e2e;background:#fde8e8}.month-week-chevron{color:var(--c-text-muted);transition:transform var(--duration) var(--ease-out);flex-shrink:0}.month-week-chevron--open{transform:rotate(180deg)}.month-week-body{border-top:1px solid var(--c-border-light);animation:.15s fadeIn}.month-week-body .report-table-wrap{box-shadow:none;border:none;border-radius:0}.dept-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.dept-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration), border-color var(--duration);flex-direction:column;gap:8px;padding:16px 18px;display:flex;position:relative}.dept-card:hover{box-shadow:var(--shadow-md)}.dept-card--inactive{opacity:.6}.dept-card-header{justify-content:space-between;align-items:center;display:flex}.dept-code{letter-spacing:.08em;text-transform:uppercase;background:var(--c-primary-light);color:var(--c-primary);border-radius:var(--r-full);padding:2px 8px;font-size:.7rem;font-weight:700}.dept-card-actions{opacity:0;transition:opacity var(--duration);gap:4px;display:flex}.dept-card:hover .dept-card-actions{opacity:1}.dept-name{color:var(--c-text);margin:0;font-size:.95rem;font-weight:700}.dept-desc{color:var(--c-text-secondary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.4;display:-webkit-box;overflow:hidden}.dept-meta{border-top:1px solid var(--c-border-light);flex-direction:column;gap:4px;margin-top:4px;padding-top:10px;display:flex}.dept-meta-item{color:var(--c-text-secondary);align-items:center;gap:5px;font-size:.775rem;display:flex}.dept-manager{font-weight:500}.dept-manager--none{color:var(--c-text-muted);font-style:italic}.dept-inactive-badge{text-transform:uppercase;letter-spacing:.05em;color:#92400e;border-radius:var(--r-full);background:#fef3c7;padding:2px 7px;font-size:.68rem;font-weight:600;position:absolute;top:12px;right:12px}.confirm-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;background:#0a0f2380;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-box{background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);width:90%;max-width:380px;animation:scaleIn .18s var(--ease-out);padding:28px 28px 22px}.confirm-title{color:var(--c-text);margin:0 0 8px;font-size:1rem;font-weight:700}.confirm-body{color:var(--c-text-secondary);margin:0 0 22px;font-size:.875rem;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:10px;display:flex}.form-checkbox-label{cursor:pointer;align-items:center;gap:8px;font-size:.875rem;flex-direction:row!important;display:flex!important}.form-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--c-primary);flex-shrink:0}.admin-section{flex-direction:column;gap:16px;display:flex}.admin-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.admin-section-title-wrap{align-items:center;gap:8px;display:flex}.admin-section-icon{color:var(--c-primary)}.admin-section-title{font-size:var(--t-md);color:var(--c-primary);letter-spacing:-.01em;font-weight:700}.admin-section-count{background:var(--c-border-light);color:var(--c-text-secondary);border-radius:var(--r-full);padding:1px 8px;font-size:.75rem;font-weight:600}.admin-empty{color:var(--c-text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 20px;display:flex}.notif-bell-wrap{position:relative}.notif-bell-btn{cursor:pointer;border-radius:var(--r-md);color:var(--c-text-secondary);transition:color var(--duration), background var(--duration);background:0 0;border:none;align-items:center;padding:6px;display:flex;position:relative}.notif-bell-btn:hover{color:var(--c-primary);background:var(--c-primary-light)}.notif-bell-badge{color:#fff;pointer-events:none;background:#dc2626;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.6rem;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notif-overlay{z-index:1000;position:fixed;inset:0}.notif-panel{z-index:1001;border:1px solid var(--c-border-light);background:#fff;border-radius:12px;flex-direction:column;width:360px;max-height:480px;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 40px #00000026,0 2px 8px #00000014}.notif-panel-header{border-bottom:1px solid var(--c-border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.notif-panel-title-wrap{color:var(--c-primary);align-items:center;gap:8px;display:flex}.notif-panel-title{font-size:var(--t-sm);color:var(--c-primary);letter-spacing:-.01em;font-weight:700}.notif-panel-badge{color:#fff;border-radius:var(--r-full);background:#dc2626;padding:1px 6px;font-size:.65rem;font-weight:700}.notif-panel-actions{align-items:center;gap:4px;display:flex}.notif-mark-all{cursor:pointer;border-radius:var(--r-sm);color:var(--c-text-muted);transition:color var(--duration), background var(--duration);background:0 0;border:none;align-items:center;padding:5px;display:flex}.notif-mark-all:hover{color:var(--c-primary);background:var(--c-primary-light)}.notif-clear-read{cursor:pointer;border-radius:var(--r-sm);color:var(--c-text-muted);transition:color var(--duration), background var(--duration);background:0 0;border:none;align-items:center;padding:5px;display:flex}.notif-clear-read:hover{color:#dc2626;background:#fef2f2}.notif-clear-read:disabled{opacity:.4;cursor:not-allowed}.notif-close-btn{cursor:pointer;border-radius:var(--r-sm);color:var(--c-text-muted);transition:color var(--duration);background:0 0;border:none;align-items:center;padding:5px;display:flex}.notif-close-btn:hover{color:var(--c-text)}.notif-list{flex:1;overflow-y:auto}.notif-empty{color:var(--c-text-muted);font-size:var(--t-sm);flex-direction:column;align-items:center;gap:10px;padding:40px 20px;display:flex}.notif-empty-icon{opacity:.35}.notif-item{border-bottom:1px solid var(--c-border-light);transition:background var(--duration);align-items:flex-start;gap:10px;padding:12px 16px;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#f8fafc}.notif-item--unread{background:#f0f5ff}.notif-item--unread:hover{background:#e8f0fe}.notif-item-icon{background:currentColor;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:1px;display:flex}.notif-item-icon svg{color:#fff}.notif-item-body{flex:1;min-width:0}.notif-item-title{font-size:var(--t-sm);color:var(--c-text);margin:0 0 3px;font-weight:600;line-height:1.4}.notif-item-desc{color:var(--c-text-secondary);white-space:nowrap;text-overflow:ellipsis;margin:0 0 4px;font-size:.78rem;line-height:1.5;overflow:hidden}.notif-item-time{color:var(--c-text-muted);margin:0;font-size:.7rem}.notif-item-actions{flex-shrink:0;align-items:center;display:flex}.notif-item-read-btn,.notif-item-delete-btn{border:1px solid var(--c-border);cursor:pointer;border-radius:var(--r-sm);color:var(--c-text-muted);transition:color var(--duration), border-color var(--duration), background var(--duration);background:0 0;flex-shrink:0;align-items:center;padding:4px;display:flex}.notif-item-read-btn:hover{color:#16a34a;background:#f0fdf4;border-color:#bbf7d0}.notif-item-delete-btn{opacity:0;transition:opacity var(--duration), color var(--duration), border-color var(--duration), background var(--duration)}.notif-item:hover .notif-item-delete-btn{opacity:1}.notif-item-delete-btn:hover{color:#dc2626;opacity:1;background:#fef2f2;border-color:#fecaca}.notif-item-delete-btn:disabled{opacity:.3;cursor:not-allowed}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;width:calc(100vw - 40px);max-width:380px;display:flex;position:fixed;top:20px;right:20px}.toast{pointer-events:all;font-size:var(--t-sm);border:1px solid #0000;border-radius:10px;align-items:flex-start;gap:10px;padding:13px 14px;font-weight:500;line-height:1.45;animation:.22s cubic-bezier(.34,1.36,.64,1) both toast-in;display:flex;box-shadow:0 8px 28px #00000024,0 2px 8px #00000014}@keyframes toast-in{0%{opacity:0;transform:translate(24px)scale(.96)}to{opacity:1;transform:translate(0)scale(1)}}.toast--success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.toast--success .toast-icon{color:#16a34a;flex-shrink:0;margin-top:1px}.toast--error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toast--error .toast-icon{color:#dc2626;flex-shrink:0;margin-top:1px}.toast--warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.toast--warning .toast-icon{color:#d97706;flex-shrink:0;margin-top:1px}.toast--info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.toast--info .toast-icon{color:#2563eb;flex-shrink:0;margin-top:1px}.toast-body{flex-direction:column;flex:1;gap:2px;display:flex}.toast-title{font-weight:600;line-height:1.3}.toast-detail{font-size:var(--t-xs);opacity:.8;line-height:1.4}.toast-close{cursor:pointer;opacity:.5;color:inherit;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;margin-top:1px;padding:2px;transition:opacity .15s;display:flex}.toast-close:hover{opacity:1}.set-password-page{background:linear-gradient(145deg,#0f1624 0%,#1a2642 55%,#12263d 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.set-password-card{background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:0;width:100%;max-width:420px;padding:40px 36px 32px;display:flex;box-shadow:0 20px 60px #00000059}.set-password-brand{flex-direction:column;align-items:center;gap:2px;margin-bottom:24px;display:flex}.set-password-brand-name{letter-spacing:.18em;text-transform:uppercase;background:linear-gradient(120deg,#264370 0%,#2470a7 60%,#41abb4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-style:italic;font-weight:900}.set-password-brand-accent{color:inherit}.set-password-brand-sub{font-family:var(--font-mono);letter-spacing:.25em;text-transform:uppercase;color:var(--c-text-muted);font-size:.6rem}.set-password-icon-wrap{border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:16px;display:flex}.set-password-icon--key{background:var(--c-primary-light);color:var(--c-primary)}.set-password-icon--success{color:#22a861;background:#edfaf3}.set-password-icon--error{color:#dc2626;background:#fef2f2}.set-password-title{font-size:var(--t-lg);color:var(--c-primary);letter-spacing:-.02em;text-align:center;margin:0 0 8px;font-weight:700}.set-password-subtitle{font-size:var(--t-sm);color:var(--c-text-secondary);text-align:center;margin:0 0 24px;line-height:1.6}.set-password-card form{flex-direction:column;gap:16px;width:100%;display:flex}.set-password-submit{width:100%;margin-top:4px}.set-password-back-btn{width:100%;margin-top:8px}.set-password-back-link{cursor:pointer;color:var(--c-text-secondary);background:0 0;border:none;align-items:center;gap:4px;margin-top:16px;padding:0;font-size:.82rem;transition:color .15s;display:inline-flex}.set-password-back-link:hover{color:var(--c-teal)}.set-password-footer{letter-spacing:.12em;color:var(--c-text-muted);text-align:center;margin-top:28px;font-size:.68rem}.form-error-banner{width:100%;font-size:var(--t-sm);color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:4px;padding:10px 14px}.admin-empty-icon{opacity:.3}.sp-card{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.sp-status-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:4px;display:flex}.sp-status-icon--success{color:#22a861;background:#edfaf3}.sp-status-icon--error{color:#dc2626;background:#fef2f2}.sp-title{font-size:var(--t-xl);color:var(--c-text-primary);margin:0;font-weight:700}.sp-subtitle{font-size:var(--t-sm);color:var(--c-text-secondary);max-width:320px;margin:0;line-height:1.6}.sp-action-btn{margin-top:8px}.sp-header-icon{background:var(--c-primary-light);width:44px;height:44px;color:var(--c-primary);border-radius:12px;justify-content:center;align-items:center;margin:0 auto 4px;display:flex}.sp-strength{align-items:center;gap:10px;margin-top:-8px;display:flex}.sp-strength-bars{flex:1;gap:4px;display:flex}.sp-strength-bar{border-radius:2px;flex:1;height:4px;transition:background-color .2s}.sp-strength-label{text-align:right;min-width:44px;font-size:.72rem;font-weight:600;transition:color .2s}.team-overview{flex-direction:column;gap:20px;display:flex}.team-kpi-row{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.team-kpi-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:18px 20px;display:flex}.team-kpi-icon{border-radius:var(--r-md);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.team-kpi-icon--amber{color:#d97706;background:#fffbeb}.team-kpi-icon--blue{color:#2563eb;background:#eff6ff}.team-kpi-icon--green{color:#16a34a;background:#f0fdf4}.team-kpi-body{flex-direction:column;gap:2px;min-width:0;display:flex}.team-kpi-value{color:var(--c-primary);letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:1.8rem;font-weight:800;line-height:1.1}.team-kpi-label{font-size:var(--t-sm);color:var(--c-text-secondary);font-weight:500;line-height:1.3}.team-overview-section{flex-direction:column;gap:10px;display:flex}.team-overview-section-title{font-size:var(--t-base);color:var(--c-primary);align-items:center;gap:8px;margin:0;font-weight:700;display:flex}.team-overview-week-range{font-size:var(--t-sm);color:var(--c-text-muted);margin-left:4px;font-weight:400}.dashboard-role-banner{background:linear-gradient(90deg,#f0f4ff 0%,#f8f9ff 100%);border-bottom:1px solid #dce4f5;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 20px;display:flex}.dashboard-role-banner-info{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.dashboard-role-pill{background:var(--c-primary);color:#fff;font-size:var(--t-xs);white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-weight:600;display:inline-flex}.dashboard-role-hint{font-size:var(--t-sm);color:var(--c-text-secondary)}.dashboard-role-link{color:var(--c-primary);font-weight:600;text-decoration:underline}.dashboard-role-link:hover{color:var(--c-primary-dark,#1a3a6e)}.dashboard-pending-alert{color:#c2410c;font-size:var(--t-sm);white-space:nowrap;transition:background var(--duration);background:#fff7ed;border:1px solid #fed7aa;border-radius:20px;flex-shrink:0;align-items:center;gap:6px;padding:5px 12px;font-weight:600;text-decoration:none;display:inline-flex}.dashboard-pending-alert:hover{background:#ffedd5;text-decoration:none}.manager-scope-bar{font-size:var(--t-sm);color:var(--c-text-secondary);background:#f0f4ff;border-bottom:1px solid #dce4f5;align-items:center;gap:6px;padding:6px 16px;display:flex}.manager-scope-bar svg{color:var(--c-primary);flex-shrink:0}.manager-scope-bar strong{color:var(--c-primary);font-weight:600}.user-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;display:block}.user-avatar--initials{color:#fff;letter-spacing:.04em;background:linear-gradient(135deg,#264370 0%,#2470a7 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;line-height:1;display:flex}.sidebar-avatar{border:2px solid #fff3}.profile-page{flex-direction:column;gap:20px;max-width:760px;margin:0 auto;padding:28px 24px;display:flex}.profile-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.profile-card-header{border-bottom:1px solid var(--c-border);background:var(--c-bg);justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex}.profile-card-title{font-size:var(--t-sm);color:var(--c-text);align-items:center;gap:6px;margin:0;font-weight:600;display:flex}.profile-avatar-input{display:none}.profile-card-body{flex-direction:column;gap:24px;padding:24px 20px;display:flex}.profile-pw-form{flex-direction:column;gap:16px;max-width:400px;display:flex}.uf-layout{grid-template-columns:176px 1fr;align-items:start;gap:32px;padding:24px 20px;display:grid}.uf-avatar-col{flex-direction:column;align-items:center;gap:10px;display:flex}.uf-avatar-zone{border-radius:var(--r-lg);cursor:pointer;background:var(--c-primary-light);border:2px dashed var(--c-border);width:176px;height:176px;transition:border-color var(--duration), background var(--duration);-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:relative;overflow:hidden}.uf-avatar-zone:hover{border-color:var(--c-primary)}.uf-avatar-zone--static{cursor:default;border-style:solid}.uf-avatar-zone--static:hover{border-color:var(--c-border)}.uf-avatar-zone--loading{opacity:.6;pointer-events:none}.uf-avatar-img{object-fit:cover;width:100%;height:100%;display:block}.uf-avatar-initials{color:var(--c-primary);letter-spacing:-.02em;font-size:3.2rem;font-weight:800;line-height:1}.uf-avatar-cam-icon{color:var(--c-text-muted)}.uf-avatar-overlay{color:#fff;font-size:var(--t-sm);opacity:0;transition:opacity var(--duration);background:#2643708c;flex-direction:column;justify-content:center;align-items:center;gap:6px;font-weight:600;display:flex;position:absolute;inset:0}.uf-avatar-zone:not(.uf-avatar-zone--static):hover .uf-avatar-overlay,.uf-avatar-zone--loading .uf-avatar-overlay{opacity:1}.uf-avatar-hint{font-size:var(--t-xs);color:var(--c-text-muted);text-align:center;margin:0;line-height:1.4}.uf-fields-col{flex-direction:column;gap:14px;display:flex}.uf-fields-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.uf-footer{border-top:1px solid var(--c-border);align-items:center;gap:10px;padding:16px 20px;display:flex}.form-input--readonly{background:var(--c-bg);color:var(--c-text-secondary);cursor:default}.form-required{color:var(--c-danger);margin-left:1px}.form-optional{color:var(--c-text-3);font-size:var(--t-xs);margin-left:4px;font-weight:400}.uf-page{flex-direction:column;gap:20px;display:flex}.uf-page-header{align-items:center;gap:12px;display:flex}.uf-back-btn{border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--t-sm);color:var(--c-text-secondary);cursor:pointer;transition:border-color var(--duration), color var(--duration);background:0 0;align-items:center;gap:4px;padding:5px 10px;display:flex}.uf-back-btn:hover{border-color:var(--c-primary);color:var(--c-primary)}.uf-page-title{font-size:var(--t-md);color:var(--c-text);margin:0;font-weight:600}.mobile-view{background:var(--c-bg);flex-direction:column;height:100%;display:flex}.mobile-week-header{background:var(--c-surface);border-bottom:1px solid var(--c-border-light);flex-direction:column;gap:8px;padding:12px 16px 10px;display:flex}.mobile-week-nav{justify-content:space-between;align-items:center;gap:8px;display:flex}.mobile-nav-btn{position:relative}.mobile-week-label{font-size:var(--t-sm);color:var(--c-text);align-items:center;gap:6px;font-weight:600;display:flex}.mobile-week-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.mobile-week-total{font-size:var(--t-sm);color:var(--c-text-2);flex:1}.mobile-week-progress{flex-direction:column;gap:4px;display:flex}.mobile-day-strip{background:var(--c-surface);border-bottom:1px solid var(--c-border-light);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.mobile-day-strip::-webkit-scrollbar{display:none}.mobile-day-pill{cursor:pointer;min-width:44px;transition:background var(--duration), border-color var(--duration);background:0 0;border:none;border-bottom:2px solid #0000;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 4px 6px;display:flex;position:relative}.mobile-day-pill:active{background:var(--c-surface-2)}.mobile-day-pill--active{border-bottom-color:var(--c-primary);background:var(--c-primary-ghost,#eff6ff)}.mobile-day-pill--today .mobile-pill-num{color:var(--c-primary);font-weight:700}.mobile-day-pill--sunday{opacity:.4}.mobile-pill-name{text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-3,#94a3b8);font-size:.68rem}.mobile-pill-num{color:var(--c-text);font-size:.82rem;font-weight:600}.mobile-pill-dot{background:var(--c-primary);border-radius:50%;width:5px;height:5px;position:absolute;bottom:3px}.mobile-day-nav{justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.mobile-day-label{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.mobile-day-name{font-size:var(--t-sm);text-transform:capitalize;color:var(--c-text-2);font-weight:500}.mobile-day-name--today{color:var(--c-primary)}.mobile-day-num{color:var(--c-text);font-size:1rem;font-weight:700}.mobile-day-num--today{color:var(--c-primary)}.mobile-day-total{color:var(--c-text-3,#94a3b8);margin-top:2px;font-size:.72rem}.mobile-activity-list{flex-direction:column;flex:1;gap:10px;padding:12px 16px;display:flex;overflow-y:auto}.mobile-empty-day{text-align:center;color:var(--c-text-3,#94a3b8);font-size:var(--t-sm);padding:40px 20px;font-style:italic}.mobile-activity-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);border-left-width:4px;align-items:stretch;gap:12px;padding:12px 14px;display:flex}.mobile-card-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.mobile-card-type{text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:700}.mobile-card-desc{font-size:var(--t-sm);color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.mobile-card-time{color:var(--c-text-3,#94a3b8);font-size:.75rem}.mobile-card-duration{color:var(--c-text-2);font-weight:600}.mobile-card-actions{flex-direction:column;justify-content:center;gap:4px;display:flex}.mobile-add-bar{background:var(--c-surface);border-top:1px solid var(--c-border-light);padding:12px 16px}.mobile-add-btn{width:100%;font-size:var(--t-sm);border-radius:var(--r-lg);justify-content:center;align-items:center;gap:8px;padding:14px;display:flex}@media (width<=767px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.content{padding:0}.topbar{padding:10px 16px}}.reject-activities{border-top:1px solid var(--c-border-light);margin-top:16px;padding-top:12px}.reject-activities-hint{font-size:var(--t-xs);color:var(--c-text-2);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;margin-bottom:10px;font-weight:600;display:flex}.reject-activities-hint-sub{text-transform:none;letter-spacing:0;font-weight:400}.reject-day{margin-bottom:10px}.reject-day-title{font-size:var(--t-xs);color:var(--c-text-3);text-transform:capitalize;margin:0 0 6px;padding-left:2px;font-weight:600}.reject-activity{border:1px solid var(--c-border-light);border-radius:var(--r-md);margin-bottom:4px;transition:border-color .15s;overflow:hidden}.reject-activity--annotated{border-color:var(--c-warning,#f59e0b);background:color-mix(in srgb, var(--c-warning,#f59e0b) 6%, transparent)}.reject-activity-header{cursor:pointer;text-align:left;width:100%;color:inherit;font-size:var(--t-sm);background:0 0;border:none;align-items:center;gap:8px;padding:7px 10px;display:flex}.reject-activity-header:hover{background:var(--c-hover)}.reject-activity-type{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.reject-activity-time{font-size:var(--t-xs);color:var(--c-text-2);white-space:nowrap}.reject-activity-badge{background:var(--c-warning,#f59e0b);color:#fff;white-space:nowrap;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.reject-activity-note-area{border-top:1px solid var(--c-border-light);background:var(--c-surface-2,var(--c-surface));padding:8px 10px}.reject-activity-desc{font-size:var(--t-xs);color:var(--c-text-2);margin:0 0 6px;font-style:italic}.reject-activity-textarea{resize:vertical;width:100%;font-size:var(--t-sm);border:1px solid var(--c-border);border-radius:var(--r-sm);background:var(--c-bg);color:var(--c-text);box-sizing:border-box;padding:6px 8px}.reject-activity-textarea:focus{border-color:var(--c-accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--c-accent) 20%, transparent);outline:none}.activity-block-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.activity-block-note-icon{color:var(--c-warning,#f59e0b);cursor:help;align-items:center;padding:2px;display:flex}.day-column--holiday{pointer-events:none;background:#fff8f0}.day-column--holiday .day-column-header{background:#fde8cc;border-bottom-color:#f8c99c}.day-column--holiday .day-column-body{background:repeating-linear-gradient(-45deg,#0000,#0000 8px,#fbbf240f 8px 16px)}.day-holiday-tag{margin-left:2px;font-size:11px;line-height:1}.day-holiday-banner{border-radius:var(--r-md);text-align:center;background:#fff7ed;border:1px solid #fed7aa;flex-direction:column;align-items:center;gap:6px;width:88%;padding:12px 8px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.day-holiday-banner-icon{font-size:22px;line-height:1}.day-holiday-banner-name{color:#c2410c;font-size:11px;font-weight:600;line-height:1.3}.form-checkbox-label{color:var(--c-text);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.form-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--c-primary);cursor:pointer}.form-banner{border-radius:var(--r-md);margin-bottom:12px;padding:10px 14px;font-size:13px}.form-banner--success{color:#15803d;background:#f0fdf4;border:1px solid #86efac}.badge--muted{color:var(--c-text-muted);border:1px solid var(--c-border);background:#f1f5f9}.impersonation-banner{z-index:9999;color:#fff;background:#7c3aed;align-items:center;gap:10px;padding:8px 20px;font-size:.82rem;font-weight:500;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #7c3aed59}.impersonation-banner strong{font-weight:700}.impersonation-role{opacity:.75;margin-left:6px;font-size:.78rem}.impersonation-exit-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:1px solid #ffffff59;border-radius:6px;align-items:center;gap:6px;margin-left:auto;padding:4px 12px;font-size:.8rem;font-weight:600;transition:background .15s;display:flex}.impersonation-exit-btn:hover{background:#ffffff47}.app-shell--impersonating .sidebar,.app-shell--impersonating .content{padding-top:37px}.online-users{max-width:760px;padding:8px 0}.online-users__header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.online-users__title{color:var(--c-text);align-items:center;gap:10px;font-size:1rem;font-weight:600;display:flex}.online-pulse{background:var(--c-border);border-radius:50%;flex-shrink:0;width:10px;height:10px}.online-pulse--active{background:#22c55e;animation:2s infinite pulse-ring;box-shadow:0 0 0 3px #22c55e33}@keyframes pulse-ring{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 7px #22c55e00}to{box-shadow:0 0 #22c55e00}}.online-users__meta{align-items:center;gap:10px;display:flex}.online-users__refresh-time{color:var(--c-text-3,#94a3b8);align-items:center;gap:4px;font-size:.75rem;display:flex}.online-users__refresh-btn{border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-surface);width:30px;height:30px;color:var(--c-text-2);cursor:pointer;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.online-users__refresh-btn:hover:not(:disabled){background:var(--c-bg);color:var(--c-primary)}.online-users__refresh-btn:disabled{opacity:.5;cursor:not-allowed}.spin{animation:.8s linear infinite spin}.online-users__empty{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:56px 24px;display:flex}.online-users__empty-icon{color:var(--c-border);margin-bottom:4px}.online-users__empty p{color:var(--c-text-2);margin:0;font-size:.95rem;font-weight:500}.online-users__empty span{color:var(--c-text-3,#94a3b8);font-size:.82rem}.online-users__list{flex-direction:column;gap:8px;display:flex}.online-user-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-lg);align-items:center;gap:14px;padding:14px 16px;transition:border-color .15s;display:flex}.online-user-card:hover{border-color:var(--c-border)}.online-user-card__avatar{background:var(--c-primary);color:#fff;text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.78rem;font-weight:700;display:flex}.online-user-card__info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.online-user-card__name{color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.online-user-card__email{color:var(--c-text-3,#94a3b8);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.online-user-card__right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.online-user-card__role{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 8px;font-size:.7rem;font-weight:600}.online-user-card__role--administrator{color:#264370;background:#2643701f}.online-user-card__role--manager{color:#2a8a92;background:#41abb41f}.online-user-card__role--collaborateur{color:#475569;background:#64748b1a}.online-user-card__duration{color:#22c55e;align-items:center;gap:4px;font-size:.75rem;font-weight:500;display:flex}.import-modal{flex-direction:column;gap:16px;display:flex}.import-dropzone{border:2px dashed var(--c-border);border-radius:var(--r-lg);text-align:center;cursor:pointer;padding:36px 24px;transition:border-color .15s,background .15s;position:relative}.import-dropzone:hover,.import-dropzone--over{border-color:var(--c-primary);background:#2643700a}.import-dropzone--filled{border-style:solid;border-color:var(--c-primary);background:#26437008}.import-file-input{display:none}.import-upload-icon{color:var(--c-border);margin:0 auto 10px;display:block}.import-drop-text{color:var(--c-text-2);margin:0 0 4px;font-size:.9rem}.import-drop-text span{color:var(--c-primary);font-weight:500;text-decoration:underline}.import-drop-hint{color:var(--c-text-3,#94a3b8);margin:0;font-size:.75rem}.import-file-chosen{justify-content:center;align-items:center;gap:10px;display:flex}.import-file-icon{color:var(--c-primary);flex-shrink:0}.import-file-name{color:var(--c-text);word-break:break-all;font-size:.88rem;font-weight:500}.import-file-clear{border:1px solid var(--c-border);background:var(--c-bg);width:22px;height:22px;color:var(--c-text-2);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.import-file-clear:hover{background:var(--c-border-light)}.import-error{color:#ef4444;align-items:center;gap:6px;margin:0;font-size:.82rem;display:flex}.import-columns{background:var(--c-bg);border-radius:var(--r-md);padding:12px 14px}.import-columns-title{color:var(--c-text-2);margin:0 0 8px;font-size:.78rem;font-weight:600}.import-columns-list{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.import-col-chip{background:var(--c-border-light);color:var(--c-text-2);border-radius:99px;padding:2px 8px;font-family:monospace;font-size:.72rem;font-weight:500}.import-col-chip--required{color:#264370;background:#2643701a}.import-col-required{color:#ef4444;margin-left:2px}.import-col-legend{color:var(--c-text-3,#94a3b8);align-items:center;gap:4px;margin:0;font-size:.72rem;display:flex}.import-template-btn{justify-content:center;width:100%}.import-results{flex-direction:column;gap:16px;display:flex}.import-summary{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.import-summary-card{border-radius:var(--r-lg);flex-direction:column;align-items:center;gap:4px;padding:14px 8px;font-size:.8rem;font-weight:500;display:flex}.import-summary-card--created{color:#16a34a;background:#22c55e14}.import-summary-card--skipped{color:#b45309;background:#f59e0b14}.import-summary-card--error{color:#dc2626;background:#ef444414}.import-summary-count{font-size:1.6rem;font-weight:700;line-height:1}.import-detail-list{border:1px solid var(--c-border-light);border-radius:var(--r-md);flex-direction:column;gap:4px;max-height:260px;padding:6px;display:flex;overflow-y:auto}.import-detail-row{border-radius:var(--r-sm);align-items:center;gap:8px;padding:6px 8px;font-size:.82rem;display:flex}.import-detail-row--created{background:#22c55e0f}.import-detail-row--skipped{background:#f59e0b0f}.import-detail-row--error{background:#ef44440f}.import-detail-badge{text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;align-items:center;gap:4px;width:56px;font-size:.7rem;font-weight:600;display:flex}.import-detail-row--created .import-detail-badge{color:#16a34a}.import-detail-row--skipped .import-detail-badge{color:#b45309}.import-detail-row--error .import-detail-badge{color:#dc2626}.import-detail-name{color:var(--c-text);flex:1;font-weight:500}.import-detail-reason{color:var(--c-text-3,#94a3b8);font-size:.75rem}.online-users__footnote{color:var(--c-text-3,#94a3b8);text-align:center;margin-top:16px;font-size:.75rem}.user-name-cell{align-items:center;gap:7px;display:inline-flex}.presence-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s infinite pulse-ring;box-shadow:0 0 0 2px #22c55e33}
