*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f172a;color:#e2e8f0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh;background:#0f172a;color:#e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.app-header{display:flex;align-items:center;padding:0 16px;height:48px;background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0}.app-logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:20px;color:#f59e0b}.logo-text{font-size:18px;font-weight:700;color:#f8fafc}.logo-subtitle{font-size:12px;color:#64748b;margin-left:4px}.toolbar{display:flex;align-items:center;padding:0 12px;height:44px;background:#1e293b;border-bottom:1px solid #334155;gap:4px;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:2px}.toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid transparent;border-radius:6px;background:transparent;color:#94a3b8;font-size:13px;cursor:pointer;transition:all .15s}.toolbar-btn:hover{background:#334155;color:#e2e8f0}.toolbar-btn.active{background:#f59e0b;color:#1e293b;font-weight:600}.toolbar-btn.mode-btn{padding:5px 14px;font-weight:500}.toolbar-btn.mode-btn.active{background:#3b82f6;color:#fff}.toolbar-icon{font-size:16px}.toolbar-label{font-size:12px}.toolbar-divider{width:1px;height:24px;background:#334155;margin:0 8px}.toolbar-spacer{flex:1}.toolbar-zoom{font-size:12px;color:#94a3b8;min-width:44px;text-align:center;font-variant-numeric:tabular-nums}.toolbar-filename{font-size:11px;color:#64748b;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px}.view-tabs{display:flex;align-items:center;padding:0 12px;height:36px;background:#0f172a;border-bottom:1px solid #1e293b;gap:2px;overflow-x:auto;flex-shrink:0}.view-tab{display:flex;align-items:center;gap:6px;padding:4px 14px;border-radius:6px 6px 0 0;background:#1e293b;color:#64748b;font-size:12px;cursor:pointer;border:1px solid #334155;border-bottom:none;transition:all .15s}.view-tab:hover{color:#e2e8f0}.view-tab.active{background:#334155;color:#f8fafc;border-color:#475569}.view-tab-icon{font-size:14px}.view-tab-rename{background:#0f172a;border:1px solid #3b82f6;border-radius:3px;color:#f8fafc;font-size:12px;padding:1px 4px;width:100px;outline:none;font-family:inherit}.view-tab-close{background:none;border:none;color:#64748b;font-size:14px;cursor:pointer;padding:0 2px;line-height:1}.view-tab-close:hover{color:#ef4444}.add-tab{background:transparent;border:1px dashed #475569;color:#64748b}.add-tab:hover{border-color:#f59e0b;color:#f59e0b}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;overflow-y:auto;flex-shrink:0;background:#1e293b;border-right:1px solid #334155}.sidebar-right{border-right:none;border-left:1px solid #334155}.canvas-area{flex:1;overflow:hidden;position:relative}.icon-palette{padding:12px}.palette-title{font-size:13px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}.palette-category{margin-bottom:12px}.palette-category-title{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px;padding-bottom:4px;border-bottom:1px solid #334155}.palette-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.palette-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border:1px solid transparent;border-radius:6px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s}.palette-item:hover{background:#334155;border-color:#475569}.palette-item.active{background:#334155;border-color:#f59e0b}.palette-item-label{font-size:9px;text-align:center;line-height:1.2}.palette-hint{font-size:11px;color:#475569;margin-top:12px;padding:8px;background:#0f172a;border-radius:6px;text-align:center}.properties-panel{padding:12px}.properties-empty{color:#475569;font-size:13px;text-align:center;padding:24px 12px}.properties-title{font-size:14px;font-weight:600;color:#f8fafc;margin:0 0 12px}.properties-icon-preview{display:flex;align-items:center;gap:10px;padding:8px;background:#0f172a;border-radius:6px;margin-bottom:12px}.properties-field{margin-bottom:10px}.properties-field label{display:block;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.properties-field input[type=text],.properties-field textarea{width:100%;padding:6px 8px;background:#0f172a;border:1px solid #334155;border-radius:4px;color:#e2e8f0;font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box}.properties-field input:focus,.properties-field textarea:focus{outline:none;border-color:#3b82f6}.properties-field input[type=range]{width:100%}.properties-section{margin-top:14px;padding-top:14px;border-top:1px solid #334155}.properties-section h4{font-size:12px;font-weight:600;color:#94a3b8;margin:0 0 8px}.properties-hint{font-size:11px;color:#475569;margin-top:8px}.media-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:8px}.media-thumb{position:relative;aspect-ratio:4/3;border-radius:4px;overflow:hidden;border:1px solid #334155}.media-thumb img,.media-thumb video{width:100%;height:100%;object-fit:cover}.media-thumb-overlay{position:absolute;top:0;right:0;display:flex;gap:4px;padding:4px}.media-type-badge{font-size:12px}.media-remove{background:#0009;border:none;color:#fff;width:18px;height:18px;border-radius:50%;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.media-caption{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background:#0009;font-size:9px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-actions{display:flex;gap:6px}.btn{padding:6px 12px;border-radius:4px;border:1px solid #334155;background:#1e293b;color:#e2e8f0;font-size:12px;cursor:pointer;transition:all .15s}.btn:hover{background:#334155}.btn-sm{padding:4px 10px;font-size:11px}.btn-primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-danger{border-color:#dc2626;color:#ef4444}.btn-danger:hover{background:#dc2626;color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:#64748b}.btn-ghost:hover{color:#e2e8f0;background:#334155}.badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600}.badge-ndaa{background:#166534;color:#4ade80}.badge-feature{background:#1e293b;color:#94a3b8;border:1px solid #334155}.popup-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.popup-container{background:#1e293b;border:1px solid #334155;border-radius:12px;max-width:900px;max-height:85vh;width:90vw;overflow:hidden;display:flex;flex-direction:column;position:relative}.popup-close{position:absolute;top:12px;right:12px;background:#00000080;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}.popup-close:hover{background:#fff3}.popup-header{padding:20px 24px 12px}.popup-header h2{margin:0;font-size:20px;color:#f8fafc}.popup-description{color:#94a3b8;font-size:14px;margin:6px 0 0}.popup-media{position:relative;flex:1;overflow:hidden}.popup-viewer{display:flex;align-items:center;justify-content:center;min-height:300px;max-height:60vh;background:#0f172a}.popup-image{max-width:100%;max-height:60vh;object-fit:contain}.popup-video{max-width:100%;max-height:60vh}.popup-caption{text-align:center;padding:8px;font-size:13px;color:#94a3b8;background:#0f172a}.popup-nav{position:absolute;top:50%;transform:translateY(-50%);background:#0009;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.popup-nav:hover{background:#fff3}.popup-nav-prev{left:12px}.popup-nav-next{right:12px}.popup-thumbs{display:flex;gap:6px;padding:10px 16px;overflow-x:auto;background:#0f172a}.popup-thumb{width:60px;height:45px;border:2px solid transparent;border-radius:4px;overflow:hidden;cursor:pointer;padding:0;background:#334155;flex-shrink:0}.popup-thumb.active{border-color:#f59e0b}.popup-thumb img{width:100%;height:100%;object-fit:cover}.popup-thumb-video{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:20px}.popup-counter{text-align:center;padding:6px;font-size:12px;color:#64748b;background:#0f172a}.popup-empty{padding:40px;text-align:center;color:#475569;font-size:14px}.product-selector{background:#1e293b;border:1px solid #334155;border-radius:12px;max-width:1000px;max-height:85vh;width:95vw;overflow:hidden;display:flex;flex-direction:column;position:relative;padding:24px}.product-selector h2{margin:0 0 4px;font-size:20px;color:#f8fafc}.product-filters{display:flex;gap:10px;margin:16px 0;align-items:center;flex-wrap:wrap}.product-search{flex:1;min-width:200px;padding:8px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:14px}.product-search:focus{outline:none;border-color:#3b82f6}.product-filters select{padding:8px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px}.ndaa-filter{display:flex;align-items:center;gap:6px;font-size:13px;color:#94a3b8;cursor:pointer}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;overflow-y:auto;max-height:55vh;padding:4px}.product-card{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:14px;cursor:pointer;transition:all .15s}.product-card:hover{border-color:#3b82f6;transform:translateY(-1px)}.product-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.product-brand{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase}.product-card-model{font-size:11px;color:#475569;font-family:monospace;margin-bottom:4px}.product-card-name{font-size:14px;font-weight:600;color:#e2e8f0;margin-bottom:6px}.product-model{font-size:10px;color:#475569;font-family:monospace}.product-resolution{font-size:16px;font-weight:700;color:#3b82f6;margin-bottom:6px}.product-features{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.product-specs-grid,.product-specs-mini{font-size:11px}.spec-row{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid #1e293b}.spec-key{color:#64748b;font-weight:500}.spec-val{color:#cbd5e1;text-align:right}.product-card-mini{background:#0f172a;border:1px solid #334155;border-radius:6px;padding:10px}.product-actions{display:flex;gap:6px;margin-top:8px}.product-empty{padding:40px;text-align:center;color:#475569;font-size:14px}.scope-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;max-width:800px;max-height:85vh;width:90vw;display:flex;flex-direction:column;position:relative;padding:24px}.scope-modal h2{margin:0 0 16px;font-size:20px;color:#f8fafc}.scope-content{flex:1;overflow-y:auto;background:#0f172a;border:1px solid #334155;border-radius:8px;padding:16px;font-size:13px;line-height:1.6;color:#e2e8f0;white-space:pre-wrap;font-family:Cascadia Code,Fira Code,Consolas,monospace;max-height:60vh}.scope-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.properties-row{display:flex;gap:8px}.properties-field-half{flex:1}.properties-field input[type=number]{width:100%;padding:6px 8px;background:#0f172a;border:1px solid #334155;border-radius:4px;color:#e2e8f0;font-size:13px;font-family:inherit;box-sizing:border-box}.properties-field input[type=number]:focus{outline:none;border-color:#3b82f6}.properties-pricing-summary{margin-top:8px;padding:8px;background:#0f172a;border-radius:4px;font-size:12px}.estimate-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;max-width:900px;max-height:90vh;width:95vw;display:flex;flex-direction:column;position:relative;overflow:hidden}.estimate-tabs{display:flex;border-bottom:1px solid #334155;padding:0 24px;flex-shrink:0}.estimate-tab{padding:12px 20px;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-size:14px;font-weight:500;cursor:pointer}.estimate-tab:hover{color:#e2e8f0}.estimate-tab.active{color:#f8fafc;border-bottom-color:#3b82f6}.estimate-settings{padding:24px;overflow-y:auto;flex:1}.estimate-settings-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #334155}.estimate-settings-section:last-child{border-bottom:none}.estimate-settings-section h4{font-size:13px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}.logo-upload-area{padding:12px;background:#0f172a;border-radius:6px;text-align:center}.logo-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.logo-preview-img{max-height:80px;max-width:240px;object-fit:contain}.logo-preview-actions{display:flex;gap:6px}.estimate-preview-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden}.estimate-preview{flex:1;overflow-y:auto;padding:40px;background:#fff;color:#1a1a1a;margin:16px 24px;border-radius:8px;font-size:13px;max-height:65vh}.estimate-preview .est-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:20px;border-bottom:3px solid #1a1a1a}.estimate-preview .est-logo{max-height:80px;max-width:200px;object-fit:contain}.estimate-preview .est-company{text-align:right}.estimate-preview .est-company-name{font-size:22px;font-weight:700;margin-bottom:4px}.estimate-preview .est-company-detail{font-size:12px;color:#555;line-height:1.6}.estimate-preview .est-title{font-size:28px;font-weight:700;margin:24px 0 8px}.estimate-preview .est-meta{display:flex;gap:40px;margin-bottom:24px;font-size:13px;color:#555}.estimate-preview .est-meta-item strong{color:#1a1a1a}.estimate-preview .est-section{margin:20px 0 8px;font-size:14px;font-weight:700;text-transform:uppercase;color:#555;border-bottom:1px solid #ddd;padding-bottom:4px}.estimate-preview table{width:100%;border-collapse:collapse;margin-bottom:16px}.estimate-preview th{text-align:left;font-size:11px;text-transform:uppercase;color:#888;padding:6px 8px;border-bottom:2px solid #ddd}.estimate-preview th.right,.estimate-preview td.right{text-align:right}.estimate-preview td{padding:6px 8px;border-bottom:1px solid #eee;font-size:13px}.estimate-preview .desc{color:#555;font-size:11px}.estimate-preview .est-totals{margin-top:24px;border-top:2px solid #1a1a1a;padding-top:12px}.estimate-preview .est-total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:14px}.estimate-preview .est-total-row.grand{font-size:20px;font-weight:700;border-top:2px solid #1a1a1a;padding-top:12px;margin-top:8px}.estimate-preview .est-terms{margin-top:32px;padding-top:16px;border-top:1px solid #ddd;font-size:12px;color:#555;line-height:1.8}.estimate-preview .est-footer{margin-top:40px;text-align:center;font-size:11px;color:#aaa}.estimate-actions{display:flex;gap:8px;padding:12px 24px 20px;justify-content:flex-end;flex-shrink:0}.properties-margin-display{display:flex;flex-direction:column;gap:2px;padding:8px 0 0;min-height:40px;justify-content:center}.margin-pct{font-size:16px;font-weight:700}.margin-pct.good{color:#22c55e}.margin-pct.low{color:#f59e0b}.margin-pct.negative{color:#ef4444}.margin-profit{font-size:11px;color:#94a3b8}.margin-na{color:#64748b;font-size:14px}.estimate-manual-materials{padding:16px 24px;border-top:1px solid #334155}.estimate-manual-materials h4{font-size:13px;margin-bottom:8px}.manual-material-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}.manual-mat-desc{flex:1;min-width:0}.manual-mat-qty{width:60px}.manual-mat-price{width:80px}.estimate-margin-summary{padding:16px 24px;border-top:1px solid #334155;background:#0f172a}.estimate-margin-summary h4{font-size:13px;margin-bottom:10px;color:#94a3b8}.margin-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.margin-summary-item{display:flex;justify-content:space-between;padding:6px 10px;background:#1e293b;border-radius:6px;font-size:13px}.margin-summary-item.highlight{grid-column:1 / -1;background:#1e3a5f;font-weight:600}.margin-label{color:#94a3b8}.margin-value{font-weight:600}.margin-value.positive,.margin-value.good{color:#22c55e}.margin-value.low{color:#f59e0b}.margin-value.negative{color:#ef4444}.canvas-draw-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#000c;color:#94a3b8;padding:6px 16px;border-radius:20px;font-size:12px;pointer-events:none;white-space:nowrap;z-index:10}.canvas-label-input{position:absolute;z-index:20;transform:translate(-4px,-4px)}.canvas-label-input input{background:#000000d9;border:2px solid #3b82f6;border-radius:4px;color:#fff;font-size:16px;font-weight:700;padding:4px 8px;width:200px;outline:none}.toolbar-snap{display:flex;align-items:center;gap:4px;font-size:12px;color:#94a3b8;cursor:pointer;padding:0 4px}.toolbar-snap input[type=checkbox]{accent-color:#3b82f6}.toolbar-install-progress{display:flex;align-items:center;gap:6px;padding:0 4px}.toolbar-install-bar{width:48px;height:4px;background:#334155;border-radius:2px;overflow:hidden}.toolbar-install-fill{display:block;height:100%;background:#22c55e;border-radius:2px;transition:width .3s}.toolbar-install-text{font-size:11px;color:#94a3b8;font-variant-numeric:tabular-nums}.toolbar-opacity{display:flex;align-items:center;gap:4px;padding:0 4px}.toolbar-opacity input[type=range]{width:60px;height:4px;accent-color:#3b82f6}.color-swatches{display:flex;flex-wrap:wrap;gap:4px}.color-swatch{width:24px;height:24px;border-radius:4px;border:2px solid transparent;cursor:pointer;padding:0}.color-swatch:hover{border-color:#94a3b8}.color-swatch.active{border-color:#f59e0b;box-shadow:0 0 0 1px #f59e0b}.address-modal{background:#1e293b;border:1px solid #334155;border-radius:12px;max-width:600px;width:90vw;position:relative;padding:24px}.address-modal h2{margin:0 0 4px;font-size:20px;color:#f8fafc}.address-select{width:100%;padding:8px 10px;background:#0f172a;border:1px solid #334155;border-radius:4px;color:#e2e8f0;font-size:13px;font-family:inherit;box-sizing:border-box}.address-select:focus{outline:none;border-color:#3b82f6}.address-error{background:#7f1d1d;color:#fca5a5;padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.address-preview{margin:12px 0;border-radius:8px;overflow:hidden;background:#0f172a;border:1px solid #334155;min-height:200px}.address-preview img{width:100%;display:block}.address-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.layers-panel{padding:12px;border-top:1px solid #334155}.layers-actions{display:flex;gap:6px;margin-bottom:10px}.layers-group{margin-bottom:4px}.layers-group-header{display:flex;align-items:center;gap:4px;padding:4px 6px;border-radius:4px;cursor:pointer;font-size:12px;color:#e2e8f0;background:#0f172a}.layers-group-header:hover{background:#1e293b}.layers-group-header.collapsed{opacity:.8}.layers-group-members{padding-left:12px}.layers-group-name-input{flex:1;background:#0f172a;border:1px solid #3b82f6;border-radius:3px;color:#f8fafc;font-size:12px;padding:1px 4px;outline:none;font-family:inherit}.layers-item{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:3px;cursor:pointer;font-size:12px;color:#94a3b8}.layers-item:hover{background:#334155;color:#e2e8f0}.layers-item.selected{background:#1e3a5f;color:#f8fafc}.layers-item-icon{font-size:12px;width:16px;text-align:center;flex-shrink:0}.layers-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}.layers-toggle{background:none;border:none;color:#64748b;font-size:11px;cursor:pointer;padding:2px 4px;border-radius:3px;flex-shrink:0}.layers-toggle:hover{color:#e2e8f0;background:#334155}.text-muted{color:#64748b;font-size:12px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0f172a}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#475569}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0f172a;padding:16px}.login-card{width:100%;max-width:380px;background:#1e293b;border:1px solid #334155;border-radius:12px;padding:32px}.login-header{text-align:center;margin-bottom:24px}.login-header h1{font-size:28px;font-weight:700;color:#f8fafc;margin:8px 0 4px}.login-subtitle{color:#64748b;font-size:13px}.login-form{display:flex;flex-direction:column;gap:12px}.login-field{display:flex;flex-direction:column;gap:4px}.login-field label{font-size:12px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.login-field input{padding:10px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:14px;font-family:inherit}.login-field input:focus{outline:none;border-color:#3b82f6}.login-error{background:#7f1d1d;color:#fca5a5;padding:8px 12px;border-radius:6px;font-size:13px}.login-btn{width:100%;padding:12px!important;font-size:14px!important;font-weight:600;margin-top:4px}.login-toggle{width:100%;text-align:center;font-size:13px!important}.login-role-group{display:flex;flex-direction:column;gap:6px}.login-role-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;background:#0f172a;border:2px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;text-align:left;transition:all .15s}.login-role-btn:hover{border-color:#475569}.login-role-btn.active{border-color:#3b82f6;background:#1e3a5f}.login-role-label{font-size:14px;font-weight:600}.login-role-desc{font-size:11px;color:#64748b}.project-list-container{flex:1;overflow-y:auto;padding:24px;max-width:960px;margin:0 auto;width:100%}.project-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.project-list-header h2{font-size:22px;font-weight:700;color:#f8fafc;margin:0}.project-list-actions{display:flex;gap:10px;align-items:center}.project-search-input{padding:8px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px;width:200px}.project-search-input:focus{outline:none;border-color:#3b82f6}.new-project-form{display:flex;gap:8px;margin-bottom:20px;padding:16px;background:#1e293b;border:1px solid #334155;border-radius:8px;flex-wrap:wrap}.new-project-form input{flex:1;min-width:160px;padding:8px 12px;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px}.new-project-form input:focus{outline:none;border-color:#3b82f6}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.project-card{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:16px;cursor:pointer;transition:all .15s;position:relative}.project-card:hover{border-color:#3b82f6;transform:translateY(-1px)}.project-card-name{font-size:16px;font-weight:600;color:#f8fafc;margin-bottom:4px}.project-card-location{font-size:13px;color:#94a3b8;margin-bottom:8px}.project-card-meta{font-size:11px;color:#64748b}.project-card-delete{position:absolute;top:12px;right:12px;opacity:0;transition:opacity .15s}.project-card:hover .project-card-delete{opacity:1}.project-list-empty{text-align:center;color:#64748b;padding:60px 20px;font-size:14px}.install-panel{padding:12px;display:flex;flex-direction:column;height:100%;overflow:hidden}.install-panel-title{font-size:14px;font-weight:600;color:#f8fafc;margin:0 0 12px}.install-progress{margin-bottom:12px}.install-progress-bar{height:6px;background:#334155;border-radius:3px;overflow:hidden;margin-bottom:6px}.install-progress-fill{height:100%;background:#22c55e;border-radius:3px;transition:width .3s ease}.install-progress-stats{display:flex;justify-content:space-between;font-size:11px;color:#94a3b8}.install-progress-counts{display:flex;gap:0}.install-view-tabs{display:flex;gap:4px;margin-bottom:8px;overflow-x:auto;flex-shrink:0}.install-view-tab{padding:4px 10px;border:1px solid #334155;border-radius:4px;background:transparent;color:#64748b;font-size:11px;cursor:pointer;white-space:nowrap}.install-view-tab:hover{color:#e2e8f0;border-color:#475569}.install-view-tab.active{background:#334155;color:#f8fafc;border-color:#475569}.install-filters{display:flex;gap:4px;margin-bottom:10px;flex-shrink:0}.install-filter-btn{flex:1;padding:4px 6px;border:1px solid #334155;border-radius:4px;background:transparent;color:#64748b;font-size:10px;cursor:pointer}.install-filter-btn:hover{color:#e2e8f0}.install-filter-btn.active{background:#1e3a5f;border-color:#3b82f6;color:#60a5fa}.install-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.install-empty{text-align:center;color:#475569;padding:24px 12px;font-size:13px}.install-item{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:10px;cursor:pointer;transition:all .15s}.install-item:hover{border-color:#475569}.install-item.selected{border-color:#3b82f6;background:#0f172a}.install-item.complete{border-left:3px solid #22c55e}.install-item.flagged{border-left:3px solid #f59e0b}.install-item-header{display:flex;align-items:center;gap:8px}.install-check{width:28px;height:28px;border-radius:6px;border:2px solid #475569;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.install-check:hover{border-color:#22c55e;background:#22c55e1a}.install-check.complete{border-color:#22c55e;background:#22c55e26}.install-check.flagged{border-color:#f59e0b;background:#f59e0b26}.install-item-icon{flex-shrink:0}.install-item-info{flex:1;min-width:0}.install-item-type{font-size:12px;font-weight:600}.install-qty{font-weight:400;color:#94a3b8;font-size:11px}.install-item-location{font-size:13px;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.install-flag-btn{width:28px;height:28px;border-radius:6px;border:1px solid #334155;background:transparent;color:#64748b;font-size:14px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.install-flag-btn:hover{border-color:#f59e0b;color:#f59e0b;background:#f59e0b1a}.install-unflag-btn{width:28px;height:28px;border-radius:6px;border:1px solid #475569;background:transparent;color:#94a3b8;font-size:12px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.install-unflag-btn:hover{border-color:#ef4444;color:#ef4444}.install-scope{margin-top:8px;padding:8px;background:#1e293b;border-radius:4px;font-size:12px;color:#cbd5e1;line-height:1.5}.install-scope-label{font-weight:600;color:#94a3b8;font-size:10px;text-transform:uppercase;letter-spacing:.05em}.install-deviation{margin-top:6px;padding:8px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:4px;font-size:12px;color:#fbbf24;line-height:1.5}.install-deviation-label{font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#f59e0b}.install-deviation-meta{font-size:10px;color:#92400e;margin-top:4px}.install-completed-meta{margin-top:4px;font-size:10px;color:#4ade80}.install-flag-form{margin-top:8px;display:flex;flex-direction:column;gap:6px}.install-flag-input{width:100%;padding:8px;background:#1e293b;border:1px solid #f59e0b;border-radius:6px;color:#e2e8f0;font-size:13px;font-family:inherit;resize:vertical;box-sizing:border-box}.install-flag-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}.install-flag-actions{display:flex;gap:6px;justify-content:flex-end}.field-capture-page{display:flex;flex-direction:column;height:100vh;background:#0f172a;color:#e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.field-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0}.field-header-title{flex:1;display:flex;align-items:center;gap:6px}.field-captures{flex:1;overflow-y:auto;padding:12px}.field-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:#64748b;font-size:16px}.field-capture-card{display:flex;gap:12px;padding:12px;background:#1e293b;border:1px solid #334155;border-radius:8px;margin-bottom:8px;align-items:center}.field-capture-thumb{width:64px;height:48px;border-radius:4px;overflow:hidden;flex-shrink:0}.field-capture-thumb img{width:100%;height:100%;object-fit:cover}.field-capture-info{flex:1;min-width:0}.field-capture-type{font-size:12px;font-weight:600}.field-capture-label{font-size:14px;color:#f8fafc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-capture-gps{font-size:10px;color:#64748b;font-family:monospace}.field-capture-time{font-size:10px;color:#475569}.field-saved-badge{color:#22c55e;font-size:16px;flex-shrink:0}.field-fab-group{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:100}.field-capture-fab{width:64px;height:64px;border-radius:50%;background:#f59e0b;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 16px #f59e0b66;display:flex;align-items:center;justify-content:center;transition:transform .15s}.field-fab-video{width:52px;height:52px;font-size:22px;background:#3b82f6;box-shadow:0 4px 16px #3b82f666}.field-capture-fab:active{transform:scale(.95)}.field-action-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#1e293b;border-bottom:1px solid #334155;flex-shrink:0}.field-capture-count{font-size:12px;color:#64748b}.field-address-panel{padding:12px;background:#1e293b;border-bottom:1px solid #334155}.field-address-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.field-address-header h3{font-size:14px;font-weight:600;margin:0}.field-address-options{display:flex;gap:8px;align-items:center;margin-top:8px}.field-address-zoom-label{font-size:12px;color:#94a3b8}.field-address-select{background:#0f172a;color:#e2e8f0;border:1px solid #334155;border-radius:6px;padding:4px 8px;font-size:12px}.field-address-error{color:#ef4444;font-size:12px;margin-top:6px}.field-address-preview{margin-top:8px;border-radius:8px;overflow:hidden}.field-address-preview img{width:100%;display:block}.field-capture-scope{font-size:11px;color:#94a3b8;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.field-form{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.field-photo-preview{position:relative;border-radius:8px;overflow:hidden;max-height:40vh}.field-photo-preview img{width:100%;max-height:40vh;object-fit:contain;background:#1e293b}.field-gps-badge{position:absolute;bottom:8px;left:8px;background:#000000b3;color:#94a3b8;padding:4px 8px;border-radius:4px;font-size:11px;font-family:monospace}.field-type-btn{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:14px;font-weight:600;cursor:pointer}.field-type-grid{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:12px;max-height:40vh;overflow-y:auto}.field-type-category{margin-bottom:8px}.field-type-category-name{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;margin-bottom:4px}.field-type-options{display:flex;flex-wrap:wrap;gap:4px}.field-type-option{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid #334155;border-radius:6px;background:#0f172a;color:#e2e8f0;font-size:12px;cursor:pointer}.field-type-option.active{background:#334155}.field-input{width:100%;padding:12px;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:14px;font-family:inherit;box-sizing:border-box}.field-input:focus{outline:none;border-color:#3b82f6}.field-textarea{resize:vertical;min-height:48px}.field-form-actions{display:flex;gap:8px;justify-content:flex-end;padding-bottom:env(safe-area-inset-bottom,8px)}.field-save-next{background:#22c55e!important;border-color:#22c55e!important;color:#fff!important;font-weight:600}@media(max-width:768px){.app-body{flex-direction:column}.sidebar{width:100%;max-height:35vh;border-right:none;border-bottom:1px solid #334155}.sidebar-right{border-left:none;border-top:1px solid #334155;border-bottom:none;max-height:40vh}.canvas-area{min-height:40vh}.toolbar{flex-wrap:wrap;height:auto;min-height:44px;padding:4px 8px;gap:2px}.toolbar-group{flex-wrap:wrap}.toolbar-btn{padding:6px 8px;font-size:12px}.toolbar-label,.toolbar-divider{display:none}.toolbar-spacer{flex-basis:100%;height:0}.toolbar-filename{display:none}.icon-palette{padding:8px}.palette-grid{grid-template-columns:repeat(4,1fr)}.view-tabs{height:auto;flex-wrap:wrap;padding:4px 8px}.popup-container,.scope-modal,.estimate-modal,.product-selector,.address-modal{width:98vw;max-height:92vh;border-radius:8px}.estimate-preview{padding:16px;margin:8px}.properties-panel,.layers-panel{padding:8px}.media-grid{grid-template-columns:repeat(3,1fr)}.project-list-container{padding:16px}.project-list-header{flex-direction:column;align-items:stretch}.project-list-actions{flex-direction:column}.project-search-input{width:100%}.project-grid{grid-template-columns:1fr}}@media(max-width:480px){.palette-grid{grid-template-columns:repeat(3,1fr)}.toolbar-btn .toolbar-icon{font-size:18px}.properties-row{flex-direction:column}}
