:root{--bg: #1a1a2e;--surface: #16213e;--surface-alt: #0f3460;--text: #e0e0e0;--text-muted: #888;--accent: #e94560;--accent-hover: #ff6b81;--border: #2a2a4a;--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{display:grid;grid-template-columns:1fr 6px 1fr;height:100vh;background:var(--border)}.resize-handle{background:var(--border);cursor:col-resize;position:relative;z-index:5;touch-action:none}.resize-handle:hover,.resize-handle:active{background:var(--accent)}.source-panel{background:var(--surface);display:flex;flex-direction:column;overflow:hidden}.source-panel__header{display:flex;gap:0;border-bottom:1px solid var(--border)}.source-panel__tab{flex:1;padding:10px 16px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .15s}.source-panel__tab--active{color:var(--accent);border-bottom:2px solid var(--accent);background:#e945600d}.source-panel__content{flex:1 1 auto;display:flex;flex-direction:column;min-height:300px}.webcam-view{flex:1;display:flex;flex-direction:column;min-height:0}.webcam-container{position:relative;flex:1;min-height:0;background:#000;overflow:hidden}.webcam-container video{width:100%;height:100%;object-fit:contain}.webcam-container__frozen{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.circle-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.circle-overlay svg{width:100%;height:100%}.circle-overlay__handle{pointer-events:all;cursor:grab}.circle-overlay__handle:active{cursor:grabbing}.circle-overlay__resize{pointer-events:all;cursor:nwse-resize}.webcam-actions{display:flex;flex-wrap:wrap;gap:8px;padding:8px 12px;background:var(--surface);border-top:1px solid var(--border);align-items:center}.image-upload{flex:1;display:flex;flex-direction:column;min-height:200px}.image-upload__dropzone{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed var(--border);margin:12px;border-radius:var(--radius);cursor:pointer;transition:border-color .15s;position:relative;overflow:hidden}.image-upload__dropzone--active{border-color:var(--accent);background:#e945600d}.image-upload__dropzone--has-image{border-style:solid;background:#000;cursor:default}.image-upload__dropzone img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.image-upload__url{display:flex;gap:8px;padding:0 12px 12px}.image-upload__url input{flex:1}.control-panel{border-top:1px solid var(--border);overflow-y:auto;flex:0 1 auto;max-height:40vh}.control-section{border-bottom:1px solid var(--border)}.control-section__header{display:flex;align-items:center;width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text);cursor:pointer;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:left;line-height:1.4;transition:background .1s;user-select:none;-webkit-user-select:none}.control-section__header:hover{background:#ffffff0d}.control-section__reset{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 4px;line-height:1;opacity:0;transition:opacity .15s,color .15s}.control-section__header:hover .control-section__reset{opacity:.7}.control-section__reset:hover{opacity:1!important;color:var(--accent)}.control-section__arrow{display:inline-block;width:12px;font-size:10px;color:var(--text-muted);transition:transform .15s}.control-section__arrow--open{transform:rotate(90deg)}.control-section__body{padding:6px 12px 12px}.control-section__actions{display:flex;gap:8px;margin-bottom:8px}.control-section__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px}.control-section__toggles{display:flex;gap:14px;flex-wrap:wrap;padding:6px 0}.control-panel__group{display:flex;flex-direction:column;gap:2px}.control-panel__group--full{grid-column:1 / -1}.control-panel label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.control-panel input[type=number],.control-panel input[type=range]{width:100%}.control-panel select{width:100%;padding:4px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:12px}.control-panel select:disabled{opacity:.5}.preview-panel{background:#000;position:relative;display:flex;flex-direction:column}.preview-panel__canvas{flex:1}.preview-panel__scene{flex:1;display:flex;transition:opacity .25s ease}.preview-panel__scene--processing{opacity:.35;pointer-events:none}.preview-panel__toolbar{display:flex;gap:8px;padding:8px 12px;background:var(--surface);border-top:1px solid var(--border);align-items:center}.preview-panel__status{flex:1;font-size:12px;color:var(--text-muted)}.preview-panel__status a{color:var(--text-muted);text-decoration:underline}.preview-panel__status a:hover{color:var(--text)}.preview-panel__toggle{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted);cursor:pointer;white-space:nowrap}.preview-panel__toggle input{accent-color:var(--accent)}.btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-alt);color:var(--text);cursor:pointer;font-size:13px;transition:all .15s;white-space:nowrap}.btn:hover{background:var(--accent);border-color:var(--accent)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn--accent{background:#7c3aed;border-color:#7c3aed;color:#fff;font-weight:600}.btn--accent:hover{background:#6d28d9;border-color:#6d28d9}.btn--sm{padding:4px 10px;font-size:12px}.btn--active{background:#059669;border-color:#059669;color:#fff}.btn--active:hover{background:#047857;border-color:#047857}input[type=number]{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:4px 6px;font-size:13px;width:100%}input[type=range]{accent-color:var(--accent)}input[type=range]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.threshold-editor{grid-column:1 / -1;padding:2px 0 4px}.threshold-editor__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:4px}.threshold-editor__bar{position:relative;height:24px;border-radius:4px;border:1px solid var(--border);cursor:default}.threshold-editor__bar--auto{opacity:.7}.threshold-editor__handle{position:absolute;top:-3px;width:10px;height:30px;margin-left:-5px;background:var(--accent);border:2px solid #fff;border-radius:3px;cursor:ew-resize;touch-action:none;z-index:2;transition:background .1s,opacity .1s}.threshold-editor__handle:hover,.threshold-editor__handle:active{background:var(--accent-hover)}.threshold-editor__handle--auto{cursor:default;opacity:.5}.threshold-editor__labels{display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--text-muted);padding-top:2px}.toggle--sm{font-size:11px}.toggle--sm input{width:28px;height:16px}.threshold-editor__reset{background:none;border:none;color:var(--accent);font-size:10px;cursor:pointer;padding:0 4px;text-decoration:underline}.threshold-editor__reset:hover{color:var(--accent-hover)}.toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px}.toggle input{width:36px;height:20px;accent-color:var(--accent)}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--accent);transition:width .2s}.shortcuts-legend{position:absolute;bottom:50px;right:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:12px;line-height:1.8;color:var(--text);z-index:10}.shortcuts-legend kbd{background:var(--bg);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:11px;font-family:inherit;margin-right:6px}@media(max-width:768px){.app{grid-template-columns:1fr!important;grid-template-rows:1fr auto 1fr}.resize-handle{cursor:row-resize;height:6px}}.heightmap-preview{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#111;padding:16px;min-height:0}.heightmap-preview__canvas{max-width:100%;max-height:calc(100% - 30px);object-fit:contain;border-radius:var(--radius);image-rendering:pixelated}.heightmap-preview__legend{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);margin-top:8px}.heightmap-preview__gradient{width:120px;height:10px;border-radius:3px;background:linear-gradient(to right,#000,#fff)}.heightmap-preview__gradient--heatmap{background:linear-gradient(to right,#000,#1e0064,#5000b4,#b400c8,#e63c3c,#ffa000,#ffe632,#fff)}
