*,*:before,*:after{box-sizing:border-box}html{margin:0;padding:0;scrollbar-gutter:stable}html,body,#root{margin:0;padding:0;min-height:100%}:root{--bg-page: #e8efff;--bg-card: #ffffff;--bg-card-soft: #f9fafb;--border-subtle: #e5e7eb;--accent: #2563eb;--accent-soft: #dbeafe;--text-main: #0f172a;--text-muted: #6b7280;--space-1: 8px;--space-2: 12px;--space-3: 16px;--space-4: 24px;--space-5: 32px;--radius-md: 12px;--radius-lg: 16px;--shadow-soft: 0 10px 30px rgba(15, 23, 42, .08);--shadow-hover: 0 16px 34px rgba(15, 23, 42, .12)}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-main);background-color:var(--bg-page);background-image:radial-gradient(ellipse 1100px 520px at 50% -15%,rgba(59,130,246,.22),transparent 58%),radial-gradient(ellipse 720px 440px at 5% 25%,rgba(37,99,235,.14),transparent 55%),radial-gradient(ellipse 680px 400px at 95% 30%,rgba(14,165,233,.16),transparent 55%),radial-gradient(ellipse 120% 70% at 50% 105%,rgba(30,64,175,.08),transparent 55%),linear-gradient(165deg,#f0f7ff,#e8efff 28%,#dde9ff 58%,#e4ecfa);background-attachment:scroll}a{color:inherit;text-decoration:none}button{font-family:inherit}.ui-card{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#ffffffeb;box-shadow:var(--shadow-soft)}.ui-card-soft{border:1px solid #dbeafe;border-radius:var(--radius-lg);background:linear-gradient(180deg,#eff6ff,#f8fbff);box-shadow:var(--shadow-soft)}.ui-card-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-2)}.ui-kpi-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.ui-kpi{border:1px solid #dbe3ee;border-radius:var(--radius-md);background:#fff;padding:var(--space-3);transition:transform .16s ease,box-shadow .16s ease}.ui-kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.ui-kpi-label{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:#64748b;margin-bottom:6px}.ui-kpi-value{font-size:22px;font-weight:700;color:#0f172a}.ui-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid #e2e8f0;border-radius:var(--radius-md);background:#fff}.ui-table{width:100%;border-collapse:collapse;min-width:760px}.ui-table th{position:sticky;top:0;z-index:2;background:linear-gradient(90deg,#eff6ff,#ecfeff)}.ui-table th,.ui-table td{padding:10px 12px;text-align:left;font-size:12px}.ui-table tbody tr:nth-child(odd){background:#fff}.ui-table tbody tr:nth-child(2n){background:#f8fafc}.ui-input{width:100%;border:1px solid #d1d5db;border-radius:10px;background:#fff;padding:10px 12px;font-size:13px;color:#0f172a;transition:border-color .15s ease,box-shadow .15s ease}.ui-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f629}.ui-field-label{display:block;margin-bottom:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#64748b}.ui-skeleton{border-radius:10px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9);background-size:200% 100%;animation:ui-skeleton 1.1s linear infinite}@keyframes ui-skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.nav-shell{border:1px solid #dbe3ee;border-radius:9999px;padding:4px;background:linear-gradient(180deg,#fff,#f8fafc);overflow:visible}.nav-adjointe-rapports-wrap{position:relative;display:inline-flex;flex-shrink:0;align-self:center;vertical-align:middle}.nav-adjointe-rapports-dropdown{position:absolute;left:0;top:100%;margin-top:.5rem;z-index:200;display:flex;flex-direction:column;min-width:14rem;overflow:hidden;border-radius:.75rem;border:2px solid rgb(203 213 225 / .95);background:#fff;padding:.375rem 0;box-shadow:0 12px 40px -12px #0f172a59,0 0 0 1px #0f172a0d}.nav-adjointe-rapports-link{margin:0 .25rem;border-radius:.5rem;padding:.625rem .75rem;font-size:.875rem;font-weight:500;color:#374151;text-decoration:none;transition:background-color .15s ease,color .15s ease}.nav-adjointe-rapports-link:hover{background:#f8fafc;color:#1f2937}.nav-adjointe-rapports-link--active{background:#eff6ff;color:#1e40af}.nav-adjointe-rapports-caret{font-size:.65rem;opacity:.7}.nav-pill{color:#334155}.nav-pill:hover{background:#eef2ff}.nav-pill-active{color:#fff;background:linear-gradient(180deg,#3b82f6,#2563eb);box-shadow:0 6px 14px -8px #2563ebb3}.activities-page{display:flex;flex-direction:column;gap:var(--space-2)}.activities-header h1{margin:0;font-size:1.2rem;font-weight:600;color:#0f172a;letter-spacing:-.02em}.activities-lede{margin:4px 0 0;font-size:12px;line-height:1.45;color:#64748b;max-width:48rem}.activities-shell{border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 1px 2px #0f172a0d;overflow:hidden}.activities-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.activities-stats{display:flex;flex-wrap:wrap;align-items:center;gap:4px 14px;font-size:11px;color:#64748b}.activities-stats b{color:#0f172a;font-weight:600}.activities-search{width:min(100%,220px);border:1px solid #cbd5e1;border-radius:8px;padding:6px 10px;font-size:12px;background:#fff;color:#0f172a}.activities-search:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 2px #3b82f626}.activities-form{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.65fr) minmax(0,1.4fr) auto;gap:8px 10px;padding:10px 12px;align-items:end;border-bottom:1px solid #f1f5f9;background:#fff}@media(max-width:900px){.activities-form{grid-template-columns:1fr 1fr}.activities-form .activities-form-actions{grid-column:1 / -1;justify-self:start}}.activities-field-label{display:block;margin-bottom:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.activities-input{width:100%;border:1px solid #d1d5db;border-radius:8px;padding:6px 10px;font-size:12px;color:#0f172a;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.activities-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 2px #3b82f61f}.activities-btn-add{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:600;color:#fff;border:none;border-radius:8px;cursor:pointer;background:linear-gradient(180deg,#3b82f6,#2563eb);box-shadow:0 4px 10px -4px #2563eb80;transition:transform .1s ease,box-shadow .15s ease;white-space:nowrap}.activities-btn-add:hover:not(:disabled){transform:translateY(-1px)}.activities-btn-add:disabled{opacity:.55;cursor:not-allowed}.activities-hint{margin:0;padding:6px 12px 8px;font-size:11px;color:#94a3b8;background:#fafafa;border-bottom:1px solid #f1f5f9}.activities-table-wrap{max-height:min(52vh,520px);overflow:auto;-webkit-overflow-scrolling:touch;background:#fff}.activities-table{width:100%;border-collapse:collapse;font-size:12px}.activities-table th{position:sticky;top:0;z-index:1;padding:7px 10px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap;pointer-events:none}.activities-table td{padding:6px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:#334155}.activities-table tbody tr:hover td{background:#f8fafc}.activities-table tr.activities-row-inactive td{color:#94a3b8}.activities-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11px;color:#0f172a}.activities-cell-muted{font-size:11px;color:#64748b;word-break:break-all}.activities-btn-toggle{padding:4px 10px;font-size:11px;font-weight:600;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:background .15s ease}.activities-btn-toggle.on{color:#fff;background:linear-gradient(180deg,#16a34a,#15803d);border-color:#15803d}.activities-btn-toggle.off{color:#475569;background:#f1f5f9;border-color:#e2e8f0}.activities-btn-toggle:disabled{opacity:.5;cursor:not-allowed}.activities-error{margin:0 12px 8px;padding:8px 10px;font-size:12px;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}@media(max-width:640px){.activities-toolbar{flex-direction:column;align-items:stretch}.activities-search{width:100%}}.activities-form.activities-form--users{grid-template-columns:repeat(2,minmax(0,1fr))}.activities-form.activities-form--users .activities-field-span{grid-column:1 / -1}.activities-form.activities-form--users .activities-form-actions{grid-column:1 / -1;justify-self:start}@media(max-width:900px){.activities-form.activities-form--users{grid-template-columns:1fr}}.activities-search--role{width:auto;min-width:132px;max-width:200px}.activities-toolbar-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.activities-toolbar-reset{padding:6px 10px;font-size:11px;font-weight:600;border-radius:8px;border:1px solid #e2e8f0;background:#f1f5f9;color:#334155;cursor:pointer;transition:background .15s ease,border-color .15s ease}.activities-toolbar-reset:hover{background:#e2e8f0}.users-actions .activities-btn-toggle.users-btn-danger{color:#b91c1c;border-color:#fecaca;background:#fef2f2}.users-actions .activities-btn-toggle.users-btn-danger:hover:not(:disabled){background:#fee2e2}.users-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}.workflow-block{padding:10px 12px;border-bottom:1px solid #f1f5f9}.workflow-block:last-child{border-bottom:none}.workflow-block-title{margin:0 0 4px;font-size:13px;font-weight:600;color:#0f172a}.workflow-block-desc{margin:0 0 10px;font-size:12px;color:#64748b;line-height:1.45;max-width:46rem}.workflow-preview-chips{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;font-size:11px}.workflow-chip{display:inline-flex;align-items:center;border-radius:9999px;padding:4px 10px;font-weight:600;border:1px solid #e2e8f0;background:#f8fafc;color:#334155}.workflow-chip--emp{border-color:#bbf7d0;background:#ecfdf5;color:#065f46}.workflow-chip--role{border-color:#bfdbfe;background:#eff6ff;color:#1e40af}.workflow-chip-arrow{color:#94a3b8;-webkit-user-select:none;user-select:none}.workflow-sequence-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.workflow-sequence-head-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.workflow-sequence-badge{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums;padding:3px 8px;border-radius:9999px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.workflow-step{display:grid;gap:8px;align-items:center;padding:8px 10px;border:1px solid #e2e8f0;border-radius:8px;background:#fafafa;grid-template-columns:auto 1fr auto auto}.workflow-step--fixed{grid-template-columns:auto 1fr auto;background:#f0fdf4;border-color:#bbf7d0}.workflow-step-num{width:28px;height:28px;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;background:#e0e7ff;color:#3730a3;flex-shrink:0}.workflow-step--fixed .workflow-step-num{background:#d1fae5;color:#047857}.workflow-step-body{min-width:0}.workflow-step-title{font-size:12px;font-weight:600;color:#0f172a}.workflow-step-hint{font-size:.65rem;color:#64748b;margin-top:2px}.workflow-step-list{display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-left:8px;border-left:2px solid #e2e8f0}.workflow-add-role{margin-top:8px;width:100%}.workflow-exception-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}.workflow-exception-toolbar .activities-search{flex:1;min-width:200px;max-width:none}.workflow-save-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid #f1f5f9}.workflow-save-row-hint{font-size:11px;color:#94a3b8;max-width:28rem;margin:0}.btn-solid{color:#fff!important;font-weight:600;text-shadow:0 1px 2px rgba(15,23,42,.6)}.approval-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);border-radius:.6rem;border:1px solid transparent;padding:.5rem .75rem;font-size:.78rem;font-weight:600;line-height:1.1;transition:background-color .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .08s ease}.approval-btn:hover:not(:disabled){transform:translateY(-1px)}.approval-btn:active:not(:disabled){transform:translateY(0)}.approval-btn:disabled{cursor:not-allowed;opacity:.55}.approval-btn-lg{padding:.75rem 1rem;font-size:.86rem}.approval-btn-sm{padding:.3rem .55rem;font-size:.68rem;border-radius:.45rem;font-weight:600}.approval-btn-sm.approval-btn-primary{box-shadow:0 3px 10px -6px #2563eba6}.approval-btn-sm.approval-btn-success{box-shadow:0 3px 10px -6px #16a34aa6}.approval-btn-sm.approval-btn-danger{box-shadow:0 3px 10px -6px #dc2626a6}.approval-btn-primary{color:#fff;background:linear-gradient(180deg,#3b82f6,#2563eb);box-shadow:0 6px 14px -8px #2563ebb3}.approval-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#2563eb,#1d4ed8)}.approval-btn-success{color:#fff;background:linear-gradient(180deg,#16a34a,#15803d);box-shadow:0 6px 14px -8px #16a34ab3}.approval-btn-success:hover:not(:disabled){background:linear-gradient(180deg,#15803d,#166534)}.approval-btn-danger{color:#fff;background:linear-gradient(180deg,#dc2626,#b91c1c);box-shadow:0 6px 14px -8px #dc2626b3}.approval-btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#b91c1c,#991b1b)}.approval-btn-ghost{color:#374151;border-color:#d1d5db;background:#fff}.approval-btn-ghost:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.approval-tabs{display:inline-flex;gap:var(--space-1);border:1px solid #dbe3ee;border-radius:9999px;padding:var(--space-1);background:linear-gradient(180deg,#f8fafc,#eef2f7)}.approval-tab{border:1px solid transparent;border-radius:9999px;padding:.42rem .9rem;font-size:.78rem;font-weight:600;color:#475569;background:transparent;transition:background-color .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease}.approval-tab:hover{background:#fff;color:#334155}.approval-tab.is-active{color:#fff;border-color:#1d4ed8;background:linear-gradient(180deg,#3b82f6,#2563eb);box-shadow:0 6px 14px -8px #2563eba6}.history-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-2)}.history-filter-field label{display:block;margin-bottom:.25rem;font-size:11px;font-weight:600;color:#4b5563}.history-input{width:100%;border:1px solid #d1d5db;border-radius:.4rem;padding:.4rem .55rem;font-size:12px;background:#fff;color:#111827}.history-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f666}.history-filter-user{grid-column:span 2}.history-filter-help{margin-top:.25rem;font-size:10px;color:#6b7280}.history-filter-actions{margin-top:var(--space-3);display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-2)}.history-export-btn{border:1px solid #d1d5db;border-radius:.4rem;background:#fff;color:#374151;padding:.42rem .7rem;font-size:12px;font-weight:600}.history-export-btn:hover:not(:disabled){background:#f3f4f6}.history-export-btn:disabled{cursor:not-allowed;opacity:.55}.project-step-btn{border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem 1rem;text-align:left;font-size:.875rem;color:#374151;background:#fff;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease,transform .08s ease}.project-step-btn:hover{border-color:#cbd5e1;background:#f8fafc}.project-step-btn.is-active{color:#1d4ed8;border-color:#93c5fd;background:#eff6ff;box-shadow:inset 0 0 0 1px #3b82f633}.punch-step-btn{position:relative;border:1px solid #dbe3ee;border-radius:.9rem;padding:.75rem 1rem;text-align:left;font-size:.86rem;color:#334155;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 1px #ffffffe6 inset,0 8px 18px -14px #0f172a73;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease,transform .1s ease,color .18s ease}.punch-step-btn:after{content:"";position:absolute;left:.75rem;right:.75rem;bottom:.48rem;height:2px;border-radius:9999px;background:transparent;transition:background-color .18s ease}.punch-step-btn:hover{border-color:#bfdbfe;background:linear-gradient(180deg,#fff,#eff6ff);transform:translateY(-1px);box-shadow:0 1px #fffffff2 inset,0 12px 24px -16px #2563eb80}.punch-step-btn.is-active{color:#1d4ed8;border-color:#93c5fd;background:linear-gradient(180deg,#eff6ff,#dbeafe);box-shadow:inset 0 0 0 1px #3b82f638,0 14px 24px -18px #2563eb99}.punch-step-btn.is-active:after{background:linear-gradient(90deg,#60a5fa,#2563eb)}.punch-field{width:100%;border:1px solid #d1d5db;border-radius:.6rem;padding:.6rem .75rem;font-size:.84rem;color:#111827;background:#fff;box-shadow:inset 0 1px #ffffffb3;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.punch-field:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f629;background:#fefeff}.punch-field:disabled{background:#f3f4f6;color:#6b7280}.punch-field-sm{padding:.5rem .75rem;font-size:.76rem;border-radius:.5rem}form{display:flex;flex-direction:column;gap:var(--space-3)}form .grid,form .flex,.history-filters-grid,.history-filter-actions,.edit-entry-modal .edit-actions{gap:var(--space-2)}form>.flex.justify-end,form>.edit-actions,form>.history-filter-actions{margin-top:var(--space-3)}.space-y-6>*+*{margin-top:var(--space-4)}.layout-stack{display:flex;flex-direction:column;gap:var(--space-4)}.section-stack{display:flex;flex-direction:column;gap:var(--space-3)}.button-group-tight{display:inline-flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.button-group{display:inline-flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.form-grid{display:grid;gap:var(--space-3)}.min-h-screen{min-height:100vh}.bg-gray-50{background-color:#f9fafb}.bg-white{background-color:var(--bg-card)}.text-gray-900{color:#111827}.text-gray-700{color:#374151}.text-gray-600{color:var(--text-muted)}.text-gray-500{color:#9ca3af}.text-red-700{color:#b91c1c}.text-blue-700{color:#1d4ed8}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-red-50{background-color:#fef2f2}.bg-red-600{background-color:#dc2626}.bg-red-700{background-color:#b91c1c}.bg-green-600{background-color:#16a34a}.bg-green-700{background-color:#15803d}.border{border-width:1px;border-style:solid;border-color:var(--border-subtle)}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-red-200{border-color:#fecaca}.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 10px 30px #0f172a14}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.08em}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.space-y-6>*+*{margin-top:1.5rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.inline-flex{display:inline-flex}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.w-full{width:100%}.max-w-md{max-width:28rem}.max-w-6xl{max-width:72rem}.min-h-\[60vh\]{min-height:60vh}.text-center{text-align:center}.block{display:block}.hidden{display:none}.mx-auto{margin-left:auto;margin-right:auto}.ml-2{margin-left:.5rem}.border-b{border-bottom:1px solid #e5e7eb}.overflow-hidden{overflow:hidden}.min-w-full{min-width:100%}.text-left{text-align:left}.text-right{text-align:right}.odd\:bg-white tr:nth-child(odd){background-color:#fff}.even\:bg-gray-50 tr:nth-child(2n){background-color:#f9fafb}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-red-700:hover{background-color:#b91c1c}.hover\:bg-green-700:hover{background-color:#15803d}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-blue-300:disabled{background-color:#93c5fd}.disabled\:bg-green-300:disabled{background-color:#86efac}.transition-transform{transition:transform .15s ease,box-shadow .15s ease}button:hover:not(:disabled){box-shadow:0 6px 18px #0f172a2e}.status-badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:9999px;padding:.15rem .6rem;font-size:.7rem;font-weight:500}.status-dot{width:.45rem;height:.45rem;border-radius:9999px}.status-draft{background-color:#e5e7eb;color:#374151}.status-draft .status-dot{background-color:#9ca3af}.status-submitted{background-color:#dbeafe;color:#1d4ed8}.status-submitted .status-dot{background-color:#2563eb}.status-approved{background-color:#dcfce7;color:#166534}.status-approved .status-dot{background-color:#16a34a}.status-rejected{background-color:#fee2e2;color:#b91c1c}.status-rejected .status-dot{background-color:#ef4444}header.site-header{position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translateZ(0);backface-visibility:hidden;background:linear-gradient(90deg,#eff6ff,#fdf2ff,#ecfeff);box-shadow:0 18px 40px #0f172a14}header.site-header nav a{border-radius:9999px}.nav-toggle{display:none}main{max-width:72rem;margin:0 auto}table{border-collapse:collapse}pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.8rem;overflow-x:auto;-webkit-overflow-scrolling:touch;background-color:#0f172a;color:#e5e7eb}thead{background:linear-gradient(90deg,#eff6ff,#ecfeff)}thead th{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af}tbody tr{border-top:1px solid rgba(229,231,235,.9)}tbody tr:hover{background-color:#f3f4f6}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b8b3;border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.director-approvals-table{min-width:760px}.admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:640px){body{font-size:14px}header.site-header .header-inner{flex-direction:column;align-items:flex-start;gap:.5rem}header.site-header .max-w-6xl{padding-left:.75rem;padding-right:.75rem}.main-nav{width:100%;justify-content:space-between;align-items:flex-start}.nav-toggle{display:inline-flex}.main-nav-links:not(.open){display:none}.main-nav-links.open{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;justify-content:flex-start;padding:.5rem .5rem .6rem;margin-top:.4rem;border-radius:.75rem;background-color:#fff;box-shadow:0 10px 25px #0f172a26;align-self:flex-start}header.site-header nav a,.main-nav-links button{padding:.35rem .6rem;font-size:.75rem}.logout-btn{margin-left:auto}main{padding:.75rem .75rem 1.5rem}section.rounded-lg{padding:var(--space-2)}form{gap:var(--space-2)}.layout-stack{gap:var(--space-3)}.section-stack{gap:var(--space-2)}.button-group{gap:var(--space-1)}form>.flex.justify-end,form>.edit-actions,form>.history-filter-actions{margin-top:var(--space-2)}table{font-size:.75rem}thead th,tbody td{padding-left:.4rem;padding-right:.4rem;word-break:break-word}.overflow-hidden{overflow-x:auto}section.rounded-lg p,section.rounded-lg li{word-break:break-word}.status-badge{font-size:.65rem;padding:.1rem .45rem;white-space:normal}.status-badge .status-dot{flex-shrink:0}.punch-table th:nth-child(3),.punch-table th:nth-child(4),.punch-table td:nth-child(3),.punch-table td:nth-child(4){display:none}.history-table th:nth-child(3),.history-table th:nth-child(4),.history-table td:nth-child(3),.history-table td:nth-child(4){display:none}.history-summary{text-align:left;align-items:flex-start}.punch-table,.history-table{width:640px}.punch-week-header{flex-direction:column;align-items:flex-start;gap:.35rem}.approvals-table th:nth-child(3),.approvals-table th:nth-child(4),.approvals-table td:nth-child(3),.approvals-table td:nth-child(4){display:none}.approvals-table{width:760px}.director-approvals-table{font-size:.7rem}.admin-table-wrapper table{min-width:720px;font-size:.8rem}.admin-table-wrapper th,.admin-table-wrapper td{padding-left:.5rem;padding-right:.5rem}pre{font-size:.7rem;padding:.5rem .75rem}}.edit-entry-overlay{z-index:9999;position:fixed;inset:0;background:#0f172a99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:.75rem;animation:edit-overlay-in .2s ease-out}@keyframes edit-overlay-in{0%{opacity:0}to{opacity:1}}.edit-entry-modal{position:relative;z-index:10000;max-height:96vh;overflow-y:auto;background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000f;padding:1.5rem;animation:edit-modal-in .25s ease-out}@keyframes edit-modal-in{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.edit-entry-modal .edit-modal-title{font-size:1.125rem;font-weight:600;color:#0f172a;margin-bottom:.25rem;letter-spacing:-.01em}.edit-entry-modal .edit-modal-hint{font-size:.8125rem;color:#64748b;margin-bottom:1.25rem;line-height:1.4}.edit-entry-overlay.project-picker-overlay{z-index:10050}.edit-entry-modal.project-picker-modal{display:flex;flex-direction:column;width:min(560px,94vw);max-height:min(88vh,680px);padding:0;overflow:hidden;border:1px solid #e2e8f0}.project-picker-modal__head{flex-shrink:0;padding:1.35rem 1.35rem 1.1rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(165deg,#fff,#f1f5f9 55%,#e8eef5);box-shadow:0 1px #ffffffe6 inset}.project-picker-modal__title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.project-picker-modal__title{margin:0;font-size:1.125rem;font-weight:700;letter-spacing:-.02em;color:#0f172a}.project-picker-modal__badge{flex-shrink:0;min-width:1.75rem;padding:.2rem .55rem;border-radius:9999px;font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.project-picker-modal__lede{margin:0 0 1rem;font-size:.8125rem;line-height:1.5;color:#475569}.project-picker-modal__lede strong{color:#334155;font-weight:600}.project-picker-search__label{display:block;margin-bottom:.4rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#64748b}.project-picker-search__field{display:flex;align-items:center;gap:.65rem;padding:.55rem .85rem;border-radius:.65rem;border:1px solid #cbd5e1;background:#fff;box-shadow:0 1px 2px #0f172a0a;transition:border-color .15s ease,box-shadow .15s ease}.project-picker-search__field:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.project-picker-search__icon{flex-shrink:0;display:flex;color:#94a3b8}.project-picker-search__input{flex:1;min-width:0;border:none;padding:0;font-size:.9375rem;color:#0f172a;background:transparent;outline:none}.project-picker-search__input::placeholder{color:#94a3b8}.project-picker-modal__kbd-hint{margin:.65rem 0 0;font-size:.6875rem;color:#94a3b8}.project-picker-modal__list-bar{display:flex;align-items:center;justify-content:space-between;flex-shrink:0;padding:.5rem 1rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0}.project-picker-modal__list-bar-count{font-variant-numeric:tabular-nums;color:#334155}.project-picker-modal__list-bar-sep{font-weight:500;color:#94a3b8}.project-picker-modal__list{flex:1;min-height:0;padding:.85rem 1rem 1rem;overflow-y:auto;overflow-x:hidden;background:#f1f5f9;-webkit-overflow-scrolling:touch}.project-picker-modal__list-inner{border-radius:.75rem;border:1px solid #cbd5e1;background:#fff;box-shadow:0 4px 14px -6px #0f172a1f,0 0 0 1px #ffffffe6 inset;overflow:hidden}.project-picker-modal__all-row{border-bottom:2px solid #e2e8f0;background:#f8fafc}.project-picker-row--all{background:#f8fafc!important;font-weight:600;color:#334155}.project-picker-row--all:hover,.project-picker-row--all:focus-visible{background:#f1f5f9!important}.project-picker-row__name--all{font-size:.9375rem}.project-picker-modal__ul{list-style:none;margin:0;padding:0}.project-picker-modal__empty{padding:2.25rem 1.25rem;text-align:center}.project-picker-modal__empty-title{margin:0 0 .5rem;font-size:.9375rem;font-weight:700;color:#334155}.project-picker-modal__empty-text{margin:0;font-size:.8125rem;line-height:1.55;color:#64748b}.project-picker-modal__empty-text strong{color:#475569}.project-picker-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;padding:.8rem 1rem;text-align:left;border:none;border-bottom:1px solid #f1f5f9;cursor:pointer;background:#fff;transition:background .12s ease,box-shadow .12s ease}.project-picker-row:last-child{border-bottom:none}.project-picker-row__content{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;flex:1;min-width:0}.project-picker-row__code-pill{display:inline-block;padding:.2rem .5rem;border-radius:.35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;font-weight:700;letter-spacing:.02em;color:#1e3a8a;background:linear-gradient(180deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe}.project-picker-row__name{font-size:.875rem;font-weight:500;line-height:1.4;color:#1e293b;word-break:break-word}.project-picker-row__check{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:9999px;color:#1d4ed8;background:#dbeafe}.project-picker-row__chev{flex-shrink:0;display:flex;color:#cbd5e1;transition:color .12s ease,transform .12s ease}.project-picker-row:hover .project-picker-row__chev,.project-picker-row:focus-visible .project-picker-row__chev{color:#64748b}.project-picker-row:hover,.project-picker-row:focus-visible{outline:none;background:#f8fafc;box-shadow:inset 3px 0 #3b82f6}.project-picker-row[aria-selected=true]{background:linear-gradient(90deg,#eff6ff,#fff 42%);box-shadow:inset 3px 0 #2563eb}.project-picker-row[aria-selected=true]:hover,.project-picker-row[aria-selected=true]:focus-visible{background:linear-gradient(90deg,#dbeafe,#fff 45%)}.project-picker-modal__footer{flex-shrink:0;display:flex;justify-content:flex-end;padding:.85rem 1.25rem 1.1rem;border-top:1px solid #e2e8f0;background:#fafbfc}.project-picker-btn-close{padding:.5rem 1.15rem;font-size:.875rem;font-weight:600;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:.5rem;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.project-picker-btn-close:hover{background:#f8fafc;border-color:#94a3b8;color:#334155}.ui-input.project-picker-trigger{transition:border-color .15s ease,box-shadow .15s ease}.ui-input.project-picker-trigger:hover:not(:disabled){border-color:#93c5fd;box-shadow:0 0 0 1px #3b82f61f}.edit-entry-modal .edit-field{margin-bottom:1rem}.edit-entry-modal .edit-field label{display:block;font-size:.8125rem;font-weight:500;color:#334155;margin-bottom:.375rem}.edit-entry-modal .edit-field input[type=date],.edit-entry-modal .edit-field input[type=time],.edit-entry-modal .edit-field input[type=text],.edit-entry-modal .edit-field input[type=search],.edit-entry-modal .edit-field input[type=number],.edit-entry-modal .edit-field input[type=password],.edit-entry-modal .edit-field select,.edit-entry-modal .edit-field textarea{width:100%;padding:.625rem .75rem;font-size:.9375rem;color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;transition:border-color .15s,box-shadow .15s}.edit-entry-modal .edit-field input:focus,.edit-entry-modal .edit-field select:focus,.edit-entry-modal .edit-field textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.edit-entry-modal .edit-field input[type=checkbox]{width:1rem;height:1rem;accent-color:#2563eb}.edit-entry-modal .edit-field .flex.items-center.gap-2{display:inline-flex;align-items:center;gap:.5rem}.edit-entry-modal .edit-field textarea{min-height:4rem;resize:vertical}.edit-entry-modal .edit-field .edit-field-hint{font-size:.75rem;color:#94a3b8;margin-top:.25rem}.edit-entry-modal .edit-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #e2e8f0}.edit-entry-modal .edit-actions .edit-btn-cancel{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:background .15s,color .15s}.edit-entry-modal .edit-actions .edit-btn-cancel:hover{background:#e2e8f0;color:#334155}.edit-entry-modal .edit-actions .edit-btn-save{padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:.5rem;cursor:pointer;transition:background .15s,transform .1s}.edit-entry-modal .edit-actions .edit-btn-save:hover:not(:disabled){background:#1d4ed8}.edit-entry-modal .edit-actions .edit-btn-save:disabled{opacity:.6;cursor:not-allowed}.edit-entry-modal .edit-fields-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.week-detail-overlay{z-index:9998}.week-detail-modal{width:min(1100px,94vw);max-width:94vw;max-height:92vh;padding:.75rem .875rem;border-radius:.75rem}.week-detail-modal .edit-modal-hint{margin-bottom:.5rem}@media(max-width:768px){.edit-entry-overlay{align-items:stretch;padding:0;background:#0f172a73;backdrop-filter:none;-webkit-backdrop-filter:none}.edit-entry-modal{max-height:100vh;border-radius:0}.week-detail-modal{width:100vw;max-width:100vw;max-height:100vh;padding:.5rem;border-radius:0}}.status-kpi-card{border:1px solid #e5e7eb;border-radius:.7rem;background:linear-gradient(180deg,#fff,#f8fafc);padding:.45rem .5rem;box-shadow:0 8px 20px -18px #0f172ab3;animation:status-card-in .26s ease both}.status-kpi-card-delay{animation-delay:80ms}@keyframes status-card-in{0%{opacity:0;transform:translateY(6px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}.status-kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.status-kpi-title{margin:0;font-size:12px;font-weight:600;color:#0f172a;letter-spacing:.01em}.status-kpi-total{border:1px solid #e2e8f0;border-radius:9999px;padding:.1rem .45rem;font-size:10px;font-weight:500;color:#475569;background:#fff}.status-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.28rem}.status-kpi-pill{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.3rem;border:1px solid #e2e8f0;border-radius:.48rem;padding:.24rem .38rem;min-height:24px;transition:transform .14s ease,box-shadow .16s ease,border-color .16s ease}.status-kpi-pill:hover{transform:translateY(-1px);box-shadow:0 8px 14px -12px #0f172aa6}.status-kpi-dot{width:6px;height:6px;border-radius:9999px;background:#94a3b8;animation:status-dot-pulse 1.8s ease-in-out infinite}@keyframes status-dot-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.25);opacity:1}}.status-kpi-label{font-size:10px;line-height:1;color:#475569;font-weight:500}.status-kpi-value{font-size:11px;line-height:1;font-weight:700;color:#0f172a}.status-kpi-pill-draft{background:#f8fafc;border-color:#e2e8f0}.status-kpi-pill-draft .status-kpi-dot{background:#94a3b8}.status-kpi-pill-pending{background:#fffbeb;border-color:#fde68a}.status-kpi-pill-pending .status-kpi-dot{background:#f59e0b}.status-kpi-pill-approved{background:#f0fdf4;border-color:#bbf7d0}.status-kpi-pill-approved .status-kpi-dot{background:#22c55e}.status-kpi-pill-rejected{background:#fef2f2;border-color:#fecaca}.status-kpi-pill-rejected .status-kpi-dot{background:#ef4444}@media print{@page{margin:10mm 12mm;size:auto}body.print-soucy-daily-report-only{background:#fff!important;min-height:0!important}html:has(body.print-soucy-daily-report-only){height:auto!important}body.print-soucy-daily-report-only .min-h-screen{min-height:0!important}body.print-soucy-daily-report-only .min-h-screen>header.site-header{display:none!important}body.print-soucy-daily-report-only main .layout-stack>*:not(.edit-entry-overlay){display:none!important}body.print-soucy-daily-report-only *{visibility:hidden}body.print-soucy-daily-report-only .soucy-daily-report,body.print-soucy-daily-report-only .soucy-daily-report *{visibility:visible}body.print-soucy-daily-report-only .edit-entry-modal>*:not(.soucy-daily-report):not(form){display:none!important}body.print-soucy-daily-report-only .edit-entry-modal form>*:not(.soucy-daily-report){display:none!important}body.print-soucy-daily-report-only .soucy-daily-report{position:relative!important;left:auto!important;top:auto!important;width:100%!important;min-width:0!important;max-width:100%!important;margin:0!important;padding:0!important;box-shadow:none!important;background:#fff!important}body.print-soucy-daily-report-only .edit-entry-overlay,body.print-soucy-daily-report-only .edit-entry-modal{position:static!important;display:block!important;max-height:none!important;height:auto!important;overflow:visible!important;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;box-shadow:none!important;border-radius:0!important;padding:0!important;animation:none!important;width:100%!important;max-width:100%!important}}@media print{body.print-weekly-payroll-only{background:#fff!important}body.print-weekly-payroll-only *{visibility:hidden}body.print-weekly-payroll-only .weekly-payroll-print-root,body.print-weekly-payroll-only .weekly-payroll-print-root *{visibility:visible}body.print-weekly-payroll-only .weekly-payroll-print-root{position:absolute;left:0;top:0;width:100%;max-width:100%;margin:0;padding:1rem;box-shadow:none!important;border:none!important;background:#fff!important}body.print-weekly-payroll-only .weekly-payroll-print-root .payroll-print-hide-btn{display:none!important}body.print-weekly-payroll-only .weekly-payroll-print-root details{break-inside:avoid}body.print-weekly-payroll-only .weekly-payroll-print-root .punchpro-logo-print{print-color-adjust:exact;-webkit-print-color-adjust:exact}}
