*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #22c55e;--green-bg: #dcfce7;--yellow: #f59e0b;--yellow-bg: #fef3c7;--red: #ef4444;--red-bg: #fee2e2;--blue: #3b82f6;--blue-bg: #eff6ff;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 25px rgba(0,0,0,.12);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--surface-2);font-size:14px}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:1.5rem 1rem}.app-header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:50}.header-inner{max-width:1200px;margin:0 auto;padding:1rem 1rem 0;display:flex;justify-content:space-between;align-items:flex-start}.app-title{font-size:1.25rem;font-weight:700;color:var(--text)}.app-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:2px}.header-scenario-badge{background:var(--blue-bg);color:var(--blue);padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600;margin-top:.25rem}.tabs{max-width:1200px;margin:0 auto;display:flex;padding:0 1rem;border-top:1px solid var(--border);margin-top:.75rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.6rem 1.1rem;border:none;background:transparent;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;position:relative;white-space:nowrap;flex-shrink:0}.tab:hover{color:var(--text)}.tab-active{color:var(--blue);border-bottom-color:var(--blue)}.tab-dot{position:absolute;top:6px;right:4px;width:6px;height:6px;border-radius:50%;background:var(--blue)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.section-header h2{font-size:1.1rem;font-weight:700}.section-subtitle{color:var(--text-muted);font-size:.85rem;margin:0 0 1rem}.btn{padding:.45rem .9rem;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;transition:background .15s,border-color .15s}.btn:hover{background:var(--surface-2);border-color:#cbd5e1}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.btn-danger{border-color:#fca5a5;color:var(--red)}.btn-danger:hover{background:var(--red-bg)}.btn-sm{padding:.3rem .65rem;font-size:.8rem}.card-list{display:flex;flex-direction:column;gap:.6rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;box-shadow:var(--shadow)}.card-main{flex:1;min-width:0}.card-name{font-weight:600;margin-bottom:.35rem}.card-meta{display:flex;flex-wrap:wrap;gap:.5rem;color:var(--text-muted);font-size:.82rem;align-items:center}.card-demand{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.card-notes{color:var(--text-muted);font-style:italic}.card-actions{display:flex;gap:.4rem;flex-shrink:0}.role-badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600}.role-pm{background:#ede9fe;color:#7c3aed}.role-tdm{background:#e0f2fe;color:#0369a1}.role-sdm{background:#f0fdf4;color:#15803d}.role-learning-administrator{background:#fff7ed;color:#c2410c}.role-consultant{background:#f1f5f9;color:#475569}.tag{display:inline-block;padding:.15rem .5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;font-size:.75rem}.demand-chip{background:#f1f5f9;border:1px solid var(--border);border-radius:4px;padding:.15rem .45rem;font-size:.75rem;font-weight:500}.demand-chip-scenario{background:var(--blue-bg);border-color:#bfdbfe;color:#1d4ed8}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.form-card h3{font-size:1rem;font-weight:700;margin-bottom:1rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:500}.form-grid .full-width{grid-column:1 / -1}.form-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:0}.form-grid-2col label{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:500}.form-grid-2col .span-2{grid-column:1 / -1}.edit-form-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start;margin-bottom:.75rem}.edit-col-left,.edit-col-right{display:flex;flex-direction:column;gap:.75rem}@media (max-width: 700px){.edit-form-layout{grid-template-columns:1fr}}input,select,textarea{padding:.45rem .65rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;color:var(--text);background:var(--surface);width:100%}input:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #3b82f633}.form-actions{display:flex;gap:.5rem}.demand-table-wrapper{margin-bottom:1rem}.demand-table-wrapper h4{font-size:.85rem;font-weight:600;margin-bottom:.5rem}.demand-table{width:100%;border-collapse:collapse}.demand-table th{text-align:left;font-size:.8rem;font-weight:600;color:var(--text-muted);padding:.4rem .5rem;border-bottom:1px solid var(--border)}.demand-table td{padding:.4rem .5rem}.units-input{width:70px}.month-week-row{display:flex;gap:.4rem;align-items:center}.month-week-row input[type=month]{flex:1}.week-select{font-size:.8rem;padding:.3rem .4rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);cursor:pointer;white-space:nowrap}.heatmap-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.heatmap{border-collapse:collapse;width:100%;min-width:600px}.heatmap th{background:var(--surface);padding:.5rem .6rem;text-align:left;font-size:.78rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap}.heatmap-name-col{min-width:120px}.heatmap-month-col{min-width:80px;text-align:center}.heatmap-name{padding:.6rem;font-weight:600;vertical-align:top}.heatmap-cap{font-size:.72rem;font-weight:400;color:var(--text-muted);margin-top:2px}.heatmap-cell{text-align:center;padding:.5rem .4rem;cursor:pointer;transition:opacity .1s;border:1px solid rgba(255,255,255,.4);min-width:66px}.heatmap-cell:hover{opacity:.8;filter:brightness(.95)}.heatmap-green{background:var(--green-bg);color:#166534}.heatmap-yellow{background:var(--yellow-bg);color:#92400e}.heatmap-red{background:var(--red-bg);color:#991b1b}.cell-pct{font-size:.82rem;font-weight:600;display:block}.heatmap-spof{outline:2px dashed var(--yellow);outline-offset:-2px}.spof-dot{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--yellow);color:#fff;border-radius:50%;font-size:.65rem;font-weight:700;margin-left:4px}.scenario-badge{background:var(--blue-bg);color:var(--blue);padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600}.legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;font-size:.78rem;color:var(--text-muted);align-items:center}.legend-item{display:flex;align-items:center;gap:.35rem}.legend-note{font-size:.72rem;color:var(--text-muted);margin-left:auto;font-style:italic}.legend-swatch{display:inline-block;width:16px;height:16px;border-radius:3px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1rem;font-weight:700}.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted)}.modal-body{padding:1.25rem}.modal-stat{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.modal-stat:last-of-type{border-bottom:none}.util-green{color:#166534}.util-yellow{color:#92400e}.util-red{color:#991b1b}.detail-table{width:100%;border-collapse:collapse;font-size:.82rem}.detail-table th{text-align:left;padding:.4rem .5rem;border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.78rem}.detail-table td{padding:.35rem .5rem;border-bottom:1px solid var(--border)}.detail-table tr:last-child td{border-bottom:none}.scenario-row{background:var(--blue-bg)}.scenario-empty{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);padding:2rem;text-align:center;color:var(--text-muted)}.scenario-empty p{margin-bottom:1rem}.cc-builder{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem}.cc-scenario-card{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:var(--radius);background:#f8fafc;border:1px solid var(--border)}.cc-scenario-info{flex:1;min-width:0}.cc-scenario-name{font-weight:700;font-size:.95rem;margin-bottom:.25rem}.cc-scenario-actions{display:flex;gap:.5rem;flex-shrink:0}.cc-results{margin-bottom:1.25rem}.cc-forecast-zone{margin-top:1.5rem}.decision-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border-radius:var(--radius);padding:1rem 1.25rem;border:1px solid;margin-bottom:.5rem}.decision-banner-text{flex:1}.decision-yes{background:var(--green-bg);border-color:#86efac}.decision-risk{background:var(--yellow-bg);border-color:#fcd34d}.decision-no{background:var(--red-bg);border-color:#fca5a5}.decision-label{font-weight:700;font-size:1rem;margin-bottom:.35rem}.decision-detail{font-size:.85rem}.cc-commit-btn{flex-shrink:0;align-self:center}.impact-wrap{margin-top:1rem}.impact-heading{font-weight:700;font-size:.88rem;color:var(--text);margin-bottom:.5rem}.impact-table-scroll{overflow-x:auto}.impact-table{border-collapse:collapse;width:100%}.impact-th-person,.impact-th-month{padding:.35rem .75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap}.impact-th-month{text-align:center}.impact-person-cell{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.82rem;font-weight:500;white-space:nowrap;border-bottom:1px solid var(--border)}.impact-person-affected{font-weight:700}.impact-cell{text-align:center;padding:.4rem .6rem;font-size:.82rem;font-weight:600;border-bottom:1px solid var(--border)}.impact-empty{color:var(--text-muted);font-weight:400}.impact-green{background:#dcfce7;color:#166534}.impact-yellow{background:#fef9c3;color:#854d0e}.impact-red{background:#fee2e2;color:#991b1b}.impact-delta{font-size:.7rem;margin-left:.25rem;opacity:.75}.forecast-arrow{color:var(--text-muted);font-weight:400;font-size:.8rem}.forecast-scenario-note{color:#7c3aed;background:#f5f3ff;border-radius:4px;padding:.25rem .5rem}.scenario-hint{margin-top:1rem;font-size:.82rem;color:var(--text-muted);padding:.75rem 1rem;background:var(--blue-bg);border-radius:var(--radius)}.empty-state{color:var(--text-muted);font-style:italic;padding:1rem 0}.template-picker{background:var(--blue-bg);border:1px solid #bfdbfe;border-radius:var(--radius);padding:.9rem 1rem;margin-bottom:.75rem;display:flex;flex-direction:column;gap:.4rem}.template-picker label{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:600}.template-picker select{max-width:100%}.template-hint{font-size:.78rem;color:#1d4ed8;margin:0}.field-hint{display:block;font-size:.72rem;color:var(--text-muted);margin-top:.2rem;font-style:italic}.form-section{margin-bottom:1.25rem}.form-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:.3rem;margin-bottom:.75rem}.confidence-toggle{display:inline-flex;border:1px solid var(--border);border-radius:5px;overflow:hidden}.confidence-btn{padding:.2rem .45rem;font-size:.72rem;font-weight:600;border:none;border-right:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s}.confidence-btn:last-child{border-right:none}.confidence-btn:hover{background:var(--surface);color:var(--text)}.confidence-btn-known.confidence-btn-active{background:#dcfce7;color:#15803d}.confidence-btn-some.confidence-btn-active{background:#fef9c3;color:#854d0e}.confidence-btn-high.confidence-btn-active{background:#fee2e2;color:#b91c1c}.demand-empty{font-size:.82rem;color:var(--text-muted);margin:0 0 .5rem}.demand-add-role{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}.demand-add-label{font-size:.72rem;color:var(--text-muted);font-weight:600}.demand-add-btn{font-size:.75rem;padding:.2rem .55rem;border:1px dashed var(--border);border-radius:5px;background:none;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s}.demand-add-btn:hover{border-color:var(--text-muted);color:var(--text)}.add-support-btn{font-size:.75rem;padding:.2rem .55rem;border:1px dashed var(--border);border-radius:5px;background:none;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s;margin-top:.25rem;align-self:flex-start}.add-support-btn:hover{border-color:var(--text-muted);color:var(--text)}.phase2-start-label{display:flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600}.addon-section{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid #bfdbfe}.addon-label{font-size:.82rem;font-weight:600;color:var(--text)}.addon-list{display:flex;flex-direction:column;gap:.35rem}.addon-checkbox{display:flex;align-items:baseline;gap:.5rem;font-size:.85rem;font-weight:500;cursor:pointer}.addon-checkbox input[type=checkbox]{width:auto;flex-shrink:0;cursor:pointer;accent-color:var(--blue)}.addon-demand-preview{font-size:.75rem;color:#1d4ed8;font-weight:400;background:#dbeafe;padding:.1rem .4rem;border-radius:4px;margin-left:.25rem}.card-section{display:flex;flex-direction:column;gap:.3rem;margin-top:.55rem}.card-section-label{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.card-section-body{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.service-chip{font-size:.76rem;padding:.2rem .6rem;border-radius:999px;font-weight:500}.service-chip-base{background:#e0f2fe;color:#0369a1}.service-chip-addon{background:#ede9fe;color:#7c3aed}.team-demand-section{margin-top:.25rem}.td-table{display:flex;flex-direction:column}.td-header{display:grid;grid-template-columns:155px 1fr 68px 96px 126px;gap:.5rem;padding:0 0 .3rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:.15rem}.td-header span:nth-child(3),.td-header span:nth-child(4){text-align:right}.td-role-group{display:flex;flex-direction:column;gap:.15rem;padding:.45rem 0;border-bottom:1px solid var(--border)}.td-role-group:last-child{border-bottom:none}.td-row{display:grid;grid-template-columns:155px 1fr 68px 96px 126px;gap:.5rem;align-items:center}.td-total-cell{display:inline-flex;align-items:center;gap:.25rem}.td-total-cell input{width:52px;text-align:right}.td-total-hours{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.td-annotation{grid-column:1 / -1;font-size:.75rem;font-style:italic;color:var(--text-muted);padding-left:1rem}.td-support-row{padding-left:1rem}.td-support-label{font-size:.78rem;font-weight:500;color:var(--text-muted)}.assignment-chip{display:inline-flex;align-items:center;gap:.3rem;font-size:.76rem;padding:.2rem .6rem;background:#f8fafc;border:1px solid var(--border);border-radius:999px;font-weight:500}.chip-role-label{font-weight:700;color:var(--text-muted);font-size:.72rem}.role-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.role-dot.role-pm{background:#7c3aed}.role-dot.role-tdm{background:#0369a1}.role-dot.role-sdm{background:#15803d}.role-dot.role-learning-administrator{background:#c2410c}.role-dot.role-consultant{background:#475569}.project-ref-chip{display:inline-flex;align-items:center;gap:.3rem;font-size:.76rem;padding:.2rem .6rem;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;font-weight:500}.project-ref-dates{color:var(--text-muted);font-weight:400;font-size:.7rem;margin-left:.15rem}.unassigned-note{font-size:.78rem;color:var(--text-muted);font-style:italic}.status-badge{font-size:.72rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.status-active{background:#dcfce7;color:#15803d}.status-upcoming{background:#dbeafe;color:#1d4ed8}.status-hold{background:#fef9c3;color:#b45309}.status-complete{background:#f1f5f9;color:#64748b}.filter-bar{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.filter-tab{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:500;padding:.25rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;line-height:1}.filter-tab:hover{border-color:var(--blue);color:var(--blue)}.filter-tab-active{background:var(--blue);color:#fff;border-color:var(--blue)}.filter-tab-active:hover{color:#fff}.filter-count{font-size:.7rem;background:#0000001f;padding:.05rem .35rem;border-radius:999px;font-weight:600}.filter-tab-active .filter-count{background:#ffffff40}.filter-secondary{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.65rem}.filter-secondary label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;color:var(--text-muted)}.filter-secondary select{font-size:.8rem;padding:.22rem .5rem;border-radius:4px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.project-card.is-editing,.template-card.is-editing{border-color:var(--blue);background:var(--blue-bg);flex-direction:column}.card-edit-header{display:flex;align-items:center;margin-bottom:.6rem;padding-bottom:.5rem;border-bottom:1px solid #bfdbfe}.card-edit-label{font-size:.82rem;font-weight:700;color:#1d4ed8}.people-card-top{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.5rem}.people-card-identity{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.people-card-stats{display:flex;align-items:center;flex-wrap:wrap;gap:.3rem;font-size:.78rem;color:var(--text-muted)}.stats-dot{color:var(--border)}.people-notes{font-style:italic;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}.assignment-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;cursor:pointer;padding:.35rem 0;text-align:left;gap:.5rem}.assignment-toggle:hover .card-section-label{color:var(--text)}.toggle-chevron{font-size:.65rem;color:var(--text-muted);flex-shrink:0}.assignment-list{display:flex;flex-direction:column;gap:.3rem;padding:.3rem 0 .15rem}.assignment-status-dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-left:.1rem}.heatmap-col-current{border-left:2px solid var(--blue)!important;border-right:2px solid var(--blue)!important}th.heatmap-col-current{color:var(--blue);font-weight:700}.support-tag{font-size:.65rem;font-weight:700;background:#ede9fe;color:#7c3aed;border-radius:3px;padding:.05rem .3rem;letter-spacing:.03em}.support-col-header{color:var(--text-muted);font-style:italic}.support-input{opacity:.8}.phase2-section{margin-bottom:1rem}.phase2-toggle-btn{border-style:dashed;color:var(--text-muted)}.phase2-toggle-btn:hover{color:var(--blue);border-color:var(--blue)}.phase2-header{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.5rem}.phase2-header h4{font-size:.85rem;font-weight:600;margin:0}.phase2-header input[type=month]{width:auto}.phase2-auto-summary{display:flex;align-items:flex-start;gap:.75rem;justify-content:space-between}.phase2-auto-info{font-size:.85rem;color:var(--text-muted);line-height:1.5}.phase2-auto-info p{margin:0 0 .25rem}.phase2-auto-info strong{color:var(--text)}.tag-phase2{background:#fef9c3;border-color:#fcd34d;color:#92400e}.tag-sow-linked{background:#dcfce7;border-color:#86efac;color:#166534}.tag-sow-missing{background:#fef3c7;border-color:#fcd34d;color:#92400e}.tag-sow-suggest{background:#fef3c7;border-color:#fcd34d;color:#92400e;font-style:italic}.tag-actuals{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.tag-actuals-none{background:var(--surface-2);border-color:var(--border);color:var(--text-muted)}.tag-health{background:#ecfdf5;border-color:#6ee7b7;color:#065f46}.tag-health-warn{background:#fffbeb;border-color:#fcd34d;color:#92400e}.tag-health-over{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.tag-escalation{background:#fef2f2;border-color:#fca5a5;color:#991b1b;font-weight:600}.pva-table{width:100%;font-size:.8rem;border-collapse:collapse;margin-top:.25rem}.pva-table th,.pva-table td{padding:.2rem .5rem}.pva-table th{font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border)}.pva-total td{border-top:1px solid var(--border)}.pva-over{color:#dc2626}.pva-under{color:#166534}.header-brand{display:flex;align-items:center;gap:.75rem}.app-logo{height:40px;width:auto;flex-shrink:0}.app-tagline{font-size:.8rem;color:var(--text-muted);font-style:italic;white-space:nowrap}.services-editor{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid #bfdbfe}.services-chip-list{display:flex;flex-wrap:wrap;gap:.35rem;min-height:1.5rem}.service-chip-editable{display:inline-flex;align-items:center;gap:.3rem;font-size:.76rem;padding:.2rem .5rem .2rem .65rem;background:#e0f2fe;color:#0369a1;border-radius:999px;font-weight:500}.service-chip-remove{background:none;border:none;cursor:pointer;color:#0369a1;font-size:.9rem;line-height:1;padding:0 .1rem;opacity:.6}.service-chip-remove:hover{opacity:1}.service-add-row{display:flex;gap:.4rem;align-items:center}.service-add-row input{flex:1;max-width:340px;font-size:.82rem;padding:.3rem .55rem}.settings-accordion{border:1px solid var(--border);border-radius:8px;margin-bottom:.75rem;background:var(--surface)}.settings-accordion-trigger{width:100%;display:flex;align-items:center;gap:.5rem;padding:.85rem 1rem;border:none;background:none;cursor:pointer;text-align:left;font-family:inherit}.settings-accordion-title{font-size:.95rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem}.settings-accordion-badge{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--hover-bg);padding:.1rem .45rem;border-radius:10px}.settings-accordion-subtitle{flex:1;font-size:.8rem;color:var(--text-muted);margin-left:.25rem}.settings-accordion-chevron{font-size:.85rem;color:var(--text-muted);transition:transform .15s;flex-shrink:0}.settings-accordion-chevron.is-open{transform:rotate(90deg)}.settings-accordion-body{padding:0 1rem 1rem;border-top:1px solid var(--border)}.template-section{margin-bottom:2rem}.template-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.template-section-header h3{font-size:.95rem;font-weight:700}.template-edit-form{width:100%}.forecast-legend{display:flex;flex-direction:column;gap:.6rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem}.forecast-legend-item{display:flex;align-items:flex-start;gap:.6rem;font-size:.85rem}.forecast-type-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:.25rem}.forecast-dot-combined{background:#0f766e}.forecast-dot-functional{background:#1d4ed8}.forecast-dot-technical{background:#7c3aed}.forecast-pool{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.secondary-roles-field{display:flex;flex-direction:column;gap:.35rem}.field-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.secondary-roles-checks{display:flex;flex-wrap:wrap;gap:.5rem .75rem}.secondary-role-check{display:flex;align-items:center;gap:.3rem;font-size:.83rem;cursor:pointer;font-weight:400}.secondary-role-check input{cursor:pointer}.forecast-pools{display:flex;gap:1.25rem;flex-wrap:wrap;margin-bottom:1.25rem}.forecast-pool-config{flex:1;min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.875rem 1rem}.forecast-pool-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;flex-wrap:wrap}.forecast-pool-subtitle{font-size:.72rem;color:var(--text-muted);width:100%;margin-left:1.5rem}.forecast-pool-people{display:flex;flex-direction:column;gap:.3rem}.forecast-pool-check{display:flex;align-items:center;gap:.4rem;font-size:.83rem;cursor:pointer}.forecast-pool-check input{cursor:pointer}.forecast-pool-role{font-size:.7rem;color:var(--text-muted);margin-left:auto}.forecast-table-wrapper{overflow-x:auto;margin-bottom:.75rem}.forecast-table{width:100%;border-collapse:collapse;font-size:.875rem}.forecast-table th{text-align:left;padding:.5rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap}.forecast-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border)}.forecast-table tbody tr:last-child td{border-bottom:none}.forecast-th-week{width:28%}.forecast-th-combined{width:24%;background:#f0fdf9}.forecast-th-type{width:24%}.forecast-slots-combined{background:#f0fdf9}.forecast-week{color:var(--text-secondary);font-size:.82rem}.forecast-slots{font-size:1.1rem;font-weight:700;text-align:center;width:80px;border-radius:6px}.slots-zero{color:#94a3b8}.slots-low{color:#b45309}.slots-mid{color:#1d4ed8}.slots-high{color:#15803d}.copy-col-btn{display:inline-block;margin-left:.6rem;padding:.15rem .4rem;font-size:.68rem;font-weight:600;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text-muted);cursor:pointer;vertical-align:middle;transition:all .15s}.copy-col-btn:hover{background:var(--surface);color:var(--text)}.copy-col-btn-copied{background:#dcfce7;color:#15803d;border-color:#bbf7d0}.forecast-note{font-size:.75rem;color:var(--text-muted);margin:0;line-height:1.5}.data-sync-section{margin-top:2rem}.data-sync-group{margin-bottom:1.5rem}.data-sync-group-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .6rem}.data-sync-actions{display:flex;flex-direction:column;gap:.6rem}.data-sync-option{display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}.data-sync-note{font-size:.78rem;color:var(--text-muted);margin:0}.pipe-add-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.pipe-mode-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1rem}.pipe-mode-btn{padding:.4rem .9rem;border:none;border-right:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);cursor:pointer;font-size:.82rem;font-weight:500;transition:background .1s,color .1s}.pipe-mode-btn:last-child{border-right:none}.pipe-mode-active{background:var(--blue);color:#fff}.pipe-mode-active:hover{background:#2563eb}.pipe-add-body{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}@media (max-width: 700px){.pipe-add-body{grid-template-columns:1fr}}.pipe-add-left,.pipe-add-right{display:flex;flex-direction:column;gap:.75rem}.pipe-schedule-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem}.pipe-stagger-hint{font-size:.75rem;color:#1d4ed8;margin:0;background:#dbeafe;padding:.25rem .5rem;border-radius:4px;line-height:1.4}.pipe-basket{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.pipe-basket-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);display:block;margin-bottom:.65rem}.pipe-basket-list{display:flex;flex-direction:column;gap:.4rem}.pipe-basket-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:6px}.pipe-basket-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.pipe-basket-name{font-weight:600;font-size:.88rem}.pipe-basket-meta{font-size:.78rem;color:var(--text-muted)}.pipe-results{display:flex;flex-direction:column;gap:1.25rem}.pipe-results-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.pipe-results-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:.3rem;margin-bottom:.75rem}.pipe-pool-cap{font-size:.72rem;color:var(--text-muted);margin-left:auto}.app-footer{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:.875rem 1.5rem;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border);background:var(--surface)}.footer-logo{height:20px;width:auto;justify-self:start}.footer-text{text-align:center}.forecast-week-control{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted);font-weight:500;white-space:nowrap}.week-count-input{width:60px;padding:.3rem .4rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;text-align:center}.forecast-breakdown{margin:1.25rem 0 .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.forecast-breakdown-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.forecast-breakdown-title{font-size:.85rem;font-weight:700;margin:0;color:var(--text)}.breakdown-month-picker{display:flex;align-items:center;gap:.4rem}.breakdown-month-label{font-size:.82rem;font-weight:600;color:var(--text);min-width:80px;text-align:center}.breakdown-month-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);width:24px;height:24px;cursor:pointer;font-size:1rem;line-height:1;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.breakdown-month-btn:hover:not(:disabled){background:var(--bg);color:var(--text)}.breakdown-month-btn:disabled{opacity:.35;cursor:default}.forecast-breakdown-pools{display:flex;gap:1.5rem;flex-wrap:wrap}.breakdown-note{margin:.75rem 0 0;font-size:.75rem;color:var(--text-muted);font-style:italic;line-height:1.5}.forecast-breakdown-pool{flex:1;min-width:200px}.forecast-breakdown-pool-label{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.forecast-breakdown-table{width:100%;border-collapse:collapse;font-size:.85rem}.forecast-breakdown-table th{text-align:left;padding:.3rem .5rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border)}.forecast-breakdown-table td{padding:.35rem .5rem;border-bottom:1px solid var(--border)}.forecast-breakdown-table tbody tr:last-child td{border-bottom:none}.heatmap-range-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.heatmap-range-controls label{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted);font-weight:500}.heatmap-range-controls input[type=month]{padding:.25rem .4rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;color:var(--text)}.overdue-banner{background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem;color:#92400e}.overdue-banner-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.overdue-list{margin:.5rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.35rem}.overdue-list li{display:flex;align-items:center;gap:.6rem}.overdue-name{font-weight:600}.overdue-end{color:#b45309;font-size:.8rem}.btn-xs{padding:.2rem .55rem;font-size:.75rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;line-height:1.4}.btn-xs:hover{background:#f1f5f9}.undo-toast{display:flex;align-items:center;gap:.75rem;background:#1e293b;color:#f1f5f9;border-radius:var(--radius);padding:.6rem 1rem;margin-bottom:1rem;font-size:.875rem;box-shadow:0 2px 8px #00000040;width:fit-content}.btn-undo{background:transparent;border:1px solid #94a3b8;color:#e2e8f0;padding:.2rem .6rem;font-size:.8rem;border-radius:var(--radius);cursor:pointer}.btn-undo:hover{background:#334155;border-color:#cbd5e1}.project-search-bar{margin-bottom:.75rem}.project-search-input{width:100%;max-width:420px;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;color:var(--text);background:var(--surface)}.project-search-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f626}.settings-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem 1.25rem}.settings-form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:600;color:var(--text-muted)}.settings-form-grid label.full-width{grid-column:1 / -1}.settings-form-grid input,.settings-form-grid select{padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;color:var(--text);background:var(--surface)}.settings-form-grid input:focus,.settings-form-grid select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f626}.settings-toggle-label{display:flex!important;flex-direction:row!important;align-items:center;gap:.4rem;font-size:.85rem!important;font-weight:500!important;color:var(--text)!important;cursor:pointer}.settings-toggle-label input[type=checkbox]{cursor:pointer}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600}.badge-gray{background:#f1f5f9;color:var(--text-muted)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-yellow{background:var(--yellow-bg);color:#92400e}.badge-green{background:var(--green-bg);color:#166534}.badge-red{background:var(--red-bg);color:#991b1b}.text-muted{color:var(--text-muted)}.dup-warning{color:var(--red);font-size:.75rem;font-weight:600}.overdue-text{color:var(--red);font-weight:600}.outstanding-val{color:var(--red);font-weight:700}.fx-badge{display:inline-block;padding:.2rem .65rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:999px;font-size:.75rem;color:#166534;margin-bottom:.75rem}.billing-summary{margin-bottom:1.5rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-bottom:1rem}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;box-shadow:var(--shadow)}.summary-card-accent{border-color:var(--blue);background:var(--blue-bg)}.summary-card-clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.summary-card-clickable:hover{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue)}.summary-card-selected{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue);background:var(--blue-bg)}.summary-card-label{font-size:.75rem;color:var(--text-muted);font-weight:600;margin-bottom:.25rem}.summary-card-val{font-size:1.2rem;font-weight:700}.summary-card-sub{font-size:.72rem;color:var(--text-muted);margin-top:.2rem}.inv-detail-section{margin-top:1rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:1rem;overflow-x:auto}.inv-detail-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.inv-detail-header h4{font-size:.9rem;font-weight:700;margin:0}.inv-detail-filters{display:flex;gap:.35rem;flex-wrap:wrap}.inv-detail-search{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.inv-search-input{flex:1;max-width:420px;padding:.45rem .65rem;font-size:.85rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:inherit;transition:border-color .15s,box-shadow .15s}.inv-search-input:focus{outline:none;border-color:var(--accent, #48A6A7);box-shadow:0 0 0 2px #48a6a726}.inv-search-input::placeholder{color:#999}.inv-search-clear{flex-shrink:0}.inv-detail-wrap{overflow-x:auto}.inv-detail-table{width:100%;font-size:.8rem;border-collapse:collapse}.inv-detail-table th,.inv-detail-table td{padding:.4rem .6rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.inv-detail-th{font-weight:600;color:var(--text-muted);font-size:.75rem}.inv-detail-th:hover{color:var(--text)}.inv-detail-overdue{background:#fef2f2}.inv-detail-aging-red{color:#dc2626;font-weight:600}.inv-detail-total td{border-top:2px solid var(--border);border-bottom:none;padding-top:.6rem}.summary-lower{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.aging-panel,.cashflow-panel,.ytd-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;box-shadow:var(--shadow)}.aging-panel h4,.cashflow-panel h4,.ytd-panel h4{font-size:.85rem;font-weight:700;margin-bottom:.5rem}.aging-table{width:100%;border-collapse:collapse;font-size:.82rem}.aging-table th{text-align:left;color:var(--text-muted);font-weight:600;padding:.25rem .4rem;border-bottom:1px solid var(--border)}.aging-table td{padding:.3rem .4rem}.aging-overdue td{color:var(--red);font-weight:600}.ytd-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.82rem;border-bottom:1px solid var(--border)}.ytd-row:last-child{border-bottom:none}.needs-attention{background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.attention-title{font-size:.95rem;font-weight:700;margin-bottom:.6rem;display:flex;align-items:center;gap:.5rem}.attention-group{margin-bottom:.6rem}.attention-group-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}.attention-row{display:flex;align-items:center;gap:.6rem;padding:.25rem 0;font-size:.82rem;flex-wrap:wrap}.attention-client{font-weight:600}.attention-amt{margin-left:auto;font-weight:600}.billing-top-actions{display:flex;gap:.5rem;align-items:center}.billing-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.billing-view-tabs{display:flex;gap:0}.view-tab{padding:.4rem .85rem;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:.82rem;font-weight:500}.view-tab:first-child{border-radius:var(--radius) 0 0 var(--radius)}.view-tab:last-child{border-radius:0 var(--radius) var(--radius) 0}.view-tab+.view-tab{border-left:none}.view-tab-active{background:var(--blue);color:#fff;border-color:var(--blue)}.billing-filters{display:flex;gap:.5rem;align-items:center}.sow-list{display:flex;flex-direction:column;gap:.5rem}.sow-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.sow-on-hold{border-left:3px solid var(--yellow);opacity:.85}.sow-attention{border-left:3px solid var(--red)}.sow-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.sow-header:hover{background:var(--surface-2)}.sow-header-left{display:flex;align-items:center;gap:.6rem}.sow-expand{color:var(--text-muted);font-size:.8rem;width:14px}.sow-client{font-weight:600;font-size:.95rem}.sow-meta{display:flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.78rem;margin-top:.2rem}.sow-header-right{display:flex;align-items:center;gap:.6rem}.sow-amounts{text-align:right}.sow-outstanding{font-weight:700;font-size:1rem;display:block}.sow-total{font-size:.75rem;display:block}.sow-detail{border-top:1px solid var(--border);padding:.75rem 1rem 1rem}.cic-row{display:flex;gap:1.5rem;margin-bottom:.75rem;flex-wrap:wrap}.cic-item{display:flex;flex-direction:column;gap:.1rem}.cic-label{font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.cic-val{font-size:.95rem;font-weight:600}.sow-notes{font-size:.82rem;color:var(--text-muted);font-style:italic;margin-bottom:.5rem}.invoice-table-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr 1.5fr;gap:.5rem;padding:.3rem .5rem;font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);margin-bottom:.2rem}.invoice-row{padding:.4rem .5rem;border-radius:4px}.invoice-row.paid{opacity:.6}.invoice-row.cancelled{opacity:.5;text-decoration:line-through}.invoice-row.overdue{background:#fff1f2}.invoice-row-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr 1.5fr;gap:.5rem;align-items:center}.invoice-desc{display:flex;align-items:center}.milestone-check{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.85rem}.milestone-check input{margin:0;cursor:pointer}.invoice-amount{font-weight:600;font-size:.85rem}.invoice-num,.invoice-date,.invoice-due,.invoice-status{font-size:.82rem}.invoice-actions{display:flex;gap:.3rem;flex-wrap:wrap}.inline-form{display:flex;gap:.4rem;align-items:center;padding:.4rem .5rem;background:var(--surface-2);border-radius:4px;margin-top:.3rem;flex-wrap:wrap}.sow-actions{display:flex;gap:.4rem;margin-top:.75rem;flex-wrap:wrap}.sow-project-link{margin-top:.6rem;display:flex;align-items:center;gap:.6rem;font-size:.82rem}.sow-project-link label{color:var(--text-muted);font-weight:600}.sow-project-link select{width:auto}.followup-log{margin-top:.4rem;background:var(--surface-2);border-radius:4px;padding:.5rem .75rem;font-size:.82rem}.followup-entry{display:flex;gap:.75rem;padding:.2rem 0;border-bottom:1px solid var(--border)}.followup-entry:last-of-type{border-bottom:none}.followup-date{color:var(--text-muted);white-space:nowrap}.followup-note{flex:1}.followup-add{display:flex;gap:.4rem;margin-top:.4rem}.client-rollup{overflow-x:auto}.rollup-table{width:100%;border-collapse:collapse;font-size:.85rem}.rollup-table th{text-align:left;padding:.5rem .75rem;border-bottom:2px solid var(--border);font-size:.78rem;color:var(--text-muted);font-weight:600}.rollup-table td{padding:.45rem .75rem;border-bottom:1px solid var(--border)}.rollup-table .has-outstanding td{background:#fff7ed}.rollup-client{font-weight:600}.invoice-lines-edit{margin-top:1rem}.invoice-lines-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.invoice-lines-edit-header h4{font-size:.9rem;font-weight:700}.invoice-line-edit-row{display:flex;gap:.4rem;align-items:center;margin-bottom:.4rem}.invoice-line-edit-row input,.invoice-line-edit-row select{font-size:.82rem}.empty-state{padding:2rem;text-align:center;color:var(--text-muted);font-size:.9rem}.fx-badge-warn{background:#fff7ed;border-color:#fed7aa;color:#92400e}.ytd-equiv{color:var(--blue);font-weight:600}.ytd-equiv span:last-child{color:var(--blue)}.tag-blue{background:var(--blue-bg);border-color:#bfdbfe;color:var(--blue)}.attention-toggle{margin-left:auto;font-size:.75rem}.fx-retry-btn{background:none;border:none;color:#92400e;text-decoration:underline;cursor:pointer;font-size:.75rem;padding:0}.fx-retry-btn:hover{color:var(--red)}.invoice-strip{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}.strip-item{display:inline-flex;align-items:center;gap:.3rem;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:.1rem .45rem;font-size:.76rem}.strip-desc{color:var(--text-muted)}.strip-amt{font-weight:600}.strip-summary{font-size:.76rem;color:var(--text-muted);font-style:italic}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg, #f5f5f5)}.login-card{background:var(--card-bg, #fff);border:1px solid var(--border, #e0e0e0);border-radius:12px;padding:2.5rem;max-width:400px;width:100%;text-align:center}.login-logo{height:48px;margin-bottom:1rem}.login-card h1{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text, #222)}.login-card form{display:flex;flex-direction:column;gap:1rem}.login-card label{text-align:left}.login-card input[type=email]{width:100%;margin-top:.25rem}.login-error{color:var(--danger, #d32f2f);font-size:.85rem;margin:0}.login-success{display:flex;flex-direction:column;gap:.75rem}.login-hint{color:var(--text-muted, #888);font-size:.85rem}.header-user{display:flex;align-items:center;gap:.5rem;margin-left:auto}.header-user-name{font-size:.85rem;color:var(--text-muted, #888)}.sandbox-banner{position:fixed;bottom:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem 1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-top:2px solid #f59e0b;font-size:.82rem;color:#92400e}.sandbox-banner-icon{background:#f59e0b;color:#fff;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.15rem .5rem;border-radius:4px}.sandbox-banner-text{font-weight:500}.sandbox-banner-btn{background:#fff;border:1px solid #f59e0b;color:#92400e;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:4px;cursor:pointer}.sandbox-banner-btn:hover{background:#fffbeb}.sandbox-banner-close{background:none;border:none;color:#92400e;font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1;opacity:.6}.sandbox-banner-close:hover{opacity:1}.project-highlight{animation:highlight-pulse 2.5s ease-out}@keyframes highlight-pulse{0%{box-shadow:0 0 0 3px var(--blue),var(--shadow)}70%{box-shadow:0 0 0 3px var(--blue),var(--shadow)}to{box-shadow:var(--shadow)}}.dashboard{display:flex;flex-direction:column;gap:1.25rem}.dash-header{display:flex;justify-content:space-between;align-items:center}.dash-header h2{font-size:1.1rem;font-weight:700}.export-buttons{display:flex;gap:.4rem;margin-top:.75rem;justify-content:flex-end}.dash-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width: 768px){.dash-kpi-row{grid-template-columns:repeat(2,1fr)}}.dash-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.25rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.25rem}.dash-kpi-accent{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.dash-kpi-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s}.dash-kpi-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#cbd5e1}.dash-kpi-ring{align-items:center;text-align:center;gap:.4rem}.dash-kpi-label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.dash-kpi-value{font-size:1.6rem;font-weight:700;color:var(--text);line-height:1.15}.dash-kpi-sub{font-size:.78rem;color:var(--text-muted)}.dash-warn{color:var(--red);font-weight:600}.dash-ok{color:var(--green);font-weight:500}.dash-ring{display:block}.dash-ring-text{font-size:.7rem;font-weight:700}.dash-alerts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media (max-width: 900px){.dash-alerts-row{grid-template-columns:1fr}}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;box-shadow:var(--shadow)}.dash-card-full{grid-column:1 / -1}.dash-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s}.dash-card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#cbd5e1}.dash-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.dash-card-header h3{font-size:.92rem;font-weight:700}.dash-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 .5rem;border-radius:999px;font-size:.72rem;font-weight:700;background:var(--surface-2);color:var(--text-muted)}.dash-badge-red{background:var(--red-bg);color:var(--red)}.dash-badge-green{background:var(--green-bg);color:var(--green)}.dash-list{display:flex;flex-direction:column;gap:.1rem}.dash-list-item{padding:.55rem .5rem;border-radius:6px;cursor:pointer;transition:background .12s}.dash-list-item:hover{background:var(--surface-2)}.dash-list-main{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.dash-list-name{font-weight:600;font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.dash-list-sub{font-size:.76rem;color:var(--text-muted);margin-top:.15rem}.dash-list-tag{font-size:.7rem;font-weight:600;padding:.1rem .45rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.dash-tag-red{background:var(--red-bg);color:var(--red)}.dash-tag-amber{background:var(--yellow-bg);color:#b45309}.dash-tag-blue{background:var(--blue-bg);color:var(--blue)}.dash-list-amt{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;flex-shrink:0}.dash-overdue-days{color:var(--red);font-weight:600}.dash-list-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:.3rem;vertical-align:middle}.dash-dot-blue{background:var(--blue)}.dash-empty{color:var(--text-muted);font-size:.84rem;text-align:center;padding:1.5rem 0}.dash-team-grid{display:flex;flex-direction:column}.dash-team-header,.dash-team-row{display:grid;grid-template-columns:1.5fr .9fr .7fr .7fr 1.3fr;gap:.5rem;align-items:center;padding:.45rem .25rem}.dash-team-header{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border);padding-bottom:.55rem;margin-bottom:.15rem}.dash-team-row{border-bottom:1px solid #f1f5f9;font-size:.84rem}.dash-team-row:last-child{border-bottom:none}.dash-team-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-team-pct{font-weight:600;font-size:.82rem;text-align:center}.dash-pct-green{color:var(--green)}.dash-pct-yellow{color:#b45309}.dash-pct-red{color:var(--red)}.dash-team-bar-header{text-align:center}.dash-cap-bar-bg{height:8px;background:#f1f5f9;border-radius:4px;position:relative;overflow:hidden}.dash-cap-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.dash-cap-bar-over{position:absolute;top:0;right:0;height:100%;background:var(--red);opacity:.35;border-radius:0 4px 4px 0}@media (max-width: 600px){.dash-team-header,.dash-team-row{grid-template-columns:1fr .6fr .6fr}.dash-team-header span:nth-child(4),.dash-team-header span:nth-child(5),.dash-team-row span:nth-child(4),.dash-team-row .dash-cap-bar-bg{display:none}}
