:root{font-family:Inter,system-ui,sans-serif;color:#0f172a;background:#f1f5f9;--c-dev: #2563eb;--c-test: #7c3aed;--c-design: #db2777;--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 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) 1fr minmax(52px,64px);align-items:start;gap:.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;gap:.5rem 1rem;font-size:.85rem}.chart-summary-item{display:inline-flex;align-items:center;gap:.35rem}.chart-summary-grand{margin-left:auto}.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-label{font-size:.88rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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{font-size:.8rem;color:#64748b;text-align:right}.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-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}
