:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;top:0;right:0;bottom:0;left:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;top:100%;right:0;bottom:0;left:0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}:root{--color-bg-canvas: #1e1e1e;--color-bg-primary: #2c2c2c;--color-bg-secondary: #333333;--color-bg-hover: #3a3a3a;--color-bg-active: #404040;--color-text-primary: #ffffff;--color-text-secondary: #d4d4d8;--color-text-tertiary: #a1a1aa;--color-text-muted: #71717a;--color-border-subtle: rgba(255, 255, 255, .08);--color-border-secondary: rgba(255, 255, 255, .06);--color-border-visible: rgba(255, 255, 255, .15);--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-accent-subtle: rgba(59, 130, 246, .15);--color-success: #10b981;--color-success-subtle: rgba(16, 185, 129, .15);--color-warning: #f59e0b;--color-warning-subtle: rgba(245, 158, 11, .15);--color-danger: #f87171;--color-danger-subtle: rgba(248, 113, 113, .1);--color-overlay: rgba(15, 15, 15, .82);--font-2xs: 9px;--font-xs: 10px;--font-sm: 11px;--font-base: 12px;--font-md: 13px;--font-lg: 14px;--font-xl: 18px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 40px;--radius-sm: 4px;--radius-md: 6px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-float: 0 4px 16px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-toolbar: 0 1px 4px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .06);--shadow-pdf: 0 2px 16px rgba(0, 0, 0, .15);--z-panel: 10;--z-toolbar: 20;--z-toast: 100;--transition-fast: .1s ease;--transition-standard: .15s ease}.btn-primary{display:flex;align-items:center;justify-content:center;padding:var(--space-2) 14px;background:var(--color-text-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-sm);font-size:var(--font-base);font-weight:500;cursor:pointer;transition:opacity var(--transition-standard)}.btn-primary:hover{opacity:.8}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) 14px;background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);font-size:var(--font-base);font-weight:500;line-height:1;cursor:pointer;transition:background var(--transition-standard)}.btn-secondary:hover{background:var(--color-bg-hover)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary.reviewed-active{background:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success-text)}.btn-minimal{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);background:none;color:var(--color-text-secondary);border:none;font-size:var(--font-base);font-weight:500;line-height:1;cursor:pointer;transition:color var(--transition-standard)}.btn-minimal:hover{color:var(--color-text-primary)}.btn-minimal.reviewed-active{color:var(--color-success-text)}.tag{display:inline-flex;align-items:center;justify-content:center;gap:3px;font-size:var(--font-xs);font-weight:600;text-transform:capitalize;letter-spacing:0;padding:3px 6px;border-radius:8px;border:1px solid;white-space:nowrap;box-sizing:border-box}.tag-large{padding:6px 12px;border-radius:12px;height:26px}.tag-large.tag-selected{padding-right:8px}.tag-interactive{cursor:pointer;transition:all var(--transition-fast)}.tag-interactive:hover{background:color-mix(in srgb,var(--tag-color) 15%,transparent);border-color:color-mix(in srgb,var(--tag-color) 50%,transparent)}.tag-interactive:active{transform:scale(.97)}.tag-selected{background:var(--tag-color)!important;color:#fff!important;border-color:var(--tag-color)!important}.tag-selected:hover{opacity:.9}.tag-dark{background:var(--color-text-primary);color:var(--color-bg-primary)}.tag-light{background:var(--color-bg-active);color:var(--color-text-secondary)}.tag-success{background:var(--color-success-bg);border-color:var(--color-success-bg);color:var(--color-success-text);height:22px}.tag-info{background:var(--color-info-bg);border-color:var(--color-info-bg);color:var(--color-info-text);height:22px}.input{padding:6px var(--space-3);font-size:var(--font-base);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);outline:none;font-family:inherit;transition:border-color var(--transition-standard);background:var(--color-bg-primary);min-height:32px;box-sizing:border-box}.input:focus{border-color:var(--color-text-primary)}.input::placeholder{color:var(--color-text-disabled)}.input:disabled{background:var(--color-bg-secondary);color:var(--color-text-disabled);cursor:not-allowed;border-color:var(--color-border-secondary)}.card{background:var(--color-bg-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-md)}.label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary)}.form-error{background:var(--color-error-bg);color:var(--color-error-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-base);line-height:1.5}.form-success{background:var(--color-success-bg);color:var(--color-success-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-base);line-height:1.5}.form-actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-1)}.form-actions button{display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-icon{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-bg-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-standard);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.btn-icon:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-icon.active{background:var(--color-text-primary);color:var(--color-bg-primary);border-color:var(--color-text-primary)}.btn-icon:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.btn-icon-toggle{display:flex;align-items:center;justify-content:center;padding:4px;background:none;color:var(--color-text-tertiary);border:none;cursor:pointer;transition:all var(--transition-fast);line-height:1;opacity:.5}.btn-icon-toggle:hover{color:var(--color-text-primary);opacity:1}.btn-delete{display:flex;align-items:center;justify-content:center;padding:4px;background:none;color:var(--color-text-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);line-height:1;opacity:.5}.btn-delete:hover{background:#0000000d;opacity:1}.drag-handle{display:flex;align-items:center;justify-content:center;padding:var(--space-2);background:none;border:none;color:var(--color-text-tertiary);cursor:grab;opacity:.5;transition:opacity var(--transition-fast);flex-shrink:0;touch-action:none}.drag-handle:hover{opacity:1}.drag-handle:active{cursor:grabbing}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.anim-fade-in{animation:fadeIn .2s ease-in}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.align-self-end{align-self:flex-end}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-column{display:flex;flex-direction:column}.flex-column-center{display:flex;flex-direction:column;align-items:center;justify-content:center}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-uppercase-spaced{text-transform:uppercase;letter-spacing:.5px}.empty-state{display:flex;align-items:center;justify-content:center;min-height:200px;padding:var(--space-6);color:var(--color-text-disabled);font-size:var(--font-base);text-align:center}.empty-state p{margin:0}.empty-state-small{display:flex;align-items:center;justify-content:center;min-height:120px;padding:var(--space-4);color:var(--color-text-disabled);font-size:var(--font-base);text-align:center}.app-root{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg-primary);color:var(--color-text-primary)}.screen-container{flex:1;min-height:0;overflow:hidden;position:relative}.topbar{height:40px;display:flex;align-items:center;padding:0 12px;background:var(--color-bg-primary);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;z-index:50;gap:12px}.topbar-logo{font-size:var(--font-base);font-weight:700;color:var(--color-text-primary);letter-spacing:-.2px;white-space:nowrap;display:flex;align-items:center;gap:5px}.topbar-logo-dot{width:5px;height:5px;border-radius:50%;background:var(--color-accent)}.topbar-nav{display:flex;align-items:center;gap:1px;flex:1}.topbar-nav-item{padding:4px 10px;border-radius:5px;border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-base);font-family:inherit;cursor:pointer;transition:color .12s ease,background .12s ease;white-space:nowrap}.topbar-nav-item:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.topbar-nav-item.active{color:var(--color-text-primary);font-weight:600;background:var(--color-bg-hover)}.right-panel-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.right-panel-section--plans{flex:7}.right-panel-section--props{flex:3}.right-panel-scroll{flex:1;overflow-y:auto;min-height:0}.right-panel-scroll::-webkit-scrollbar{width:3px}.right-panel-scroll::-webkit-scrollbar-track{background:transparent}.right-panel-scroll::-webkit-scrollbar-thumb{background:var(--color-border-visible);border-radius:2px}.panel-split-line{flex-shrink:0;height:1px;background:var(--color-border-subtle)}.panel-header-btn{display:flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;border:1px solid var(--color-border-subtle);background:transparent;color:var(--color-text-tertiary);font-size:var(--font-xs);font-family:inherit;cursor:pointer;transition:color .12s,border-color .12s,background .12s}.panel-header-btn:hover{color:var(--color-text-primary);border-color:var(--color-border-visible);background:var(--color-bg-hover)}.sheet-row{display:flex;align-items:center;width:100%;padding:4px 8px 4px 4px;gap:4px;border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-sm);font-family:inherit;cursor:pointer;text-align:left;transition:background .1s,color .1s;-webkit-user-select:none;user-select:none}.sheet-row:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sheet-row.active{background:var(--color-bg-active);color:var(--color-text-primary)}.sheet-row.drag-over{box-shadow:inset 0 2px 0 var(--color-accent)}.sheet-code-cell{flex-shrink:0;width:52px;font-size:var(--font-xs);font-weight:600;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;padding:2px 4px;border-radius:3px;transition:background .1s}.sheet-code-cell:hover{background:var(--color-bg-hover)}.sheet-row.active .sheet-code-cell{color:var(--color-accent)}.sheet-name-cell{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 4px;border-radius:3px;transition:background .1s}.sheet-name-cell:hover{background:var(--color-bg-hover)}.sheet-rev-cell{flex-shrink:0;width:28px;text-align:center;font-size:var(--font-xs);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;padding:2px 4px;border-radius:3px;transition:background .1s}.sheet-rev-cell:hover{background:var(--color-bg-hover)}.sheet-cell-input{display:inline-block;min-width:3ch;max-width:100%;background:transparent;border:none;outline:1px solid var(--color-accent);border-radius:2px;color:var(--color-text-primary);font-size:var(--font-sm);font-family:inherit;padding:0 2px}.sheet-drop-end{height:10px;flex-shrink:0}.sheet-drop-end.active{box-shadow:inset 0 -2px 0 var(--color-accent)}.topbar-account{margin-left:auto;width:26px;height:26px;border-radius:50%;background:var(--color-bg-hover);border:1px solid var(--color-border-visible);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:700;color:var(--color-text-secondary);cursor:pointer;flex-shrink:0}.dashboard{height:100%;overflow-y:auto;background:var(--color-bg-secondary);padding:32px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-title{font-size:var(--font-xl);font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.dashboard-subtitle{font-size:var(--font-base);color:var(--color-text-secondary);margin-top:2px}.dashboard-filters{display:flex;gap:6px;margin-bottom:20px}.filter-chip{padding:4px 12px;border-radius:5px;border:1px solid var(--color-border-subtle);background:var(--color-bg-primary);color:var(--color-text-secondary);font-size:var(--font-sm);font-family:inherit;cursor:pointer;transition:all .12s ease}.filter-chip:hover{border-color:var(--color-border-visible);color:var(--color-text-primary)}.filter-chip.active{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg-primary)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.project-card{background:var(--color-bg-primary);border:1px solid var(--color-border-subtle);border-radius:6px;padding:16px;cursor:pointer;transition:border-color .12s ease}.project-card:hover{border-color:var(--color-border-visible)}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}.project-card-name{font-size:var(--font-md);font-weight:600;color:var(--color-text-primary);line-height:1.3}.project-status-chip{padding:1px 7px;border-radius:4px;font-size:var(--font-xs);font-weight:600;white-space:nowrap;flex-shrink:0;margin-left:8px}.project-status-chip.active{background:var(--color-success-subtle);color:var(--color-success)}.project-status-chip.tender{background:var(--color-warning-subtle);color:var(--color-warning)}.project-status-chip.complete{background:var(--color-border-secondary);color:var(--color-text-muted)}.project-card-address{font-size:var(--font-sm);color:var(--color-text-secondary);margin-bottom:14px;line-height:1.4}.project-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--color-border-subtle)}.project-card-value{font-size:var(--font-lg);font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.project-card-meta{font-size:var(--font-xs);color:var(--color-text-tertiary)}.new-project-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:5px;border:none;background:var(--color-accent);color:var(--color-text-primary);font-size:var(--font-base);font-weight:600;font-family:inherit;cursor:pointer;transition:background .12s ease}.new-project-btn:hover{background:var(--color-accent-hover)}.takeoff-view{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:var(--color-bg-canvas)}.takeoff-canvas-outer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:var(--color-bg-canvas);-webkit-user-select:none;user-select:none}.takeoff-canvas-inner{position:absolute;top:0;left:0}.pdf-wrapper{position:relative;display:inline-block}.measurements-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.canvas-zoom-label{position:absolute;bottom:16px;right:16px;background:var(--color-text-primary);border:1px solid var(--color-border-subtle);border-radius:4px;padding:3px 8px;font-size:var(--font-xs);color:var(--color-text-secondary);pointer-events:none;z-index:var(--z-toolbar)}.canvas-drawing-hint{position:absolute;bottom:72px;left:50%;transform:translate(-50%);background:var(--color-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--color-border-subtle);border-radius:20px;padding:5px 14px;font-size:var(--font-sm);color:var(--color-text-tertiary);pointer-events:none;white-space:nowrap;z-index:var(--z-toolbar);letter-spacing:.01em}.floating-panel{position:absolute;top:0;bottom:0;display:flex;flex-direction:column;background:var(--color-bg-primary);z-index:var(--z-panel);transition:transform .22s cubic-bezier(.4,0,.2,1)}.floating-panel--left{left:0;border-right:1px solid var(--color-border-subtle)}.ledger-resize-handle{position:absolute;top:0;right:0;width:5px;height:100%;cursor:col-resize;z-index:20;background:transparent;transition:background .15s ease}.ledger-resize-handle:hover,.ledger-resize-handle.resizing{background:var(--color-accent);opacity:.5}.floating-panel--right{right:0;width:252px;border-left:1px solid var(--color-border-subtle);transform:translate(0)}.floating-panel--right.collapsed{transform:translate(252px)}.panel-toggle-btn{position:absolute;top:50%;transform:translateY(-50%);width:18px;height:36px;border:1px solid var(--color-border-subtle);background:var(--color-bg-primary);color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .12s ease,background .12s ease;z-index:calc(var(--z-panel) + 1)}.panel-toggle-btn:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.floating-panel--left .panel-toggle-btn{right:-18px;border-left:none;border-radius:0 4px 4px 0}.floating-panel--right .panel-toggle-btn{left:-18px;border-right:none;border-radius:4px 0 0 4px}.panel-header{padding:0 10px;height:32px;border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--color-bg-secondary)}.panel-title{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-tertiary)}.panel-body{flex:1;overflow-y:auto}.panel-body::-webkit-scrollbar{width:3px}.panel-body::-webkit-scrollbar-track{background:transparent}.panel-body::-webkit-scrollbar-thumb{background:var(--color-border-visible);border-radius:2px}.ledger-table-scroll{flex:1;overflow:auto;min-height:0;position:relative}.ledger-table-scroll::-webkit-scrollbar{width:3px;height:3px}.ledger-table-scroll::-webkit-scrollbar-track{background:transparent}.ledger-table-scroll::-webkit-scrollbar-thumb{background:var(--color-border-visible);border-radius:2px}.ledger-table-scroll::-webkit-scrollbar-corner{background:transparent}.ledger-grid{min-width:max-content}.ledger-col-hd{display:flex;align-items:stretch;height:26px;border-bottom:1px solid var(--color-border-subtle);background:var(--color-bg-active);position:sticky;top:0;z-index:5;-webkit-user-select:none;user-select:none}.lhd-name{flex-shrink:0;position:relative;padding-left:8px;display:flex;align-items:center;font-size:var(--font-2xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary)}.lhd-col{flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;padding:0 4px;border-left:1px solid var(--color-border-subtle);font-size:var(--font-2xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary)}.lhd-col:last-child,.lhd-grid-cell:last-child{border-right:1px solid var(--color-border-subtle)}.lhd-resize-handle{position:absolute;top:0;right:-4px;width:8px;height:100%;cursor:col-resize;z-index:2}.resize-cursor-lock{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;-webkit-user-select:none;user-select:none}.resize-cursor-lock--col{cursor:col-resize}.resize-cursor-lock--panel{cursor:ew-resize}.ledger-list{display:block}.ledger-heading{display:flex;align-items:stretch;min-height:30px;background:var(--color-bg-hover);border-bottom:1px solid var(--color-border-subtle);cursor:pointer;-webkit-user-select:none;user-select:none}.ledger-heading:hover{background:var(--color-bg-active)}.ledger-heading.drag-into{background:var(--color-accent-subtle)!important}.lhd-grid-cell{flex-shrink:0;position:relative;border-left:1px solid var(--color-border-subtle)}.lhd-grid-cell.heading-subtotal{display:flex;align-items:center;justify-content:center;padding:0 6px;font-size:var(--font-xs);font-weight:600;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.heading-chevron{flex-shrink:0;align-self:center;width:16px;height:16px;border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;padding:0;transition:color .1s}.heading-chevron:hover{color:var(--color-text-primary)}.heading-name-col{flex-shrink:0;display:flex;align-items:stretch}.heading-name-wrap{flex:1;min-width:0;cursor:text;display:flex;align-items:center;padding:4px 2px}.heading-name{font-size:var(--font-sm);font-weight:600;color:var(--color-text-primary);white-space:normal;overflow-wrap:anywhere;line-height:1.4;display:block}.ledger-item{display:flex;align-items:stretch;min-height:30px;background:var(--color-bg-primary);border-bottom:1px solid var(--color-border-secondary);box-shadow:inset 2px 0 0 transparent;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.ledger-item:hover{background:var(--color-bg-hover)}.ledger-item--ghost{cursor:text}.ledger-item--ghost:hover{background:var(--color-bg-hover)}.ledger-item.selected{background:var(--color-accent-subtle)}.ledger-item.drag-before{box-shadow:inset 0 2px 0 var(--color-accent)}.ledger-item.drag-after{box-shadow:inset 0 -2px 0 var(--color-accent)}.li-name{flex-shrink:0;padding:4px;font-size:var(--font-sm);line-height:1.4;display:flex;align-items:center}.li-color-btn{flex-shrink:0;align-self:center;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;border-radius:3px;padding:0;transition:background .1s}.li-color-btn:hover{background:var(--color-bg-hover)}.li-type-dot{width:6px;height:6px;border-radius:50%;pointer-events:none;flex-shrink:0}.color-picker-popover{position:fixed;z-index:300;background:var(--color-bg-primary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:6px;display:grid;grid-template-columns:repeat(4,20px);gap:4px}.color-swatch{width:20px;height:20px;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;padding:0;transition:transform .1s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:#ffffff80}.li-name-text{display:block;color:var(--color-text-secondary);white-space:normal;overflow-wrap:anywhere}.ledger-item.selected .li-name-text{color:var(--color-text-primary)}.li-col{flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;padding:4px 6px;border-left:1px solid var(--color-border-subtle);font-size:var(--font-xs);font-variant-numeric:tabular-nums;color:var(--color-text-secondary)}.li-total{font-weight:600;color:var(--color-text-primary);border-right:1px solid var(--color-border-subtle)}.ledger-inline-input{margin:0;padding:0 2px;border:none;outline:none;box-shadow:0 0 0 1px var(--color-accent);border-radius:2px;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;font-size:var(--font-sm);color:var(--color-text-primary);background:transparent;width:100%;display:block;resize:none;overflow:hidden;white-space:pre-wrap;word-break:normal;overflow-wrap:anywhere}.ledger-inline-input.num{font-size:var(--font-xs);font-variant-numeric:tabular-nums;text-align:center}.ledger-select{width:100%;background:transparent;border:none;color:var(--color-text-secondary);font-family:inherit;font-size:var(--font-xs);cursor:pointer;outline:none;padding:0;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none}.ledger-select:hover,.ledger-select:focus{color:var(--color-text-primary)}.ledger-select:disabled{opacity:1;cursor:default;pointer-events:none}.ledger-drop-end{height:8px}.ledger-drop-end.active{box-shadow:inset 0 -2px 0 var(--color-accent)}.props-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:5px;padding:16px;text-align:center}.props-empty-icon{color:var(--color-text-tertiary)}.props-empty-text{font-size:var(--font-sm);color:var(--color-text-tertiary)}.props-list{padding:4px 0}.props-row{display:flex;align-items:baseline;justify-content:space-between;padding:4px 10px;font-size:var(--font-sm);color:var(--color-text-primary)}.props-row-label{color:var(--color-text-tertiary);flex-shrink:0;margin-right:8px}.props-row-value{text-align:right;word-break:break-word}.takeoff-toolbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:2px;padding:4px;background:var(--color-bg-primary);border-radius:100px;z-index:var(--z-toolbar);white-space:nowrap}.toolbar-btn{position:relative;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .12s ease;font-family:inherit}.toolbar-btn:hover{color:var(--color-text-primary)}.toolbar-btn.active{color:#fff}.toolbar-btn.disabled{opacity:.35;cursor:not-allowed}.toolbar-btn-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--color-accent)}.toolbar-divider{width:1px;height:18px;background:var(--color-border-subtle);margin:0 3px;flex-shrink:0}.toolbar-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;background:var(--color-text-primary);border-radius:4px;padding:3px 8px;font-size:var(--font-xs);color:var(--color-bg-primary);white-space:nowrap;pointer-events:none;z-index:1}.toolbar-context-pill{position:absolute;bottom:calc(100% + 8px);left:0;right:0;width:fit-content;margin:0 auto;display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg-primary);border:1px solid var(--color-border-subtle);border-radius:100px;white-space:nowrap;pointer-events:none}.toolbar-context-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.toolbar-context-name{font-size:var(--font-xs);color:var(--color-text-secondary)}.toast{position:fixed;bottom:70px;left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--color-text-primary);border-radius:100px;color:var(--color-bg-primary);font-size:var(--font-base);pointer-events:none;white-space:nowrap}.toast.success .toast-icon{color:var(--color-success)}.toast.error .toast-icon{color:var(--color-danger)}.toast.info .toast-icon{color:var(--color-accent)}.context-menu{position:fixed;z-index:200;background:var(--color-bg-primary);border:1px solid var(--color-border-subtle);border-radius:6px;padding:3px;min-width:144px}.ctx-item{display:flex;align-items:center;gap:7px;width:100%;text-align:left;padding:5px 9px;border:none;background:transparent;color:var(--color-text-primary);font-size:var(--font-base);font-family:inherit;cursor:pointer;border-radius:3px;transition:background .08s ease}.ctx-item:hover{background:var(--color-bg-hover)}.ctx-item--disabled{opacity:.35;cursor:default}.ctx-item--disabled:hover{background:transparent}.ctx-item--danger{color:var(--color-danger)}.ctx-item--danger:hover{background:var(--color-danger-subtle)}.ctx-divider{height:1px;background:var(--color-border-subtle);margin:2px 3px}@font-face{font-family:PP Object Sans;src:url(/fonts/PPObjectSans-Regular.otf) format("opentype");font-weight:100 900;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}button,h1,h2,h3,h4,h5,h6{font-family:inherit}html,body{height:100%;overflow:hidden}body{font-family:PP Object Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-canvas);color:var(--color-text-primary)}#root{height:100%}
