:root{--font-sans:"SF Pro Text", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--bg:#f3f4f6;--bg-accent:#fafafa;--surface:#fffffff5;--surface-strong:#fff;--surface-muted:#fffc;--border:#11182714;--text:#1f2937;--muted:#6b7280;--headline:#111827;--accent:#111827;--accent-strong:#111827;--accent-soft:#1118270f;--success:#11885a;--success-soft:#11885a1f;--warning:#b45309;--warning-soft:#b453091f;--danger:#b42318;--danger-soft:#b423181f;--info:#2563eb;--info-soft:#2563eb1f;--shadow:0 6px 18px #0f172a0a;--radius-xl:12px;--radius-lg:9px;--radius-md:8px;--radius-sm:6px;--container:1280px;font-family:var(--font-sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#app{min-height:100%}body{background:var(--bg);min-height:100vh;margin:0}a{color:inherit}button,input,select,textarea{font:inherit}button{cursor:pointer}h1,h2,h3,h4,p{margin:0}#app{min-height:100vh}.shell{width:min(var(--container), 100%);margin:0 auto;padding:14px}.shell--employee{width:min(820px,100%);padding:10px}.shell__top{margin-bottom:12px;padding:2px 0}.shell__title{color:var(--headline);font-size:.95rem;font-weight:700}.status-badge{border:1px solid var(--border);color:var(--text);background:#ffffffe6;border-radius:14px;align-items:center;gap:8px;padding:6px 9px;font-size:.78rem;font-weight:600;display:inline-flex}.status-badge--neutral{background:#ffffffb8}.status-badge--success{background:var(--success-soft);color:var(--success);border-color:#11885a2e}.status-badge--warning{background:var(--warning-soft);color:var(--warning);border-color:#b453092e}.status-badge--danger{background:var(--danger-soft);color:var(--danger);border-color:#b423182e}.status-badge--info{background:var(--info-soft);color:var(--info);border-color:#2563eb2e}.shell__body{grid-template-columns:220px minmax(0,1fr);gap:12px;display:grid}.nav{align-self:start;gap:8px;display:grid;position:sticky;top:20px}.nav__link{border:1px solid var(--border);color:var(--muted);background:#ffffffb8;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-weight:600;text-decoration:none;transition:border-color .18s,background .18s,color .18s;display:flex}.nav__link--button{text-align:left;width:100%}.nav__link:hover{color:var(--text);border-color:#11182724}.nav__link--active{background:var(--surface-strong);color:var(--headline);border-color:#1118272e}.shell__content,.shell__content--employee{min-width:0}.page{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.page__header{border-bottom:1px solid var(--border);background:#ffffffeb;padding:14px 16px}.page__toolbar{justify-content:space-between;align-items:center;gap:10px;display:flex}.page__title{color:var(--headline);letter-spacing:-.02em;font-size:1.1rem;font-weight:700}.page__body{gap:12px;padding:14px 16px 16px;display:grid}.auth-page{max-width:440px;margin:48px auto 0}.auth-card{gap:14px;display:grid}.section-grid{gap:16px;display:grid}.card{border-radius:var(--radius-lg);background:#fffffffa;border:1px solid #11182714;padding:12px}.card--soft{background:#ffffff94}.card__header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.card__title{color:var(--headline);font-size:1rem;font-weight:700}.card__meta{color:var(--muted);margin-top:6px;font-size:.9rem;line-height:1.45}.list-grid{gap:10px;display:grid}.record-card{border-radius:var(--radius-lg);background:#fffffffa;border:1px solid #11182714;gap:10px;padding:12px;display:grid}.record-card__head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.record-card__eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.7rem;font-weight:700}.record-card h3{color:var(--headline);margin-top:4px;font-size:1rem}.record-card__meta{color:var(--muted);flex-wrap:wrap;gap:8px;font-size:.88rem;display:flex}.record-card__actions{flex-wrap:wrap;gap:10px;display:flex}.button{border:1px solid var(--border);min-height:36px;color:var(--text);background:#fffffffa;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-weight:600;text-decoration:none;transition:border-color .18s,background .18s,color .18s;display:inline-flex}.button:hover{border-color:#11182729}.button--accent{background:var(--accent);border-color:var(--accent);color:#fff}.button--ghost{background:0 0}.button--small{min-height:36px;padding:0 12px;font-size:.88rem}.button--danger{background:var(--danger-soft);color:var(--danger);border-color:#b4231824}.button:disabled{cursor:not-allowed;opacity:.55;box-shadow:none;transform:none}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.toolbar__group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.form-grid{gap:12px;display:grid}.form-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.field{gap:6px;display:grid}.field__label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.72rem;font-weight:700}.field input,.field select,.field textarea{background:var(--surface-strong);width:100%;color:var(--text);border:1px solid #11182724;border-radius:8px;padding:11px 12px;transition:border-color .18s,box-shadow .18s}.field input:focus,.field select:focus,.field textarea:focus{border-color:#d9770673;outline:none;box-shadow:0 0 0 4px #d977061f}.field textarea{resize:vertical;min-height:100px}.field__help{color:var(--muted);font-size:.92rem;line-height:1.45}.field__error{color:var(--danger);font-size:.9rem;line-height:1.45}.field__resolved{color:var(--muted);font-size:.85rem;line-height:1.35;display:block}.field__resolved-skeleton{background:linear-gradient(90deg,#11182714 0%,#11182724 50%,#11182714 100%) 0 0/200% 100%;border-radius:4px;width:min(280px,72%);height:.95rem;animation:1.15s linear infinite shimmer}.toggle{background:var(--surface-strong);border:1px solid #1118271f;border-radius:8px;align-items:center;gap:12px;min-height:44px;padding:12px;display:flex}.toggle input{width:18px;height:18px;margin:0}.notice{background:#ffffffeb;border:1px solid #11182714;border-radius:8px;gap:4px;padding:10px 12px;display:grid}.notice--info{background:var(--info-soft);border-color:#2563eb24}.notice--success{background:var(--success-soft);border-color:#11885a24}.notice--warning{background:var(--warning-soft);border-color:#b4530924}.notice__title{color:var(--headline);font-weight:700}.notice__text{color:var(--muted);font-size:.9rem;line-height:1.4}.table-shell{overflow-x:auto}.table{border-collapse:collapse;width:100%;min-width:920px}.table th,.table td{text-align:left;vertical-align:top;border-bottom:1px solid #11182714;padding:14px 12px}.table th{color:var(--muted);text-transform:uppercase;letter-spacing:.15em;font-size:.76rem;font-weight:800}.table__actions{flex-wrap:wrap;gap:10px;display:flex}.report-date{color:var(--muted);flex-wrap:wrap;align-items:baseline;gap:8px 14px;font-size:.95rem;font-weight:600;display:flex}.report-date__meta{color:#6b7280eb;font-size:.82rem;font-weight:500}.report-editor{gap:10px;display:grid}.report-row{border-radius:var(--radius-lg);background:#fffffffa;border:1px solid #11182714;gap:10px;padding:12px;display:grid}.report-row__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.report-row__head--actions{justify-content:flex-end}.report-row__fields{grid-template-columns:minmax(240px,1.15fr) minmax(280px,1fr) minmax(120px,.35fr);align-items:start;gap:10px;display:grid}.report-row__fields--no-hours{grid-template-columns:minmax(240px,1.15fr) minmax(280px,1fr)}.report-row__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.report-row__status{color:var(--muted);font-size:.92rem}.report-row__remove{margin-left:auto}.empty-state{border-radius:var(--radius-lg);text-align:center;background:#fffc;border:1px dashed #1118272e;place-items:center;gap:8px;padding:18px 14px;display:grid}.empty-state__title{color:var(--headline);font-size:1.05rem;font-weight:700}.empty-state__text{max-width:58ch;color:var(--muted);line-height:1.6}.stack{gap:12px;display:grid}.split{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=1080px){.shell__body{grid-template-columns:1fr}.nav{grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;position:static;overflow-x:auto}.nav__link{white-space:nowrap;justify-content:center}}@media (width<=840px){.shell{padding:16px}.shell__top,.page__toolbar,.card__header,.record-card__head,.report-row__head,.report-row__footer{flex-direction:column;align-items:stretch}.split,.form-grid--two,.report-row__fields,.report-row__fields--no-hours{grid-template-columns:1fr}.page__header,.page__body{padding:18px}.shell__top{align-items:flex-start}}
