:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#252833;--border:#333845;--text:#e1e4ea;--text-dim:#8b8fa3;--primary:#4f8ff7;--primary-hover:#3a7be0;--danger:#e55050;--warning:#e5a850;--success:#50c878;--invalid:#e55050;--radius:6px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}.app{max-width:900px;min-height:100vh;margin:0 auto;padding:0 16px}.app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 0;display:flex}.app-header h1{font-size:1.25rem}.header-right{align-items:center;gap:12px;display:flex}.user-badge{color:var(--text-dim);background:var(--surface-2);border-radius:var(--radius);padding:4px 10px;font-size:.85rem}button{cursor:pointer;border-radius:var(--radius);border:none;padding:6px 14px;font-size:.875rem;transition:background .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-save{background:var(--success);color:#fff}.btn-cancel{background:var(--surface-2);color:var(--text)}.btn-warning{background:var(--warning);color:#000}.btn-danger{background:var(--danger);color:#fff}.btn-settings{background:var(--surface-2);color:var(--text)}.btn-back{color:var(--primary);background:0 0;padding:0;font-size:.9rem}.btn-sm{background:var(--surface-2);color:var(--text);padding:4px 10px;font-size:.8rem}.btn-icon{color:var(--text-dim);background:0 0;padding:2px 6px;font-size:1.1rem}.btn-icon:hover{color:var(--danger)}.btn-add-row{background:var(--surface-2);color:var(--text-dim);margin-top:8px;font-size:.8rem}.btn-new-cluster{background:var(--primary);color:#fff;font-size:.8rem}input,select{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);width:100%;padding:6px 10px;font-size:.875rem}input:focus{border-color:var(--primary);outline:none}input.readonly{opacity:.6;cursor:default}label{color:var(--text-dim);flex-direction:column;gap:4px;font-size:.8rem;display:flex}.checkbox-label{cursor:pointer;flex-direction:row;align-items:center;gap:8px}.checkbox-label input{width:auto}.session-list-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.create-session{background:var(--surface);border-radius:var(--radius);align-items:flex-end;gap:8px;margin-bottom:16px;padding:12px;display:flex}.empty-state{color:var(--text-dim);font-style:italic}.session-card{background:var(--surface);border-radius:var(--radius);border-left:3px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:8px;padding:12px 16px;display:flex}.session-card.active{border-left-color:var(--success)}.session-card.closed{border-left-color:var(--warning)}.session-info{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.session-date,.session-scans{color:var(--text-dim);font-size:.85rem}.session-status{text-transform:uppercase;border-radius:12px;padding:2px 8px;font-size:.75rem}.status-active{background:var(--success);color:#000}.status-closed{background:var(--warning);color:#000}.session-actions{gap:6px;display:flex}.session-view-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.session-view-header h2{font-size:1.1rem}.scan-form{background:var(--surface);border-radius:var(--radius);padding:20px}.cluster-control{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.cluster-id{color:var(--text-dim);flex:1;font-family:monospace;font-size:.85rem}.form-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px;display:grid}.materials-section{margin-bottom:16px}.materials-section h4{margin-bottom:8px;font-size:.9rem}.material-header{color:var(--text-dim);border-bottom:1px solid var(--border);grid-template-columns:30px 1fr 90px 80px 70px 30px;gap:6px;padding:0 0 4px;font-size:.75rem;display:grid}.material-row-wrap{grid-template-columns:1fr 70px;align-items:center;display:grid}.material-row{grid-template-columns:30px 1fr 90px 80px 30px;align-items:center;gap:6px;padding:4px 0;display:grid}.material-row.partial{opacity:.5}.mat-index{color:var(--text-dim);text-align:center;font-size:.75rem}.mat-volume-calc{color:var(--text-dim);text-align:right;font-size:.8rem}.autocomplete{position:relative}.autocomplete input{width:100%}.autocomplete-dropdown{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);z-index:50;max-height:180px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.autocomplete-dropdown li{cursor:pointer;padding:6px 10px;font-size:.85rem}.autocomplete-dropdown li:hover,.autocomplete-dropdown li.highlighted{background:var(--primary);color:#fff}.validation-checks{flex-wrap:wrap;gap:10px;margin-bottom:12px;display:flex}.validation-badge{white-space:nowrap;border-radius:12px;padding:3px 10px;font-size:.8rem}.validation-badge.valid{color:var(--success);background:#50c87826}.validation-badge.invalid{color:var(--invalid);background:#e5505026}.validation-errors{border:1px solid var(--invalid);border-radius:var(--radius);background:#e550501a;margin-bottom:12px;padding:10px}.validation-errors .error{color:var(--invalid);padding:2px 0;font-size:.8rem}.scan-counter{color:var(--text-dim);margin-left:12px;font-size:.85rem}.scan-list{margin-top:24px}.scan-list h3{margin-bottom:8px;font-size:.95rem}.scan-table{border-collapse:collapse;width:100%;font-size:.85rem}.scan-table th,.scan-table td{text-align:left;border-bottom:1px solid var(--border);padding:6px 10px}.scan-table th{color:var(--text-dim);font-weight:500}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;width:90%;max-width:440px;padding:24px}.modal h2{margin-bottom:16px;font-size:1.1rem}.modal h3{margin-top:16px;margin-bottom:8px;font-size:.95rem}.settings-section{flex-direction:column;gap:10px;display:flex}.settings-section.danger{border-top:1px solid var(--danger);margin-top:4px;padding-top:12px}.settings-section.danger h3{color:var(--danger)}.small-text{color:var(--text-dim);font-size:.78rem}.modal-actions{gap:8px;margin-top:20px;display:flex}.setup-prompt{text-align:center;color:var(--text-dim);padding:40px 20px}.setup-prompt p{margin-bottom:16px}.ocr-controls{background:var(--surface-2);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:8px 12px;display:flex}.ocr-buttons{flex-shrink:0;gap:6px;display:flex}.ocr-status{align-items:center;gap:8px;min-width:0;padding:2px 0;font-size:.8rem;display:flex}.ocr-status-icon{flex-shrink:0;font-size:1rem}.ocr-status-message{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ocr-status-confidence{color:var(--success);flex-shrink:0}.ocr-status-idle{color:var(--text-dim)}.ocr-status-capturing{color:var(--primary)}.ocr-status-processing{color:var(--warning)}.ocr-status-success{color:var(--success)}.ocr-status-error{color:var(--danger)}.capture-overlay{z-index:200;background:#000;flex-direction:column;display:flex;position:fixed;inset:0}.capture-overlay-toolbar{background:var(--surface);color:var(--text);z-index:201;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;font-size:.85rem;display:flex}.capture-overlay-actions{flex-shrink:0;gap:8px;display:flex}.capture-overlay-canvas{object-fit:contain;cursor:crosshair;flex:1;width:100%}.capture-overlay-message{height:100%;color:var(--text);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:1rem;display:flex}.preview-overlay{z-index:200;background:var(--bg);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.preview-header{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:8px 16px;display:flex}.preview-title{white-space:nowrap;margin-right:6px;font-size:1rem;font-weight:600}.preview-profile-status{flex-wrap:wrap;flex:1;align-items:center;gap:6px;display:flex}.preview-profile-name{color:var(--text-dim);font-family:monospace;font-size:.78rem}.status-pill{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:.75rem}.status-pill.ok{color:var(--success);background:#50c87826}.status-pill.warn{color:var(--warning);background:#e5a85026}.preview-error{border-bottom:1px solid var(--danger);color:var(--danger);background:#e550501f;flex-shrink:0;padding:6px 16px;font-size:.82rem}.preview-body{flex:1;gap:0;display:flex;overflow:hidden}.preview-frame-col{border-right:1px solid var(--border);flex-direction:column;flex:65%;min-width:0;display:flex;overflow:hidden}.preview-frame-canvas{object-fit:contain;background:#000;flex:1;width:100%;display:block}.preview-legend{background:var(--surface);flex-shrink:0;gap:16px;padding:4px 12px;font-size:.75rem;display:flex}.legend-anchor{color:var(--success)}.legend-subanchor{color:var(--primary)}.legend-roi{color:#ffe066}.preview-roi-col{flex:0 0 35%;min-width:0;padding:8px;overflow-y:auto}.preview-roi-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px;display:grid}.roi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:3px;padding:4px;display:flex}.roi-card-missing{border-color:var(--danger);opacity:.6}.roi-card-name{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;justify-content:space-between;align-items:center;gap:4px;font-family:monospace;font-size:.7rem;display:flex;overflow:hidden}.roi-card-mode{color:var(--primary);opacity:.7;flex-shrink:0;font-size:.65rem}.roi-card-canvas{width:100%;image-rendering:pixelated;background:#000;display:block}.roi-card-oob{color:var(--danger);text-align:center;padding:4px 0;font-size:.7rem}
