:root{--tod-ease-spring:cubic-bezier(.16,1,.3,1);--tod-shadow-sm:0 1px 2px #0f172a0a;--tod-shadow-md:0 4px 12px #0f172a0f,0 2px 4px #0f172a0a;--tod-shadow-float:0 20px 40px -8px #0f172a1f,0 8px 16px -4px #0f172a14;--tod-radius-lg:16px;--tod-radius-md:12px;--tod-radius-sm:8px}.tod-root{background-color:var(--wh-bg,#f8fafc);animation:todFadeIn .4s var(--tod-ease-spring);flex-direction:column;width:100%;height:100%;margin:0 auto;display:flex}.tod-content-island{background:var(--wh-surface,#fff);border:1px solid var(--wh-border-light,#e2e8f0);border-radius:var(--tod-radius-lg);flex-direction:column;flex:1;gap:12px;min-height:0;margin:16px;padding:16px;display:flex;overflow:hidden;box-shadow:0 4px 20px #0f172a08}.tod-inner-island{background:var(--wh-surface,#fff);border:1px solid var(--wh-border-light,#e2e8f0);border-radius:var(--tod-radius-md);box-shadow:var(--tod-shadow-sm);flex-shrink:0}.tod-subbar{flex-flow:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.tod-subbar-left,.tod-subbar-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}[data-theme=dark] .tod-content-island,[data-theme=dark] .tod-inner-island{background:var(--wh-surface,#0f172a);border-color:#ffffff14;box-shadow:0 4px 20px #0003}@keyframes todFadeIn{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.tod-header{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:6px;display:flex}.tod-eyebrow{color:var(--wh-indigo,#3b82f6);font-size:11px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);text-transform:uppercase;letter-spacing:.08em}.tod-main-tabs{gap:4px;margin-top:4px;display:flex}.tod-main-tab{color:var(--wh-text-muted,#64748b);font-size:14px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);cursor:pointer;border-radius:var(--tod-radius-sm);background:0 0;border:none;padding:6px 12px;transition:all .2s;position:relative}.tod-main-tab:hover,.tod-main-tab--active{color:var(--wh-text,#0f172a);background:var(--wh-surface-hover,#f1f5f9)}.tod-main-tab--active:after{content:"";background:var(--wh-text,#0f172a);border-radius:2px;height:2px;position:absolute;bottom:-2px;left:12px;right:12px}.tod-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.tod-toolbar{border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);box-shadow:var(--tod-shadow-sm);flex-direction:column;flex-shrink:0;gap:10px;margin-bottom:4px;padding:10px 14px;display:flex}.tod-toolbar-top{align-items:center;gap:12px;display:flex}.tod-search-wrap{border-radius:var(--tod-radius-sm);border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-bg,#f8fafc);flex:0 320px;align-items:center;gap:8px;min-width:220px;max-width:360px;height:36px;padding:0 12px;transition:border-color .2s,box-shadow .2s;display:flex}.tod-search-wrap:focus-within{border-color:var(--wh-indigo,#3b82f6);box-shadow:0 0 0 3px color-mix(in srgb,var(--wh-indigo,#3b82f6)15%,transparent);background:var(--wh-surface,#fff)}.tod-search-input{font-size:14px;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text,#0f172a);background:0 0;border:none;outline:none;flex:1}.tod-search-input::placeholder{color:var(--wh-text-muted,#94a3b8)}.tod-search-clear{cursor:pointer;color:var(--wh-text-muted,#94a3b8);background:0 0;border:none;padding:2px;transition:color .15s;display:flex}.tod-search-clear:hover{color:var(--wh-text,#0f172a)}.tod-toolbar-actions{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.tod-toolbar-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;display:flex}.tod-view-toggle{border-radius:var(--tod-radius-sm);border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-bg,#f8fafc);gap:2px;padding:3px;display:flex;overflow:hidden}.tod-view-btn{cursor:pointer;color:var(--wh-text-muted,#64748b);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.tod-view-btn:hover{color:var(--wh-text,#0f172a)}.tod-view-btn--active{background:var(--wh-surface,#fff);color:var(--wh-text,#0f172a);box-shadow:var(--tod-shadow-sm)}.tod-status-tabs{background:var(--wh-bg,#f1f5f9);border-radius:var(--tod-radius-sm);flex-wrap:wrap;align-self:flex-start;align-items:center;gap:4px;padding:4px;display:flex}.tod-status-tab{font-size:13px;font-weight:500;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text-secondary,#475569);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;transition:all .15s;display:flex}.tod-status-tab:hover{color:var(--wh-text,#0f172a)}.tod-status-tab--active{background:var(--wh-surface,#fff);color:var(--wh-text,#0f172a);font-weight:600;box-shadow:0 1px 3px #0f172a14}.tod-status-count{background:var(--wh-border-light,#e2e8f0);color:var(--wh-text-secondary,#475569);border-radius:12px;padding:2px 6px;font-size:11px;font-weight:700}.tod-status-tab--active .tod-status-count{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)12%,transparent);color:var(--wh-indigo,#3b82f6)}.tod-policy-chips{flex-wrap:wrap;gap:8px;display:flex}.tod-policy-chip{border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-bg,#f8fafc);font-size:13px;font-weight:500;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text,#0f172a);cursor:pointer;border-radius:999px;padding:6px 14px;transition:all .15s}.tod-policy-chip:hover{border-color:var(--wh-border-strong,#94a3b8);background:var(--wh-surface,#fff)}.tod-policy-chip--active{border-color:var(--wh-indigo,#3b82f6);background:color-mix(in srgb,var(--wh-indigo,#3b82f6)8%,transparent);color:var(--wh-indigo,#3b82f6);font-weight:600}.tod-year-nav{align-items:center;gap:8px;display:flex}.tod-year-btn{border-radius:var(--tod-radius-sm);border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-surface,#fff);cursor:pointer;color:var(--wh-text,#0f172a);justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.tod-year-btn:hover{background:var(--wh-surface-hover,#f1f5f9);border-color:var(--wh-border-strong,#94a3b8)}.tod-year-label{color:var(--wh-text,#0f172a);font-size:15px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);text-align:center;min-width:48px}.tod-content{border-radius:var(--tod-radius-md);flex:1;min-height:0;overflow-y:auto}.tod-card{border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);cursor:pointer;transition:transform .2s var(--tod-ease-spring),box-shadow .2s ease,border-color .2s ease;animation:todFadeIn .25s var(--tod-ease-spring);flex-direction:column;gap:12px;padding:16px;display:flex;box-shadow:0 1px 2px #0f172a05}.tod-card:hover{box-shadow:var(--tod-shadow-md);border-color:var(--wh-border-strong,#cbd5e1);transform:translateY(-2px)}.tod-card-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.tod-card-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.tod-card-info{flex:1;min-width:0}.tod-card-name{color:var(--wh-text,#0f172a);font-size:14.5px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);display:block}.tod-card-date{color:var(--wh-text-secondary,#475569);font-size:13px;font-family:var(--wh-font,"Inter",sans-serif);margin-top:2px;display:block}.tod-card-hours{color:var(--wh-text-muted,#64748b);font-weight:600}.tod-card-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.tod-card-reason{color:var(--wh-text-secondary,#475569);font-size:13.5px;font-family:var(--wh-font,"Inter",sans-serif);white-space:nowrap;text-overflow:ellipsis;margin:0;line-height:1.5;overflow:hidden}.tod-card-actions{border-top:1px solid var(--wh-divider,#f1f5f9);justify-content:flex-end;gap:8px;padding-top:12px;display:flex}.tod-avatar{object-fit:cover;border:1px solid #0f172a0d;border-radius:16px;flex-shrink:0;width:32px;height:32px}.tod-avatar--fallback{background:var(--wh-bg,#f1f5f9);color:var(--wh-text-secondary,#475569);font-size:12px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);justify-content:center;align-items:center;display:inline-flex}.tod-kind-chip{font-size:12px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:4px 10px;display:inline-flex}.tod-table-wrap{border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);flex:1;min-height:0;overflow:auto;box-shadow:0 1px 3px #0f172a05}.tod-table{border-collapse:collapse;font-family:var(--wh-font,"Inter",sans-serif);width:100%}.tod-table th{text-align:left;color:var(--wh-text-muted,#64748b);text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--wh-border-light,#e2e8f0);z-index:2;background:#ffffffd9;padding:12px 16px;font-size:11px;font-weight:700;position:sticky;top:0}.tod-table td{color:var(--wh-text,#0f172a);border-bottom:1px solid var(--wh-divider,#f1f5f9);font-variant-numeric:tabular-nums;vertical-align:middle;padding:10px 16px;font-size:14px}.tod-table-row{cursor:pointer;transition:background .15s}.tod-table-row:hover{background:var(--wh-surface-hover,#f8fafc)}.tod-table-row:last-child td{border-bottom:none}.tod-table-employee{align-items:center;gap:12px;font-weight:600;display:flex}.tod-unlimited{color:var(--wh-indigo,#3b82f6);background:color-mix(in srgb,var(--wh-indigo,#3b82f6)10%,transparent);border-radius:999px;padding:2px 8px;font-size:12px;font-weight:700}.tod-stat-cards{flex-shrink:0;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px;display:grid}.tod-stat-card{border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);flex-direction:row;align-items:center;gap:14px;padding:16px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 1px 3px #0f172a05}.tod-stat-card:hover{box-shadow:var(--tod-shadow-md);transform:translateY(-2px)}.tod-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.tod-stat-value{color:var(--wh-text,#0f172a);font-size:24px;font-weight:800;font-family:var(--wh-font,"Inter",sans-serif);letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:4px;line-height:1;display:block}.tod-stat-label{color:var(--wh-text-muted,#64748b);font-size:12px;font-weight:500;font-family:var(--wh-font,"Inter",sans-serif);line-height:1.1;display:block}.tod-table-emp-info{flex-direction:column;gap:2px;min-width:0;display:flex}.tod-table-emp-name{color:var(--wh-text,#0f172a);font-size:14px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif)}.tod-table-emp-dept{color:var(--wh-text-muted,#64748b);font-size:12.5px;font-family:var(--wh-font,"Inter",sans-serif)}.tod-date-primary{color:var(--wh-text,#0f172a);font-size:13px;font-weight:500;font-family:var(--wh-font,"Inter",sans-serif);white-space:nowrap;font-variant-numeric:tabular-nums;display:block}.tod-date-duration{color:var(--wh-text-muted,#64748b);font-size:12px;font-family:var(--wh-font,"Inter",sans-serif);margin-top:2px;display:block}.tod-table-page-btns{align-items:center;gap:4px;display:flex}.tod-table-page-btn{border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-surface,#fff);font-size:13px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text-secondary,#475569);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;transition:all .15s;display:flex}.tod-table-page-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--wh-bg,#f8fafc)}.tod-table-page-btn:hover:not(:disabled){border-color:var(--wh-border-strong,#94a3b8);background:var(--wh-surface-hover,#f1f5f9);color:var(--wh-text,#0f172a)}.tod-table-page-btn--active{background:var(--wh-indigo,#3b82f6);border-color:var(--wh-indigo,#3b82f6);color:#fff}.tod-table-page-btn--active:hover:not(:disabled){color:#fff;background:#2563eb}.tod-page-ellipsis{color:var(--wh-text-muted,#94a3b8);padding:0 6px;font-size:14px}.tod-gantt{flex-direction:column;gap:16px;display:flex}.tod-gantt-nav{justify-content:space-between;align-items:center;display:flex}.tod-gantt-nav-left{align-items:center;gap:12px;display:flex}.tod-gantt-title{color:var(--wh-text,#0f172a);font-size:16px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif)}.tod-gantt-period{color:var(--wh-text-muted,#64748b);font-size:13px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-surface,#fff);border-radius:999px;padding:6px 12px}.tod-gantt-wrap{border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);overflow-x:auto;box-shadow:0 1px 3px #0f172a05}.tod-gantt-table{border-collapse:collapse;font-family:var(--wh-font,"Inter",sans-serif);width:100%;min-width:800px}.tod-gantt-emp-header{text-align:left;color:var(--wh-text-muted,#64748b);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--wh-border-light,#e2e8f0);-webkit-backdrop-filter:blur(12px);z-index:2;border-right:1px solid var(--wh-border-light,#e2e8f0);background:#ffffffe6;min-width:240px;padding:12px 16px;font-size:11px;font-weight:700;position:sticky;left:0}.tod-gantt-day-header{text-align:center;color:var(--wh-text-muted,#64748b);font-size:13px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--wh-border-light,#e2e8f0);font-variant-numeric:tabular-nums;background:#ffffffe6;min-width:44px;padding:12px 0}.tod-gantt-day-header--today{color:var(--wh-indigo,#3b82f6);position:relative}.tod-gantt-day-header--today:after{content:"";background:var(--wh-indigo,#3b82f6);border-radius:2px;width:4px;height:4px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.tod-gantt-row{border-bottom:1px solid var(--wh-divider,#f1f5f9)}.tod-gantt-row:last-child{border-bottom:none}.tod-gantt-emp-cell{background:var(--wh-surface,#fff);z-index:1;border-right:1px solid var(--wh-border-light,#e2e8f0);padding:10px 16px;position:sticky;left:0}.tod-gantt-cell{text-align:center;vertical-align:middle;border-right:1px solid var(--wh-divider,#f8fafc);min-height:48px;padding:6px 2px}.tod-gantt-cell:last-child{border-right:none}.tod-gantt-cell--today{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)3%,transparent)}.tod-gantt-cell--filled{cursor:pointer;transition:background .15s}.tod-gantt-cell--filled:hover{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)8%,transparent)}.tod-gantt-dot{border:2px solid;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .15s;display:inline-flex}.tod-gantt-cell--filled:hover .tod-gantt-dot{transform:scale(1.1)}.tod-gantt-dot .tod-avatar{border:none;border-radius:8px;width:24px;height:24px;font-size:10px}.tod-gantt-empty{text-align:center;color:var(--wh-text-muted,#64748b);font-size:14px;font-family:var(--wh-font,"Inter",sans-serif);padding:48px}.tod-req-table{table-layout:fixed}.tod-th-check,.tod-td-check{text-align:center;width:48px;padding-left:16px!important;padding-right:8px!important}.tod-th-actions{width:90px}.tod-td-date{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--wh-text-secondary,#475569);font-size:13px}.tod-td-reason{max-width:280px}.tod-reason-text{-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;color:var(--wh-text-secondary,#475569);-webkit-box-orient:vertical;font-size:13.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.tod-td-actions{padding-right:16px!important}.tod-table-row--selected{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)4%,transparent)}.tod-table-row--selected:hover{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)6%,transparent)}.tod-inline-actions{opacity:0;justify-content:flex-end;gap:6px;transition:opacity .15s;display:flex}.tod-table-row:hover .tod-inline-actions{opacity:1}.tod-inline-action{border:1px solid var(--wh-border-light,#e2e8f0);background:var(--wh-surface,#fff);cursor:pointer;color:var(--wh-text-muted,#64748b);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.tod-inline-action:hover{transform:scale(1.05)}.tod-inline-action--approve{color:var(--wh-success,#10b981);border-color:color-mix(in srgb,var(--wh-success,#10b981)30%,transparent)}.tod-inline-action--approve:hover{background:var(--wh-success,#10b981);border-color:var(--wh-success,#10b981);color:#fff;box-shadow:0 4px 12px #10b98140}.tod-inline-action--reject{color:var(--wh-error,#f43f5e);border-color:color-mix(in srgb,var(--wh-error,#f43f5e)30%,transparent)}.tod-inline-action--reject:hover{background:var(--wh-error,#f43f5e);border-color:var(--wh-error,#f43f5e);color:#fff;box-shadow:0 4px 12px #f43f5e40}.tod-table-footer{border-top:1px solid var(--wh-divider,#e2e8f0);backdrop-filter:blur(8px);background:#fffffff2;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;bottom:0}.tod-modal{flex-direction:column;gap:0;display:flex}.tod-modal-status-bar{font-size:13px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);color:#fff;letter-spacing:.05em;text-transform:uppercase;border-radius:999px;align-self:flex-start;align-items:center;gap:8px;margin-bottom:20px;padding:6px 14px;display:inline-flex;box-shadow:0 2px 4px #0000000d}.tod-modal-status-bar--pending{background:var(--wh-warning,#f59e0b);color:#fff}.tod-modal-status-bar--approved{background:var(--wh-success,#10b981)}.tod-modal-status-bar--rejected{background:var(--wh-error,#f43f5e)}.tod-modal-emp{background:var(--wh-bg,#f8fafc);border-radius:var(--tod-radius-md);border:1px solid var(--wh-border-light,#e2e8f0);align-items:center;gap:16px;margin-bottom:12px;padding:16px 20px;display:flex}.tod-modal-avatar-wrap{flex-shrink:0}.tod-modal-avatar-wrap .tod-avatar{border-radius:28px;width:56px;height:56px;font-size:18px}.tod-modal-emp-info{flex-direction:column;gap:6px;display:flex}.tod-modal-emp-name{color:var(--wh-text,#0f172a);font-size:18px;font-weight:800;font-family:var(--wh-font,"Inter",sans-serif);letter-spacing:-.02em}.tod-modal-fields{flex-direction:column;display:flex}.tod-modal-row{border-bottom:1px solid var(--wh-divider,#f1f5f9);align-items:flex-start;gap:16px;padding:16px 0;display:flex}.tod-modal-row:last-child{border-bottom:none}.tod-modal-row-icon{background:color-mix(in srgb,var(--wh-indigo,#3b82f6)8%,transparent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.tod-modal-row-content{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.tod-modal-row-label{color:var(--wh-text-muted,#64748b);font-size:12px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);text-transform:uppercase;letter-spacing:.05em}.tod-modal-row-value{color:var(--wh-text,#0f172a);font-size:15px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif)}.tod-modal-row-sub{color:var(--wh-text-muted,#64748b);font-size:13.5px;font-family:var(--wh-font,"Inter",sans-serif)}.tod-modal-row-reason{color:var(--wh-text,#334155);font-size:14.5px;font-family:var(--wh-font,"Inter",sans-serif);margin:0;line-height:1.6}.tod-modal-file-link{color:var(--wh-indigo,#3b82f6);font-size:14px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);background:color-mix(in srgb,var(--wh-indigo,#3b82f6)6%,transparent);border-radius:8px;align-items:center;gap:6px;padding:8px 12px;text-decoration:none;transition:opacity .15s;display:inline-flex}.tod-modal-file-link:hover{opacity:.8;background:color-mix(in srgb,var(--wh-indigo,#3b82f6)10%,transparent)}.tod-modal-timeline{border-top:1px solid var(--wh-divider,#e2e8f0);margin-top:20px;padding-top:20px}.tod-modal-timeline-title{color:var(--wh-text-secondary,#475569);font-size:13px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);text-transform:uppercase;letter-spacing:.05em;margin:0 0 16px}.tod-modal-tl-item{border-left:2px solid var(--wh-border-light,#e2e8f0);align-items:flex-start;gap:12px;margin-left:12px;padding-bottom:20px;padding-left:4px;display:flex;position:relative}.tod-modal-tl-item:last-child{border-left-color:#0000;padding-bottom:0}.tod-modal-tl-dot{background:var(--wh-surface,#fff);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-left:-15px;display:flex}.tod-modal-tl-dot--approved{background:var(--wh-success,#10b981);box-shadow:0 0 0 4px color-mix(in srgb,var(--wh-success,#10b981)15%,transparent)}.tod-modal-tl-dot--rejected{background:var(--wh-error,#f43f5e);box-shadow:0 0 0 4px color-mix(in srgb,var(--wh-error,#f43f5e)15%,transparent)}.tod-modal-tl-dot--submitted{background:var(--wh-indigo,#3b82f6);box-shadow:0 0 0 4px color-mix(in srgb,var(--wh-indigo,#3b82f6)15%,transparent)}.tod-modal-tl-content{flex-direction:column;gap:4px;padding-top:3px;display:flex}.tod-modal-tl-event{color:var(--wh-text,#0f172a);font-size:14px;font-family:var(--wh-font,"Inter",sans-serif)}.tod-modal-tl-event strong{font-weight:700}.tod-modal-tl-date{color:var(--wh-text-muted,#64748b);font-size:12.5px;font-family:var(--wh-font,"Inter",sans-serif)}.tod-modal-pending-box{border-radius:var(--tod-radius-md);background:color-mix(in srgb,var(--wh-warning,#f59e0b)8%,transparent);border:1px solid color-mix(in srgb,var(--wh-warning,#f59e0b)20%,transparent);align-items:flex-start;gap:16px;margin-top:20px;padding:16px 20px;display:flex}.tod-modal-pending-title{color:var(--wh-warning-strong,#d97706);font-size:14.5px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);display:block}.tod-modal-pending-sub{color:var(--wh-text-secondary,#475569);font-size:13.5px;font-family:var(--wh-font,"Inter",sans-serif);margin-top:4px;display:block}.tod-modal-actions{gap:16px;width:100%;margin-top:24px;display:flex}.tod-modal-btn{border-radius:var(--tod-radius-md);font-size:15px;font-weight:700;font-family:var(--wh-font,"Inter",sans-serif);cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;gap:10px;height:48px;padding:0 20px;transition:background .2s,box-shadow .2s,transform .2s,opacity .2s;display:flex}.tod-modal-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none!important;transform:none!important}.tod-modal-btn--approve{background:var(--wh-text,#0f172a);color:#fff;box-shadow:0 4px 12px #0f172a26}.tod-modal-btn--approve:hover:not(:disabled){background:#1e293b;transform:translateY(-1px);box-shadow:0 6px 16px #0f172a33}.tod-modal-btn--reject{background:var(--wh-surface,#fff);color:var(--wh-error,#f43f5e);border:1px solid var(--wh-error,#f43f5e)}.tod-modal-btn--reject:hover:not(:disabled){background:color-mix(in srgb,var(--wh-error,#f43f5e)5%,transparent);transform:translateY(-1px)}.tod-sort-select{border-radius:var(--tod-radius-sm);border:1px solid var(--wh-border,#cbd5e1);background:var(--wh-surface,#fff);font-size:13.5px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text,#0f172a);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;height:36px;padding:0 32px 0 14px;transition:border-color .15s}.tod-sort-select:hover{border-color:var(--wh-border-strong,#94a3b8)}.tod-sort-select:focus{border-color:var(--wh-indigo,#3b82f6);outline:none}.tod-select-all-btn{cursor:pointer;font-size:13px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);color:var(--wh-text-secondary,#475569);border-radius:var(--tod-radius-sm);background:0 0;border:none;align-items:center;gap:8px;padding:6px 10px;transition:background .15s;display:flex}.tod-select-all-btn:hover{background:var(--wh-surface-hover,#f8fafc)}.tod-results-count{color:var(--wh-text-muted,#64748b);font-size:13px;font-family:var(--wh-font,"Inter",sans-serif);font-weight:500}.tod-card-checkbox{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:4px;transition:transform .15s;display:flex}.tod-card-checkbox:hover{transform:scale(1.1)}.tod-bulk-bar{background:var(--wh-text,#0f172a);color:#fff;box-shadow:var(--tod-shadow-float);z-index:50;border-radius:999px;align-items:center;gap:20px;padding:12px 20px;animation:.3s cubic-bezier(.16,1,.3,1) forwards todSlideUp;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%)}@keyframes todSlideUp{0%{opacity:0;transform:translate(-50%)translateY(24px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.tod-bulk-count{font-size:14.5px;font-weight:600;font-family:var(--wh-font,"Inter",sans-serif);white-space:nowrap;font-variant-numeric:tabular-nums;align-items:center;gap:8px;display:flex}.tod-bulk-actions{gap:10px;display:flex}.tod-bulk-dismiss{cursor:pointer;color:#fffc;background:#ffffff1a;border:none;border-radius:50%;padding:6px;transition:all .15s;display:flex}.tod-bulk-dismiss:hover{color:#fff;background:#fff3}.tod-skeleton-list{flex-direction:column;gap:12px;display:flex}.tod-skel-card{border-radius:var(--tod-radius-md);height:100px}@media (width<=640px){.tod-root{background-color:var(--wh-surface,#fff)}.tod-content-island{box-shadow:none;border-left:none;border-right:none;border-radius:0;margin:0;padding:12px}.tod-header{flex-direction:column}.tod-toolbar-top{flex-direction:column;align-items:stretch}.tod-toolbar-actions{justify-content:space-between}.tod-stat-cards{grid-template-columns:repeat(2,1fr)}.tod-req-table{table-layout:auto}.tod-bulk-bar{justify-content:space-between;bottom:24px;left:16px;right:16px;transform:none}@keyframes todSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.tod-sort-select{width:100%}}@keyframes todCardEntrance{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.tod-table-row{animation:.3s cubic-bezier(.16,1,.3,1) both todRowReveal;animation-delay:var(--tod-row-delay,0s)}@keyframes todRowReveal{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tod-table th.tod-th-sortable{cursor:pointer;user-select:none;transition:background .15s}.tod-table th.tod-th-sortable:hover{background:var(--wh-surface-hover,#f1f5f9)}.tod-th-sort-icon{opacity:.5;margin-left:6px;transition:opacity .15s;display:inline-flex}.tod-th-sortable:hover .tod-th-sort-icon{opacity:1}.tod-th-sort-icon--active{opacity:1;color:var(--wh-indigo,#3b82f6)}.tod-root button:focus-visible,.tod-root a:focus-visible,.tod-root select:focus-visible,.tod-root input:focus-visible{outline:2px solid var(--wh-indigo,#3b82f6);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion:reduce){.tod-root,.tod-card,.tod-table-row,.tod-cal-item,.tod-bulk-bar,.tod-detail-panel{transition-duration:.01ms!important;animation:none!important}}