:root{font-family:Inter,system-ui,sans-serif;color:#0f172a;background:#f1f5f9;--c-dev: #2563eb;--c-test: #7c3aed;--c-design: #db2777;--c-admin: #ea580c;--c-mgr: #0d9488}*{box-sizing:border-box}body{margin:0}.page{min-height:100vh;padding:2rem 1.5rem}.page-login{display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem}.login-card{width:100%;max-width:400px;margin:0 auto}.login-title{margin:0 0 .35rem;font-size:1.35rem;line-height:1.25}.login-subtitle{margin-bottom:0}.page-login .form{margin-top:1.5rem}.page-login .form input{width:100%;max-width:100%}.page-login .form button{width:100%}.page-login .error{margin-top:1rem}.page.dashboard{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:0}.dashboard-stack{display:flex;flex-direction:column;gap:.75rem}.card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0f172a14}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.topbar h1{margin:0 0 .25rem;font-size:1.35rem}.app-nav{display:flex;gap:.35rem;margin-bottom:.35rem}.nav-link{padding:.35rem .65rem;border-radius:8px;font-size:.92rem;font-weight:600;color:#64748b;text-decoration:none}.nav-link:hover{color:#0f172a;background:#f1f5f9}.nav-link.active{color:#0f172a;background:#e2e8f0}.user-line{margin:0;font-size:.85rem}.section-title{margin:0;font-size:1.15rem;line-height:1.3}.section-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem;margin:.65rem 0 1rem}.meta-pill{display:inline-flex;align-items:center;padding:.15rem .55rem;font-size:.78rem;font-weight:600;color:#334155;background:#f1f5f9;border-radius:999px}.meta-pill-muted{font-weight:500;color:#64748b;background:transparent;padding-left:0}.meta-link{font-size:.78rem;margin-left:.15rem}.status-line{margin:.75rem 0 0;font-size:.88rem;line-height:1.45}.page-footer{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #e2e8f0}.page-footer-details{font-size:.82rem;color:#64748b}.page-footer-summary{cursor:pointer;font-weight:600;color:#475569;-webkit-user-select:none;user-select:none}.page-footer-summary:hover{color:#0f172a}.page-footer-list{margin:.65rem 0 0;padding-left:1.15rem;line-height:1.5}.page-footer-list li{margin-bottom:.35rem}.page-footer-list li:last-child{margin-bottom:0}.page-footer-list code{font-size:.9em}.page-footer-list a{color:#0284c7}.link-btn{border:none;background:none;padding:0;color:#0284c7;font-size:inherit;cursor:pointer;text-decoration:underline}.settings-fieldset{border:none;margin:0 0 1rem;padding:0}.settings-fieldset-spaced{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #e2e8f0}.settings-checkbox{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer}.settings-checkbox input{margin-top:.2rem}.rates-hint{margin:0 0 .75rem}.rates-save-status{margin:.65rem 0 0;min-height:1.25rem}.rates-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.rates-row{display:grid;grid-template-columns:minmax(8rem,1fr) minmax(10rem,14rem);align-items:center;gap:.75rem}.rates-label{font-weight:500}.rates-input-wrap{display:flex;align-items:center;gap:.4rem}.rates-input{width:100%;max-width:8rem;padding:.4rem .55rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem}.rates-suffix{color:#64748b;font-size:.85rem;white-space:nowrap}@media (max-width: 520px){.rates-row{grid-template-columns:1fr;gap:.35rem}}.settings-fieldset legend{margin-bottom:.65rem}.settings-options{display:flex;flex-direction:column;gap:.55rem}.settings-radio{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer}.settings-radio input{margin-top:.2rem}.muted{color:#64748b;margin:0;font-size:.9rem}.form{display:flex;flex-direction:column;gap:.65rem;margin-top:1.25rem}.form label{font-size:.85rem;font-weight:500}.form input{padding:.55rem .65rem;border:1px solid #cbd5e1;border-radius:8px;font-size:1rem}.form button{margin-top:.5rem;padding:.65rem 1rem;border:none;border-radius:8px;background:#0f172a;color:#fff;font-weight:600;cursor:pointer}.form button:disabled{opacity:.6;cursor:default}.ghost{padding:.45rem .85rem;border-radius:8px;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-size:.9rem}.error{color:#b91c1c;font-size:.9rem;margin:0}.error-block{margin-top:.75rem}.error-block .status-line{margin-top:.35rem}.date-row{display:flex;flex-wrap:wrap;gap:1rem;margin:0 0 1rem}.date-row label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}.label-text{font-weight:600;color:#334155}.date-row input[type=date]{padding:.45rem .55rem;border:1px solid #cbd5e1;border-radius:8px}.group-by-row{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin-bottom:1rem}.segmented{display:inline-flex;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden}.segmented button{padding:.4rem .85rem;border:none;background:#fff;font-size:.88rem;font-weight:500;color:#475569;cursor:pointer}.segmented button+button{border-left:1px solid #cbd5e1}.segmented button.segmented-active{background:#0f172a;color:#fff}.chart{margin-top:.25rem}.legend{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin-bottom:1rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:#475569}.swatch{width:12px;height:12px;border-radius:3px}.bars{display:flex;flex-direction:column;gap:.85rem}.bar-row{display:grid;grid-template-columns:minmax(100px,180px) minmax(0,1fr) auto;align-items:start;gap:.65rem .75rem}.bar-row-expandable{cursor:pointer;border-radius:8px;margin:-.2rem -.35rem;padding:.2rem .35rem}.bar-row-expandable:hover{background:#f1f5f9}.bar-row-expanded.bar-row-expandable{background:#f8fafc}.bar-label{display:flex;align-items:center;gap:.25rem;min-width:0;font-size:.88rem;font-weight:500}.bar-label-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-label-nested{padding-left:.35rem}.chevron{flex-shrink:0;width:1rem;font-size:1.1rem;line-height:1;color:#94a3b8;transition:transform .15s ease;display:inline-block}.chevron-expanded{transform:rotate(90deg);color:#475569}.chart-drilldown-hint{margin:-.35rem 0 .75rem}.drilldown-project-block-expanded{padding-bottom:.15rem}.drilldown-people{margin:.15rem 0 .35rem .75rem;padding-left:.65rem;border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:.5rem}.drilldown-person-block{display:flex;flex-direction:column;gap:.25rem}.bar-row-nested{grid-template-columns:minmax(88px,160px) minmax(0,1fr) auto}.bar-track-nested{height:18px}.drilldown-tasks{list-style:none;margin:0 0 .25rem 1.65rem;padding:.35rem .5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;max-height:220px;overflow-y:auto}.drilldown-task-item{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto;gap:.1rem .75rem;padding:.35rem 0;font-size:.8rem;border-bottom:1px solid #eef2f7}.drilldown-task-item:last-child{border-bottom:none}.drilldown-task-title{grid-column:1;grid-row:1;font-weight:500;color:#334155;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drilldown-task-key{grid-column:1;grid-row:2}.drilldown-task-hours{grid-column:2;grid-row:1 / span 2;align-self:center;text-align:right;white-space:nowrap;color:#64748b}.drilldown-empty{margin:.15rem 0 .25rem 1.65rem}.bar-track-wrap{display:flex;flex-direction:column;gap:.3rem}.chart-summary{margin-bottom:.85rem;padding:.55rem .65rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.chart-summary-title{margin:0 0 .35rem}.chart-summary-totals{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;font-size:.85rem;width:100%}.chart-summary-item{display:inline-flex;align-items:center;gap:.35rem}.chart-summary-grand{margin-left:auto;white-space:nowrap;flex-shrink:0}.chart-money{color:#0f766e;font-weight:600}.bar-breakdown{display:flex;flex-wrap:wrap;gap:.25rem .65rem;font-size:.74rem;color:#64748b;line-height:1.35}.bar-breakdown-item{display:inline-flex;align-items:center;gap:.25rem}.swatch-inline{width:8px;height:8px;border-radius:2px;flex-shrink:0}.bar-track{height:22px;background:#e2e8f0;border-radius:6px;overflow:hidden}.bar-fill{height:100%;display:flex;border-radius:6px;overflow:hidden;min-width:2px}.segment{height:100%;min-width:2px;cursor:default;display:flex;align-items:center;justify-content:center;overflow:hidden}.segment-label{font-size:.62rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgb(15 23 42 / 45%);padding:0 2px;white-space:nowrap;overflow:hidden;text-overflow:clip;max-width:100%}.bar-total{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:.15rem;font-size:.8rem;color:#64748b;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;flex-shrink:0;padding-right:.1rem;line-height:1.25}.bar-total-money{font-size:.78rem;line-height:1.2}.users-panel{margin-top:0}.users-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin:.5rem 0 .85rem}.primary-btn{padding:.5rem .9rem;border:none;border-radius:8px;background:#0f172a;color:#fff;font-weight:600;font-size:.88rem;cursor:pointer}.primary-btn:disabled,.apply-btn:disabled{opacity:.45;cursor:not-allowed}.apply-btn{padding:.5rem .9rem;border:1px solid #0f172a;border-radius:8px;background:#fff;color:#0f172a;font-weight:600;font-size:.88rem;cursor:pointer}.apply-btn:not(:disabled){background:#e0f2fe;border-color:#0284c7}.reset-btn{padding:.5rem .9rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#64748b;font-weight:600;font-size:.88rem;cursor:pointer}.reset-btn:disabled{opacity:.45;cursor:not-allowed}.reset-btn:not(:disabled):hover{border-color:#94a3b8;color:#334155}.success-msg{color:#047857;margin:0 0 .5rem}.users-checklist{list-style:none;margin:0;padding:0;max-height:min(560px,58vh);overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px}.users-checklist li{border-bottom:1px solid #e2e8f0}.users-checklist li:last-child{border-bottom:none}.users-checklist li.dismissed{opacity:.55}.users-checklist li.user-special{opacity:.75}.user-check-row{display:flex;align-items:center;justify-content:space-between;gap:.65rem;padding:.55rem .75rem}.user-check-label{display:flex;align-items:flex-start;gap:.65rem;flex:1;min-width:0;cursor:pointer}.work-type-select{flex-shrink:0;max-width:9.5rem;padding:.3rem .4rem;font-size:.78rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155}.work-type-select:disabled{opacity:.45;cursor:not-allowed;background:#f1f5f9}.user-check-label input{margin-top:.2rem;flex-shrink:0}.user-check-main{display:flex;flex-direction:column;gap:.15rem;min-width:0}.user-check-name{font-weight:500}.user-check-meta{font-size:.85rem}.panel-toggle{display:flex;width:100%;justify-content:space-between;align-items:center;gap:.75rem;border:none;background:none;padding:0;font-size:1rem;font-weight:600;cursor:pointer;color:inherit;text-align:left}.panel-toggle-text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.panel-collapsed-summary{font-size:.85rem;font-weight:500;color:#047857}.panel-collapsed-summary.panel-collapsed-dirty{color:#b45309}.panel-chevron{flex-shrink:0}.filter-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.chip-btn{padding:.35rem .7rem;border:1px solid #cbd5e1;border-radius:999px;background:#fff;font-size:.82rem;cursor:pointer;color:#334155}.chip-btn:hover{border-color:#94a3b8}.chip-btn-active{background:#0f172a;border-color:#0f172a;color:#fff}.chip-btn-group{border-style:dashed}.filter-row{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem 1rem;margin-bottom:.75rem}.filter-row .filter-chips{margin-bottom:0;flex:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;padding:1.25rem 1.5rem;box-shadow:0 12px 40px #0f172a33}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}.modal-header h2{margin:0;font-size:1.1rem}.modal-checklist{max-height:280px;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.groups-list{list-style:none;margin:0 0 1rem;padding:0;border:1px solid #e2e8f0;border-radius:8px}.groups-list-item{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.6rem .75rem;border-bottom:1px solid #e2e8f0}.groups-list-item:last-child{border-bottom:none}.groups-list-actions{display:flex;gap:.35rem;flex-shrink:0}.danger-text{color:#b91c1c}.form-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.form-field input{padding:.5rem .65rem;border:1px solid #cbd5e1;border-radius:8px}.users-search{width:100%;max-width:360px;margin:0 0 .4rem;padding:.5rem .65rem;border:1px solid #cbd5e1;border-radius:8px}.list-stats{margin:0 0 .5rem;font-size:.82rem}.dirty-hint{color:#b45309;font-weight:600}.users-table-wrap{overflow-x:auto;max-height:320px;overflow-y:auto}.users-table{width:100%;border-collapse:collapse;font-size:.88rem}.users-table th,.users-table td{text-align:left;padding:.45rem .5rem;border-bottom:1px solid #e2e8f0;vertical-align:top}.users-table tr.dismissed{opacity:.55}.users-table code{font-size:.85em}.tag{margin-left:.35rem;font-size:.75rem;color:#b45309}.small{font-size:.8rem}.small-btn{font-size:.78rem;padding:.25rem .5rem;white-space:nowrap}.hours-section{position:relative}.hours-section-head{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.hours-section-head .section-title{margin-bottom:0}.hours-refresh-btn{margin-left:auto}.hours-refresh-badge{font-size:.82rem;font-weight:600;color:#0369a1;background:#e0f2fe;padding:.2rem .55rem;border-radius:999px}.hours-section-refreshing .chart-dimmed{opacity:.55;pointer-events:none;transition:opacity .15s ease}.hours-refresh-hint{color:#0369a1;font-weight:500}.activity-log-panel{margin-top:0}.activity-log-panel .activity-log-viewport{margin-top:.65rem}.activity-log-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem}.activity-log-toggle{flex:1;margin:0;padding:0;border:none;background:none;font:inherit;font-weight:600;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;text-align:left}.activity-log-viewport{max-height:280px;overflow:auto;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;padding:.5rem .65rem}.activity-log-list{list-style:none;margin:0;padding:0}.log-line{font-size:.82rem;line-height:1.4;padding:.35rem 0;border-bottom:1px solid #e2e8f0}.log-line:last-child{border-bottom:none}.log-time{display:inline-block;min-width:4.5rem;color:#64748b;font-variant-numeric:tabular-nums;margin-right:.35rem}.log-msg{word-break:break-word}.log-line-success .log-msg{color:#047857}.log-line-error .log-msg{color:#b91c1c;font-weight:600}.log-line-warn .log-msg{color:#b45309}.log-detail{margin:.35rem 0 0 4.85rem;padding:.45rem .55rem;font-size:.75rem;background:#fff;border:1px solid #fecaca;border-radius:6px;white-space:pre-wrap;word-break:break-word;max-height:120px;overflow:auto}.log-empty{margin:.5rem 0;font-size:.85rem}.calendar-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,300px);gap:1rem;align-items:start}.calendar-main{min-width:0}.calendar-main-head{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem}.calendar-main-head .calendar-month-nav{flex:1;min-width:200px}.calendar-month-nav{display:flex;align-items:center;gap:.5rem;background:#334155;color:#f8fafc;border-radius:8px;padding:.5rem .65rem}.calendar-month-title{flex:1;margin:0;text-align:center;font-size:1.15rem;font-weight:600}.calendar-nav-btn{color:#f8fafc;border-color:#64748b;background:transparent;min-width:2.25rem;padding:.35rem .5rem}.calendar-nav-btn:hover:not(:disabled){background:#475569}.calendar-nav-btn:disabled{opacity:.35}.calendar-grid-wrap{margin-top:.25rem}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px}.calendar-weekday{text-align:center;font-size:.72rem;font-weight:700;color:#475569;padding:.35rem 0}.calendar-weekday-off{color:#dc2626}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:#e2e8f0;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.calendar-day{position:relative;min-height:72px;background:#fff;padding:.35rem .4rem;display:flex;flex-direction:column;gap:.2rem}.calendar-day-pad{background:#f8fafc;min-height:72px}.calendar-day-off{background:#fff7f7}.calendar-day-future{background:#f8fafc}.calendar-day-has-hours .calendar-day-hours{color:#15803d;font-weight:700;font-size:.95rem;line-height:1.2}.calendar-day-num{align-self:flex-end;font-size:.8rem;font-weight:600;color:#334155}.calendar-day-num-off{color:#dc2626}.calendar-day-future .calendar-day-num{color:#94a3b8}.calendar-day-hours{margin-top:auto;font-size:.85rem}.calendar-day-person-btn{position:absolute;top:.2rem;left:.2rem;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;padding:0;border:none;border-radius:4px;background:#e2e8f0;color:#475569;cursor:pointer}.calendar-day-person-btn:hover,.calendar-day-person-btn-active{background:#cbd5e1;color:#1e293b}.calendar-day-person-btn-pinned{background:#334155;color:#f8fafc}.calendar-day-person-svg{width:.85rem;height:.85rem;display:block}.calendar-day-people-tooltip-title{margin:0 0 .35rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#94a3b8}.calendar-day-people-tooltip-list li{gap:.5rem}.calendar-day-tooltip{min-width:160px;max-width:min(240px,calc(100vw - 24px));padding:.45rem .55rem;background:#1e293b;color:#f8fafc;border-radius:8px;box-shadow:0 8px 24px #0f172a40;pointer-events:none}.calendar-day-tooltip-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem;font-size:.78rem}.calendar-day-tooltip-list li{display:flex;align-items:center;gap:.35rem}.calendar-day-tooltip-list strong{margin-left:auto;font-weight:600}.calendar-sidebar{position:sticky;top:.5rem;max-height:calc(100vh - 6rem);display:flex;flex-direction:column;min-height:280px}.calendar-sidebar-title{margin:0 0 .35rem;font-size:1rem}.calendar-sidebar-hint{margin:0 0 .65rem}.calendar-filter-search{width:100%;margin-bottom:.5rem;padding:.4rem .55rem;border:1px solid #cbd5e1;border-radius:8px;font-size:.88rem}.calendar-filter-actions{display:flex;gap:.4rem;margin-bottom:.5rem}.calendar-filter-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1;min-height:0}.calendar-filter-item{display:flex;align-items:center;gap:.45rem;padding:.3rem 0;font-size:.88rem;cursor:pointer}.calendar-filter-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-main-refreshing .calendar-dimmed{opacity:.55;pointer-events:none;transition:opacity .15s ease}@media (max-width: 900px){.calendar-layout{grid-template-columns:1fr}.calendar-sidebar{position:static;max-height:none}}
