@import"https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,400;0,700;1,400&family=Noto+Serif+Display:wght@400&display=swap";.topbar{position:sticky;top:0;z-index:20;background:var(--color-panel);border-bottom:1px solid var(--color-border);padding:12px var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.topbar-left{display:flex;align-items:center;gap:var(--space-3);min-width:0;flex:1}.hamburger-btn{width:44px;height:44px;min-height:44px;border-radius:var(--radius-md);background:var(--color-muted-bg);color:var(--color-primary);font-size:22px;font-weight:400;line-height:1;padding:0;flex-shrink:0}.brand-wrap{min-width:0;flex:1}.brand-name{font-family:var(--font-heading);font-size:18px;font-weight:400;color:var(--color-primary);line-height:1.2}.brand-sub{font-size:12px;color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;line-height:1.3;margin-top:2px}.topbar-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.user-chip{display:none;flex-direction:column;align-items:flex-end;font-size:13px;color:var(--color-text);font-weight:700}.user-role{font-size:11px;color:var(--color-muted);font-weight:400;text-transform:capitalize}@media (min-width: 480px){.brand-sub{max-width:220px}}@media (min-width: 640px){.user-chip{display:flex}.brand-sub{max-width:300px}}.project-switcher{font-size:12px;color:var(--color-muted);background:transparent;border:1px solid var(--color-border, #d9e1e8);border-radius:4px;padding:2px 6px;margin-top:2px;max-width:200px;cursor:pointer}@media (min-width: 480px){.project-switcher{max-width:260px}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f171f66;z-index:30}.nav-drawer{position:fixed;top:0;left:0;bottom:0;width:88%;max-width:320px;background:var(--color-sidebar);z-index:40;box-shadow:var(--shadow-lg);padding:var(--space-4);overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:var(--space-2)}.drawer-head{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:var(--space-3);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:var(--space-1);flex-shrink:0}.drawer-brand{font-family:var(--font-heading);font-size:20px;font-weight:400;color:var(--color-white);line-height:1.2}.drawer-user{color:#ffffff8c!important;font-size:13px;margin-top:var(--space-1);text-transform:capitalize}.drawer-close-btn{width:44px;height:44px;min-height:44px;border-radius:var(--radius-md);background:#ffffff1a;color:var(--color-white);font-size:18px;font-weight:400;padding:0;flex-shrink:0}.drawer-close-btn:hover{background:#ffffff2e}.nav-section-title{font-size:11px;font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) 0 var(--space-1) var(--space-1)}.nav-link{display:flex;align-items:center;width:100%;min-height:44px;text-align:left;background:transparent;color:#fffc;border:1px solid transparent;padding:10px var(--space-3);border-radius:var(--radius-md);margin-bottom:2px;font-size:16px;font-weight:400;text-decoration:none;transition:background .12s ease,color .12s ease}.nav-link:hover{background:#ffffff14;color:var(--color-white);text-decoration:none}.nav-link.active{background:#22579c8c;border-color:#22579ccc;color:var(--color-white);font-weight:700}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:var(--space-4);background:var(--color-bg)}.login-card{width:100%;max-width:420px;background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow)}@media (min-width: 480px){.login-wrap,.login-card{padding:var(--space-6)}}.kpi-grid{display:grid;gap:var(--space-3);grid-template-columns:1fr}.kpi-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);background:var(--color-white)}.kpi-label{font-size:12px;color:var(--color-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:28px;font-weight:700;color:var(--color-primary);line-height:1.1}@media (min-width: 600px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 900px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}.projects-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4, 16px)}.project-create-form{margin-bottom:var(--space-5, 20px);padding-bottom:var(--space-4, 16px);border-bottom:1px solid var(--color-border, #d9e1e8)}.phase-group{margin-bottom:var(--space-3, 12px)}.phase-header{display:flex;align-items:center;gap:var(--space-2, 8px);width:100%;padding:var(--space-2, 8px) 0;background:none;border:none;cursor:pointer;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-steel, #5c5e5a)}.phase-header-label{display:flex;align-items:center;gap:var(--space-2, 8px);flex:1}.phase-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--color-muted-bg, #edf3f8);font-size:11px;font-weight:700;color:var(--color-steel, #5c5e5a)}.phase-chevron{font-size:10px;transition:transform .15s}.phase-chevron.collapsed{transform:rotate(-90deg)}.phase-cards{display:grid;gap:var(--space-2, 8px);grid-template-columns:1fr;padding-left:18px;margin-bottom:var(--space-3, 12px)}@media (min-width: 600px){.phase-cards{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1000px){.phase-cards{grid-template-columns:repeat(3,1fr)}}.project-card{display:flex;flex-direction:column;gap:var(--space-1, 4px);padding:var(--space-3, 12px);border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);background:var(--color-white, #fff);text-align:left;cursor:pointer;transition:box-shadow .15s,border-color .15s}.project-card:hover{border-color:var(--color-primary, #22579c);box-shadow:var(--shadow)}.project-card.highlighted{border-left:3px solid var(--color-accent, #9ba747)}.project-card-name{font-weight:700;font-size:14px;color:var(--color-text, #171717)}.project-card-addr{font-size:12px;color:var(--color-muted, #6b7785)}.project-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-1, 4px)}.phase-badge-sm{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;color:#fff;white-space:nowrap}.project-avatars{display:flex;flex-direction:row-reverse}.project-avatar{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-steel, #5c5e5a);color:#fff;font-size:10px;font-weight:700;border:2px solid var(--color-white, #fff);margin-left:-6px;position:relative}.project-avatar.more{background:var(--color-muted-bg, #edf3f8);color:var(--color-steel, #5c5e5a);font-size:9px}.scope-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg, 14px);padding:var(--space-4, 16px)}.scope-version-list{display:flex;flex-direction:column;gap:var(--space-1, 4px)}.scope-version-row{display:flex;align-items:center;gap:var(--space-2, 8px);padding:var(--space-2, 8px) var(--space-3, 12px);border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);background:var(--color-white);width:100%}.scope-version-row:hover{border-color:var(--color-primary)}.scope-version-row-inner{display:flex;align-items:center;gap:var(--space-3, 12px);flex:1;min-width:0;background:none;border:none;padding:4px 0;cursor:pointer;text-align:left;font:inherit;color:inherit}.scope-version-row.latest{border-left:3px solid var(--color-accent, #9ba747)}.scope-version-label{font-weight:700;font-size:14px;min-width:36px}.scope-version-meta{font-size:12px;margin-left:auto}.scope-status-badge{display:inline-block;padding:2px 10px;border-radius:4px;font-size:11px;font-weight:700;color:#fff;white-space:nowrap;background:var(--color-steel, #5c5e5a)}.scope-status-badge.draft{background:var(--color-muted, #6b7785)}.scope-status-badge.internal_review{background:#c99a2e}.scope-status-badge.approved_to_send{background:var(--color-accent, #9ba747)}.scope-status-badge.sent_to_client{background:var(--color-primary, #22579c)}.scope-status-badge.voided{background:var(--color-danger, #863b1d)}.scope-status-badge.archived{background:var(--color-muted, #6b7785)}.scope-version-row.voided{opacity:.55}.scope-version-row.voided .scope-version-label{text-decoration:line-through}.scope-back-btn{display:inline-block;font-size:13px;font-weight:700;color:var(--color-accent, #9ba747);background:none;border:none;cursor:pointer;padding:0;margin-bottom:var(--space-3, 12px)}.scope-back-btn:before{content:"←"}.scope-back-btn:hover{text-decoration:underline}.scope-doc-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3, 12px);margin-bottom:var(--space-3, 12px);flex-wrap:wrap}.scope-doc-header-left{display:flex;align-items:center;gap:var(--space-2, 8px)}.scope-doc-header-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.scope-header-cluster{display:flex;align-items:center;gap:6px}.scope-header-cluster:not(:first-child):before{content:"";display:block;width:1px;height:20px;background:var(--color-border, #d9e1e8);margin-right:2px}.scope-void-btn{background:none;border:1px solid var(--color-danger, #863b1d);color:var(--color-danger, #863b1d);border-radius:4px;padding:4px 10px;font-size:12px;font-weight:700;cursor:pointer;min-height:auto}.scope-void-btn:hover{background:var(--color-danger, #863b1d);color:#fff}.scope-pending-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3, 12px);padding:8px 12px;margin-bottom:var(--space-3, 12px);background:#fefce8;border:1px solid #fde68a;border-left:3px solid #f59e0b;border-radius:var(--radius-sm, 8px);font-size:13px}.scope-pending-bar-label{color:#92400e;font-weight:600}.scope-pending-bar-actions{display:flex;gap:6px}.scope-pending-approve-btn{background:#dcfce7;border:1px solid #86efac;color:#166534;border-radius:4px;padding:3px 10px;font-size:12px;font-weight:700;cursor:pointer;min-height:auto}.scope-pending-approve-btn:hover{background:#16a34a;color:#fff}.scope-pending-decline-btn{background:#fef2f2;border:1px solid #fca5a5;color:var(--color-danger, #863b1d);border-radius:4px;padding:3px 10px;font-size:12px;font-weight:700;cursor:pointer;min-height:auto}.scope-pending-decline-btn:hover{background:var(--color-danger, #863b1d);color:#fff}.scope-pdf-menu-wrap{display:inline-block}.scope-pdf-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-white);border:1px solid var(--color-border, #d9e1e8);border-radius:6px;box-shadow:0 4px 12px #0000001a;z-index:50;min-width:180px;overflow:hidden}.scope-pdf-menu button{display:block;width:100%;text-align:left;padding:8px 14px;font-size:13px;background:none;border:none;border-bottom:1px solid #f3f4f6;cursor:pointer;min-height:auto;color:var(--color-text, #171717)}.scope-pdf-menu button:last-child{border-bottom:none}.scope-pdf-menu button:hover{background:var(--color-muted-bg, #edf3f8)}.scope-lock-icon{display:inline-block;font-size:11px;font-weight:700;color:var(--color-danger, #863b1d);margin-left:var(--space-2, 8px)}.scope-area{border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);padding:var(--space-4, 16px);margin-bottom:var(--space-3, 12px);background:var(--color-white)}.scope-area-header{display:flex;align-items:center;gap:var(--space-2, 8px);margin-bottom:var(--space-3, 12px)}.scope-area-name{font-weight:700;font-size:16px;color:var(--color-primary, #22579c);text-transform:uppercase;letter-spacing:.03em;flex:1}.scope-subarea{margin-bottom:var(--space-3, 12px);padding-left:var(--space-3, 12px);border-left:2px solid var(--color-border, #d9e1e8)}.scope-subarea-header{display:flex;align-items:center;gap:var(--space-2, 8px);margin-bottom:var(--space-2, 8px)}.scope-subarea-name{font-weight:700;font-size:14px;flex:1}.scope-bullet-section{margin-bottom:var(--space-2, 8px)}.scope-bullet-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-1, 4px);padding-top:var(--space-2, 8px);border-top:1px dashed var(--color-border, #d9e1e8)}.scope-bullet-section.assumptions .scope-bullet-section-title{color:var(--color-primary, #22579c)}.scope-bullet-section.exclusions .scope-bullet-section-title{color:var(--color-danger, #863b1d)}.scope-bullet{margin-bottom:var(--space-1, 4px)}.scope-bullet-main{display:flex;align-items:flex-start;gap:6px;width:100%}.scope-bullet-input{flex:1 1 auto;min-width:0;border:1px solid transparent;border-radius:4px;padding:4px 6px;font-size:14px;font-family:var(--font-body, Lato, sans-serif);resize:none;overflow:hidden;line-height:1.4;min-height:28px;box-sizing:border-box}.scope-bullet-input:focus{border-color:var(--color-border, #d9e1e8);outline:none}.scope-bullet-input:disabled{background:transparent;color:var(--color-text)}.scope-save-status{font-size:11px;flex-shrink:0;padding-top:6px}.scope-internal-badge{font-size:10px;font-weight:700;color:var(--color-danger, #863b1d);padding-top:6px;flex-shrink:0}.scope-add-row{display:flex;gap:var(--space-2, 8px);flex-wrap:wrap;margin-top:var(--space-2, 8px)}.scope-add-area{display:flex;gap:var(--space-2, 8px);margin-top:var(--space-3, 12px)}.scope-add-area input{flex:1;padding:6px 8px;border:1px solid var(--color-border, #d9e1e8);border-radius:4px;font-size:13px}.scope-add-subarea-toggle{margin-top:var(--space-3, 12px);margin-left:24px}.scope-add-subarea-panel{display:flex;align-items:center;gap:8px;margin-top:var(--space-3, 12px);margin-left:24px;max-width:400px;padding:8px 12px;background:var(--color-bg-muted, #f5f6f7);border:1px solid var(--color-border, #d9e1e8);border-radius:6px}.scope-add-subarea-label{font-size:12px;font-weight:600;white-space:nowrap;color:var(--color-steel, #5c5e5a)}.scope-add-subarea-panel input{flex:1;padding:5px 8px;border:1px solid var(--color-border, #d9e1e8);border-radius:4px;font-size:13px;background:#fff}.scope-add-subarea-actions{display:flex;gap:4px;flex-shrink:0}.scope-split-layout{display:flex;gap:var(--space-4, 16px);align-items:flex-start}.scope-split-left-col{width:40%;min-width:300px;flex-shrink:0;transition:width .2s ease,min-width .2s ease;position:sticky;top:80px}.scope-split-left-col.collapsed{width:32px;min-width:32px}.scope-split-left{max-height:calc(100vh - 240px);overflow-y:auto;overflow-x:hidden;border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-lg, 14px);background:var(--color-white);padding:var(--space-4, 16px);transition:padding .2s ease}.scope-split-left-col.collapsed .scope-split-left{padding:var(--space-2, 8px) 4px;overflow:hidden}.scope-split-right{flex:1;min-width:0}.scope-split-left-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3, 12px)}.scope-split-left-col.collapsed .scope-split-left-header h4{display:none}.scope-split-left-col.collapsed .scope-split-left-header{margin-bottom:0;justify-content:center}.scope-collapse-toggle{background:none;border:1px solid var(--color-border, #d9e1e8);border-radius:4px;padding:0 6px;min-height:auto;font-size:18px;line-height:1.2;cursor:pointer;color:var(--color-steel, #5c5e5a)}.scope-collapse-toggle:hover{background:var(--color-muted-bg, #edf3f8);color:var(--color-primary, #22579c)}.scope-mobile-close{display:none;background:none;border:none;font-size:24px;padding:4px 8px;min-height:auto;color:var(--color-muted);cursor:pointer}.scope-files-toggle{display:none;margin-bottom:var(--space-3, 12px)}.scope-split-backdrop{display:none}@media (max-width: 767px){.scope-split-layout{display:block}.scope-split-left-col{width:100%!important;min-width:0!important;position:static}.scope-split-left{display:none;position:fixed;top:0;left:0;right:0;bottom:0;max-height:100vh;z-index:200;border-radius:0}.scope-split-left.mobile-open,.scope-mobile-close{display:block}.scope-collapse-toggle{display:none}.scope-files-toggle{display:inline-block}.scope-split-backdrop{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:199}.scope-split-right{width:100%}}.file-ref-panel{display:flex;flex-direction:column;gap:var(--space-2, 8px)}.file-filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-1, 4px);margin-bottom:var(--space-2, 8px)}.file-filter-pill{padding:4px 10px;font-size:11px;font-weight:700;border-radius:12px;background:var(--color-muted-bg, #edf3f8);color:var(--color-steel, #5c5e5a);border:1px solid transparent;cursor:pointer;min-height:auto}.file-filter-pill.active{background:var(--color-primary, #22579c);color:#fff}.file-filter-pill:hover:not(.active){border-color:var(--color-border, #d9e1e8)}.file-filter-pill.split-toggle{margin-left:auto}.file-list{display:flex;flex-direction:column;gap:var(--space-1, 4px)}.file-list-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-2, 8px) var(--space-3, 12px);border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);background:var(--color-white);cursor:pointer;text-align:left;width:100%;min-height:auto}.file-list-item:hover{border-color:var(--color-primary)}.file-list-name{font-weight:700;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-list-meta{font-size:11px}.file-type-tag{display:inline-block;padding:1px 6px;border-radius:3px;background:var(--color-muted-bg, #edf3f8);font-size:10px;font-weight:700}.file-viewer{display:flex;flex-direction:column;gap:var(--space-2, 8px)}.file-viewer-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2, 8px)}.file-viewer-name{font-weight:700;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.file-viewer-caption{font-size:12px}.file-viewer-iframe{width:100%;height:500px;border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px)}.file-viewer-img{max-width:100%;border-radius:var(--radius-sm, 8px)}.file-split-view{display:flex;flex-direction:column;height:calc(100vh - 320px)}.file-split-top,.file-split-bottom{flex:1;overflow-y:auto;min-height:0}.file-split-divider{height:2px;background:var(--color-border, #d9e1e8);margin:var(--space-2, 8px) 0;flex-shrink:0}.file-upload-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:300;display:flex;align-items:center;justify-content:center;padding:var(--space-4, 16px)}.file-upload-modal{background:var(--color-white);border-radius:var(--radius-lg, 14px);padding:var(--space-5, 20px);max-width:440px;width:100%;box-shadow:0 8px 24px #141e281f}.scope-audit-meta{font-size:12px;margin-bottom:var(--space-1, 4px)}.scope-summary-field{margin-bottom:var(--space-4, 16px)}.scope-summary-field label{font-size:13px;font-weight:700;display:block;margin-bottom:4px}.scope-summary-field textarea{width:100%;border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);padding:8px;font-size:14px;font-family:var(--font-body, Lato, sans-serif);resize:vertical;line-height:1.5}.scope-summary-field textarea:focus{border-color:var(--color-primary, #22579c);outline:none}.drag-handle{cursor:grab;color:var(--color-muted, #6b7785);font-size:14px;-webkit-user-select:none;user-select:none;padding:0 4px;flex-shrink:0;line-height:1}.drag-handle:active{cursor:grabbing}.drag-handle-area{color:var(--color-primary, #22579c);font-size:18px}[data-drag-item].dragging,[data-bullet-id].dragging{opacity:.4}[data-drag-item].drag-over,[data-bullet-id].drag-over{border-top:2px solid var(--color-accent, #9ba747)!important}.scope-bullet-section.drag-active{border:1px dashed transparent;border-radius:4px;transition:border-color .15s,background-color .15s}.scope-bullet-section.drag-active:not(:has(.dragging)){border-color:var(--color-border, #d9e1e8)}.scope-bullet-section.drag-over-section{border-color:var(--color-accent, #9ba747)!important;background:#9ba7470f}.scope-area.fixed .scope-area-name{color:var(--color-steel, #5c5e5a)}.scope-area.suggested-delete,.scope-subarea.suggested-delete{opacity:.5}.scope-area.suggested-delete .scope-area-name,.scope-subarea.suggested-delete .scope-subarea-name{text-decoration:line-through}.suggestion-inline-actions{display:flex;align-items:center;gap:6px;font-size:12px;flex-shrink:0}.scope-internal-toggle{background:none;border:none;padding:2px;min-height:auto;cursor:pointer;flex-shrink:0;line-height:0;color:var(--color-steel, #5c5e5a);display:flex;align-items:center}.scope-internal-toggle:hover{color:var(--color-primary, #22579c)}.scope-internal-toggle.hidden-from-client{color:var(--color-danger, #863b1d);opacity:.7}.scope-internal-toggle.hidden-from-client:hover{opacity:1}.scope-bullet.internal{opacity:.55}.scope-bullet-controls{display:flex;align-items:center;gap:4px;flex-shrink:0;white-space:nowrap}.scope-view-toggle{display:flex;gap:0;margin-bottom:var(--space-3, 12px)}.scope-view-pill{padding:5px 16px;font-size:12px;font-weight:700;border:1px solid var(--color-border, #d9e1e8);background:var(--color-white);color:var(--color-steel, #5c5e5a);cursor:pointer;min-height:auto}.scope-view-pill:first-child{border-radius:6px 0 0 6px}.scope-view-pill:last-child{border-radius:0 6px 6px 0;border-left:none}.scope-view-pill.active{background:var(--color-primary, #22579c);color:#fff;border-color:var(--color-primary, #22579c)}.scope-view-pill:hover:not(.active){background:var(--color-muted-bg, #edf3f8)}.allowance-summary{display:flex;flex-direction:column;gap:var(--space-3, 12px)}.allowance-summary-area{border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);background:var(--color-white);overflow:hidden}.allowance-summary-area-header{font-weight:700;font-size:14px;color:var(--color-primary, #22579c);text-transform:uppercase;letter-spacing:.03em;padding:var(--space-3, 12px) var(--space-4, 16px);background:#f0f4f8;border-bottom:1px solid var(--color-border, #d9e1e8)}.allowance-summary-table{padding:0 var(--space-3, 12px)}.allowance-summary-table-head{display:flex;gap:6px;padding:8px 4px;border-bottom:1px solid var(--color-border, #d9e1e8);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-steel, #5c5e5a)}.allowance-summary-row{display:flex;gap:6px;padding:6px 4px;border-bottom:1px solid #f3f4f6;align-items:center}.allowance-summary-row:last-child{border-bottom:none}.allowance-col-label{flex:1.5;min-width:0}.allowance-col-scope{flex:2;min-width:0;font-size:11px}.allowance-col-unit{width:80px;flex-shrink:0}.allowance-col-qty{width:50px;flex-shrink:0}.allowance-col-price{width:80px;flex-shrink:0}.allowance-col-total{width:80px;flex-shrink:0;font-weight:600;font-size:12px;text-align:right;color:var(--color-steel, #5c5e5a)}.allowance-col-intent{flex:2;min-width:0}.allowance-summary-row input,.allowance-summary-row select{width:100%;border:1px solid transparent;border-radius:3px;padding:3px 5px;font-size:12px;background:transparent;font-family:inherit;min-height:auto}.allowance-summary-row input:focus,.allowance-summary-row select:focus{border-color:var(--color-border, #d9e1e8);background:#fff;outline:none}.allowance-summary-row input:hover:not(:focus):not(:disabled){border-color:#e5e7eb}.allowance-summary-row input[type=number]{text-align:right}.allowance-summary-subtotal{display:flex;justify-content:space-between;padding:8px var(--space-4, 16px);border-top:1px solid var(--color-border, #d9e1e8);font-size:13px;font-weight:700;color:var(--color-steel, #5c5e5a)}.allowance-summary-grand-total{display:flex;justify-content:space-between;padding:var(--space-3, 12px) var(--space-4, 16px);background:var(--color-primary, #22579c);color:#fff;font-size:15px;font-weight:700;border-radius:var(--radius-sm, 8px)}.scope-allowance-add{background:none;border:none;padding:2px 4px;min-height:auto;font-size:12px;cursor:pointer;flex-shrink:0;line-height:1;border-radius:3px;color:var(--color-muted, #6b7785)}.scope-allowance-add:hover{color:var(--color-primary, #22579c);background:#edf3f8}.scope-allowance-badge-btn{display:inline-block;padding:1px 7px;border-radius:10px;background:#edf3f8;color:var(--color-steel, #5c5e5a);font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0;line-height:1.5;border:1px solid var(--color-border, #d9e1e8);cursor:pointer;min-height:auto}.scope-allowance-badge-btn:hover{background:#dbe8f4;border-color:var(--color-primary, #22579c);color:var(--color-primary, #22579c)}.scope-allowance-section{margin:4px 0 4px 28px;padding:6px 8px;border-left:3px solid #f59e0b;background:#fffbeb;border-radius:0 4px 4px 0}.scope-allowance-row{margin-bottom:4px}.scope-allowance-row-main{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.scope-allowance-label{flex:1 1 120px;min-width:80px;border:1px solid var(--color-border, #d9e1e8);border-radius:3px;padding:3px 6px;font-size:12px;background:#fff}.scope-allowance-unit{width:85px;border:1px solid var(--color-border, #d9e1e8);border-radius:3px;padding:3px 4px;font-size:11px;background:#fff;min-height:auto}.scope-allowance-qty{width:50px;border:1px solid var(--color-border, #d9e1e8);border-radius:3px;padding:3px 4px;font-size:12px;text-align:right;background:#fff}.scope-allowance-price-wrap{display:flex;align-items:center;gap:0}.scope-allowance-dollar{font-size:11px;color:var(--color-muted, #6b7785);padding-right:1px}.scope-allowance-price{width:75px;border:1px solid var(--color-border, #d9e1e8);border-radius:3px;padding:3px 4px;font-size:12px;text-align:right;background:#fff}.scope-allowance-total{font-size:12px;font-weight:600;color:var(--color-steel, #5c5e5a);min-width:70px;text-align:right;flex-shrink:0}.scope-allowance-intent{margin:2px 0 0;padding-left:4px}.scope-allowance-intent-input{width:100%;border:1px solid var(--color-border, #d9e1e8);border-radius:3px;padding:3px 6px;font-size:11px;font-style:italic;background:#fff;color:var(--color-text, #171717)}.scope-allowance-intent-input:focus{border-color:#f59e0b;outline:none}.scope-allowance-add-btn{background:none;border:none;font-size:11px;color:var(--color-accent, #9ba747);cursor:pointer;padding:4px 0;font-weight:700;min-height:auto}.scope-allowance-add-btn:hover{text-decoration:underline}.scope-allowance-draft{background:#f0fdf4;border-radius:0 4px 4px 0;padding:6px 8px;margin:4px 0}.scope-allowance-suggestion{display:flex;align-items:center;gap:6px;padding:4px 8px;margin:2px 0;border-left:3px solid;border-radius:0 4px 4px 0;background:#00000005;font-size:12px;flex-wrap:wrap}.scope-allowance-subtotal{font-size:11px;font-weight:600;color:var(--color-steel, #5c5e5a);text-align:right;padding-top:4px;border-top:1px dashed var(--color-border, #d9e1e8);margin-top:4px}.scope-delete-btn{background:none;border:none;color:var(--color-muted, #6b7785);font-size:16px;cursor:pointer;padding:2px 4px;min-height:auto;flex-shrink:0;opacity:.5;line-height:1}.scope-delete-btn:hover{color:var(--color-danger, #863b1d);opacity:1}.scope-delete-confirm{font-size:11px;color:var(--color-danger, #863b1d);white-space:nowrap;flex-shrink:0}.scope-delete-confirm button{background:none;border:none;cursor:pointer;font-size:11px;min-height:auto;padding:0 2px;text-decoration:underline;color:inherit}.suggestion-row{margin:4px 0 4px 24px;padding:6px 10px;border-left:3px solid;border-radius:0 4px 4px 0;background:#00000005;font-size:13px}.suggestion-diff-line{font-size:13px;line-height:1.5}.suggestion-delete-text{text-decoration:line-through;color:var(--color-danger, #863b1d)}.suggestion-meta{font-size:11px;margin-top:4px;display:flex;align-items:center;gap:6px}.suggestion-accept-btn,.suggestion-reject-btn{background:none;border:1px solid;border-radius:4px;padding:1px 6px;cursor:pointer;font-size:12px;min-height:auto;line-height:1.4}.suggestion-accept-btn{color:#16a34a;border-color:#16a34a}.suggestion-accept-btn:hover{background:#16a34a;color:#fff}.suggestion-reject-btn{color:var(--color-danger, #863b1d);border-color:var(--color-danger, #863b1d)}.suggestion-reject-btn:hover{background:var(--color-danger, #863b1d);color:#fff}.pending-insert-row{margin:4px 0;padding:6px 10px;border-left:3px solid;border-radius:0 4px 4px 0;background:#00000005;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pending-insert-indicator{font-weight:700;font-size:16px}.pending-insert-text{font-size:13px;flex:1}.pending-insert-row.draft .scope-bullet-input{flex:1}.scope-suggestion-mode-banner{background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-sm, 8px);padding:8px 12px;font-size:13px;margin-bottom:var(--space-3, 12px);color:#92400e}.scope-bullet.has-delete-suggestion{border-left:2px solid var(--color-danger, #863b1d)}.suggestion-history{border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);padding:var(--space-3, 12px);margin-bottom:var(--space-4, 16px);max-height:300px;overflow-y:auto;background:var(--color-white)}.history-entry{font-size:12px;padding:4px 0;border-bottom:1px solid var(--color-border, #d9e1e8)}.history-entry:last-child{border-bottom:none}.history-action{font-weight:700}.history-preview{font-style:italic;color:var(--color-steel, #5c5e5a)}.scope-redline-view{margin:16px 0;border:1px solid #fca5a5;border-radius:8px;overflow:hidden}.scope-redline-banner{background:#fef2f2;color:#dc2626;padding:8px 16px;font-size:13px;font-weight:600;border-bottom:1px solid #fca5a5}.scope-redline-summary,.scope-redline-area{padding:12px 16px;border-bottom:1px solid #f3f4f6}.scope-redline-area:last-child{border-bottom:none}.scope-redline-subarea{margin-top:8px;padding-left:16px}.scope-redline-bullet{font-size:13px;line-height:1.6;margin:2px 0}.scope-redline-section{margin-top:6px}.scope-redline-section-label{font-size:12px;font-weight:600;font-style:italic;color:#5c5e5a;margin-bottom:2px}.project-breadcrumb{display:inline-block;font-size:13px;font-weight:700;color:var(--color-accent, #9ba747);text-decoration:none;margin-bottom:var(--space-3, 12px)}.project-breadcrumb:before{content:"←"}.project-breadcrumb:hover{text-decoration:underline}.project-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4, 16px);margin-bottom:var(--space-5, 20px)}.project-title{margin:0 0 4px;font-size:1.5rem}.project-address{font-size:14px;color:var(--color-muted, #6b7785)}.phase-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-sm, 8px);font-size:12px;font-weight:700;color:#fff;white-space:nowrap;flex-shrink:0}.phase-selector{position:relative}.phase-badge-clickable{cursor:pointer;border:none;min-height:auto}.phase-badge-clickable:hover:not(:disabled){opacity:.88}.phase-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--color-white, #fff);border:1px solid var(--color-border, #d9e1e8);border-radius:var(--radius-sm, 8px);box-shadow:0 8px 24px #141e281f;z-index:100;min-width:210px;overflow:hidden}.phase-dropdown-item{display:flex;align-items:center;gap:var(--space-2, 8px);width:100%;padding:10px 14px;background:none;border:none;border-radius:0;min-height:40px;font-size:13px;color:var(--color-text, #171717);cursor:pointer;text-align:left}.phase-dropdown-item:hover{background:var(--color-muted-bg, #edf3f8)}.phase-dropdown-item.active{font-weight:700;background:var(--color-muted-bg, #edf3f8)}.phase-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.phase-updated-meta{font-size:11px;margin-top:var(--space-1, 4px);text-align:right}:root{--color-primary: #22579c;--color-sidebar: #2D1F18;--color-steel: #5c5e5a;--color-danger: #863b1d;--color-accent: #9ba747;--color-text: #171717;--color-white: #ffffff;--color-primary-dark: #1a4278;--color-bg: #f4f6f8;--color-panel: #ffffff;--color-border: #d9e1e8;--color-muted: #6b7785;--color-muted-bg: #edf3f8;--font-heading: "Noto Serif Display", Georgia, "Times New Roman", serif;--font-body: "Lato", Arial, Helvetica, sans-serif;--shadow: 0 8px 24px rgba(20, 30, 40, .08);--shadow-lg: 0 16px 36px rgba(0, 0, 0, .18);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 16px}*,*:before,*:after{box-sizing:border-box}a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);font-size:15px;line-height:1.5;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased}h1{font-family:var(--font-heading);font-weight:400;color:var(--color-primary);margin:0 0 var(--space-4)}h2{font-family:var(--font-body);font-weight:400;text-transform:uppercase;letter-spacing:.06em;color:var(--color-steel);margin:0 0 var(--space-3)}h3{font-family:var(--font-body);font-weight:400;color:var(--color-text);margin:0 0 var(--space-3)}h4{font-family:var(--font-body);font-weight:700;color:var(--color-primary);margin:0 0 var(--space-2)}a{color:var(--color-accent);font-weight:700;text-decoration:none}a:hover{text-decoration:underline}p{margin:0 0 var(--space-3)}.hidden{display:none!important}.muted{color:var(--color-muted);font-size:13px}.status{font-size:13px;margin-top:var(--space-2);min-height:18px}.status.success{color:var(--color-accent)}.status.error{color:var(--color-danger)}button{font-family:var(--font-body);font-weight:700;font-size:15px;border:0;border-radius:var(--radius-md);padding:11px 16px;min-height:44px;cursor:pointer;transition:background .15s ease,opacity .15s ease}button:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-muted-bg);color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background:#dce9f4}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-danger:hover:not(:disabled){opacity:.88}.btn-sm{padding:9px 12px;min-height:44px;font-size:13px}input,textarea,select{font-family:var(--font-body);font-size:16px;width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:11px 14px;background:var(--color-white);color:var(--color-text);outline:none;transition:border-color .15s ease}input:focus,textarea:focus,select:focus{border-color:var(--color-primary)}textarea{min-height:200px;resize:vertical;line-height:1.5}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;font-weight:700;color:var(--color-muted)}.panel{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow);margin-bottom:var(--space-4)}.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:14px}.placeholder-box{border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);color:var(--color-muted);background:#fafcfe;font-size:14px}.page-content{padding:var(--space-4);max-width:100%;overflow-x:hidden}.tab-bar{display:flex;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-1);margin-bottom:14px}.tab-btn{white-space:nowrap;background:var(--color-muted-bg);color:var(--color-primary);border:1px solid #dce6ef;padding:10px 14px;min-height:44px;border-radius:var(--radius-md);font-weight:400}.tab-btn.active{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);font-weight:700}.list-stack{display:flex;flex-direction:column;gap:10px}.list-item{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px;background:var(--color-white)}.divider{border:0;border-top:1px solid var(--color-border);margin:var(--space-5) 0}
