*{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,Roboto,sans-serif;background:#1a1a1a}.app-container{width:100%;height:100%;position:relative}.canvas-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.welcome-screen{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);z-index:10}.welcome-content{text-align:center;color:#fff;max-width:700px;padding:40px}.welcome-content h1{font-size:3rem;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:1.1rem;color:#888;margin-bottom:40px}.welcome-options{display:flex;flex-direction:column;gap:30px}.sample-grid{display:flex;flex-direction:column;gap:12px}.sample-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.sample-grid h3{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:1px;margin-bottom:0}.source-toggle{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#666;cursor:pointer}.source-toggle span{transition:color .2s}.source-toggle span.active{color:#667eea;font-weight:500}.source-toggle input{display:none}.source-toggle .toggle-slider{width:36px;height:20px;background:#333;border-radius:10px;position:relative;transition:background .2s}.source-toggle .toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#888;border-radius:50%;transition:all .2s}.source-toggle input:checked+.toggle-slider:after{left:18px;background:#667eea}.no-local-files{padding:20px;color:#666;font-size:.9rem;text-align:center}.no-local-files code{display:block;margin-top:8px;padding:8px 12px;background:#0000004d;border-radius:6px;font-family:monospace;font-size:.8rem;color:#888}.sample-grid>div,.sample-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.sample-card{display:flex;flex-direction:column;align-items:center;padding:16px 24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .2s;min-width:100px}.sample-card:hover{background:#ffffff1a;border-color:#667eea80;transform:translateY(-2px)}.sample-name{font-size:.95rem;font-weight:500;color:#fff;text-transform:capitalize}.sample-ext{font-size:.7rem;color:#666;margin-top:4px}.drop-zone{border:2px dashed rgba(255,255,255,.2);border-radius:16px;padding:40px;transition:all .2s}.app-container.dragging .drop-zone{border-color:#667eea;background:#667eea1a}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.drop-icon{font-size:2.5rem;opacity:.5}.drop-zone p{margin:0;color:#888}.drop-hint{font-size:.8rem;color:#555}.app-container.dragging .drop-zone-content,.app-container.dragging .drop-icon{opacity:1}.controls-panel{position:absolute;top:20px;left:20px;z-index:100;background:#000000b3;padding:12px;border-radius:10px;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto;display:flex;flex-direction:column;gap:10px}.open-load-button{padding:10px 16px;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.open-load-button:hover{background:#535bf2}.compact-controls{display:flex;flex-direction:column;gap:8px}.compact-controls .button-row{gap:4px}.compact-controls .mode-button{padding:6px 12px;font-size:.75rem}.flip-toggle.compact{font-size:.75rem;gap:6px}.flip-toggle.compact input{width:14px;height:14px}.sample-buttons{margin-bottom:16px}.sample-buttons label{font-size:.875rem;font-weight:500;display:block;margin-bottom:8px}.button-row{display:flex;gap:8px;flex-wrap:wrap}.sample-button{padding:8px 16px;background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .2s;text-transform:capitalize}.sample-button:hover{background:#3a3a3a;border-color:#646cff}.sample-button:disabled{opacity:.5;cursor:not-allowed}.url-input-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.url-input-group label{font-size:.875rem;font-weight:500}.url-input-group input{padding:10px 12px;border:1px solid #444;border-radius:8px;background:#2a2a2a;color:#fff;font-size:.875rem}.url-input-group input:focus{outline:none;border-color:#646cff}.load-button{width:100%;padding:12px;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.load-button:hover{background:#535bf2}.load-button:disabled{background:#444;cursor:not-allowed}.status{margin-top:12px;padding:10px;border-radius:8px;font-size:.8rem}.status.loading{background:#646cff33;color:#a5a9ff}.status.error{background:#ff646433;color:#ffa5a5}.status.success{background:#64ff6433;color:#a5ffa5}.instructions{margin-top:16px;padding-top:16px;border-top:1px solid #333;font-size:.8rem;color:#888}.instructions ul{list-style:none;margin-top:8px}.instructions li{margin-bottom:4px}.instructions kbd{background:#333;padding:2px 6px;border-radius:4px;font-family:monospace}.format-info{margin-top:12px;padding:12px;border-radius:8px;font-size:.8rem}.format-info.gaussian-splat{background:#64c8ff26;border:1px solid rgba(100,200,255,.3)}.format-info.point-cloud{background:#ffb46426;border:1px solid rgba(255,180,100,.3)}.format-badge{font-weight:600;margin-bottom:4px}.gaussian-splat .format-badge{color:#7dd3fc}.point-cloud .format-badge{color:#fbbf24}.format-details{color:#aaa;font-size:.75rem}.format-note{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,180,100,.2);color:#d97706;font-size:.7rem;font-style:italic}.orientation-controls{margin-top:12px;padding:12px;background:#ffffff0d;border-radius:8px}.flip-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem}.flip-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#646cff}.flip-hint{color:#fbbf24;font-size:.75rem;font-style:italic}.camera-mode-selector{margin-top:12px;padding:12px;background:#ffffff0d;border-radius:8px}.camera-mode-selector label{font-size:.875rem;font-weight:500;display:block;margin-bottom:8px}.mode-button{padding:8px 16px;background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .2s;flex:1}.mode-button:hover{background:#3a3a3a;border-color:#646cff}.mode-button.active{background:#646cff;border-color:#646cff}.paint-mode-selector{margin-top:12px;padding:12px;background:#ffffff0d;border-radius:8px}.paint-mode-selector label{font-size:.875rem;font-weight:500;display:block;margin-bottom:8px}.brush-settings{margin-top:12px;padding:12px;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:8px}.brush-settings label{font-size:.875rem;font-weight:500;display:block;margin-bottom:10px;color:#ffa5a5}.brush-control{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:.8rem}.brush-control:last-child{margin-bottom:0}.brush-control span{min-width:80px;color:#ccc}.brush-control input[type=color]{width:40px;height:28px;border:1px solid #444;border-radius:4px;background:transparent;cursor:pointer}.brush-control input[type=range]{flex:1;height:6px;border-radius:3px;background:#333;cursor:pointer;accent-color:#ff6b6b}.color-presets{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.color-preset{width:28px;height:28px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s;padding:0}.color-preset:hover{transform:scale(1.1);border-color:#ffffff80}.color-preset.active{border-color:#fff;box-shadow:0 0 8px #ffffff80}.custom-color-picker{position:relative;width:28px;height:28px;border:2px dashed #666;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;overflow:hidden}.custom-color-picker:hover{border-color:#888;transform:scale(1.1)}.custom-color-picker input[type=color]{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer}.custom-color-picker .picker-icon{color:#888;font-size:16px;font-weight:700;pointer-events:none}.paint-toolbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:4px;padding:8px 12px;background:linear-gradient(180deg,#282832f2,#14141ef2);border:2px solid #4a4a5a;border-radius:8px;box-shadow:0 4px 20px #00000080,inset 0 1px #ffffff1a;z-index:100}.toolbar-slot{position:relative;width:48px;height:48px;background:linear-gradient(180deg,#3a3a4a,#2a2a3a);border:2px solid #5a5a6a;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s}.toolbar-slot:hover{border-color:#7a7a8a;transform:translateY(-2px)}.toolbar-slot.active{border-color:var(--slot-color, #fff);box-shadow:0 0 12px var(--slot-color, #fff),inset 0 0 8px #fff3;transform:translateY(-3px)}.toolbar-slot.eraser.active{border-color:#ff6b6b;box-shadow:0 0 12px #ff6b6b,inset 0 0 8px #fff3}.slot-color{width:32px;height:32px;border-radius:4px;box-shadow:inset 0 2px 4px #0000004d}.slot-icon{font-size:24px;color:#ff6b6b;font-weight:700}.slot-key{position:absolute;bottom:2px;right:4px;font-size:11px;font-weight:600;color:#ffffffb3;text-shadow:0 1px 2px rgba(0,0,0,.8);font-family:monospace}.toolbar-separator{width:2px;height:40px;background:linear-gradient(180deg,transparent,#5a5a6a,transparent);margin:4px 8px}.paint-toolbar:before{content:"Hold key to paint";position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:11px;color:#ffffff80;white-space:nowrap}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:12px;width:90%;max-width:400px;color:#fff;box-shadow:0 20px 60px #00000080}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #3a3a3a}.dialog-header h2{font-size:1.1rem;font-weight:600;margin:0}.dialog-close{background:none;border:none;color:#888;font-size:24px;cursor:pointer;padding:0;line-height:1;transition:color .2s}.dialog-close:hover{color:#fff}.dialog-content{padding:20px}.dialog-content .sample-buttons{margin-bottom:20px}.dialog-content .url-input-group{margin-bottom:16px}.dialog-content .load-button{width:100%}.dialog-content .format-info{margin-top:16px}.toolbar-slot.portal{background:linear-gradient(180deg,#3a4a5a,#2a3a4a)}.toolbar-slot.portal .slot-icon{font-size:24px}.toolbar-slot.portal:hover{border-color:#6af;box-shadow:0 0 8px #64aaff80}.toolbar-slot.help{background:linear-gradient(180deg,#4a4a5a,#3a3a4a)}.toolbar-slot.help .slot-icon{color:#aaa;font-size:20px;font-weight:700}.toolbar-slot.help:hover .slot-icon{color:#fff}.help-dialog{max-width:450px}.help-section{margin-bottom:20px}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:.9rem;font-weight:600;color:#888;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.help-section ul{list-style:none;padding:0;margin:0}.help-section li{padding:6px 0;font-size:.85rem;color:#ccc;border-bottom:1px solid #2a2a2a}.help-section li:last-child{border-bottom:none}.help-section kbd{background:#333;padding:2px 8px;border-radius:4px;font-family:monospace;font-size:.8rem;margin-right:4px}.help-section b{color:#fff}.canvas-container{touch-action:none}.toolbar-slot{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.toolbar-slot.bbox{background:linear-gradient(180deg,#5a4a5a,#4a3a4a)}.toolbar-slot.bbox .slot-icon{font-size:20px;color:#c8c}.toolbar-slot.bbox:hover{border-color:#c8c;box-shadow:0 0 8px #c864c880}.toolbar-slot.bbox.active{border-color:#c8c;box-shadow:0 0 12px #c864c899}.toolbar-slot.bbox.active .slot-icon{color:#f8f}.toolbar-slot.debug{background:linear-gradient(180deg,#4a5a4a,#3a4a3a)}.toolbar-slot.debug .slot-icon{font-size:20px}.toolbar-slot.debug:hover{border-color:#8c8;box-shadow:0 0 8px #64c86480}.toolbar-slot.debug.active{border-color:#8c8;box-shadow:0 0 12px #64c86499}.debug-dialog{max-width:500px}.debug-section{margin-bottom:20px}.debug-section h3{font-size:.85rem;font-weight:600;color:#888;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.debug-presets{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.debug-preset{display:flex;flex-direction:column;align-items:flex-start;padding:12px;background:#2a2a2a;border:2px solid #3a3a3a;border-radius:8px;cursor:pointer;transition:all .2s;color:#fff}.debug-preset:hover{border-color:#5a5a5a;background:#333}.debug-preset.active{border-color:#8c8;background:#64c86426}.preset-label{font-weight:600;font-size:.9rem}.preset-desc{font-size:.75rem;color:#888;margin-top:2px}.debug-preset.active .preset-desc{color:#8c8}.debug-legend{margin-top:16px;padding:12px;background:#ffffff0d;border-radius:8px}.legend-gradient{height:20px;border-radius:4px;margin-bottom:8px}.depth-gradient{background:linear-gradient(to right,#fff,#000)}.size-gradient{background:linear-gradient(to right,#06f,#0f6,red)}.legend-labels{display:flex;justify-content:space-between;font-size:.75rem;color:#888}.legend-colors{display:flex;flex-wrap:wrap;gap:12px}.legend-color-item{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#aaa}.color-swatch{width:16px;height:16px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.debug-sliders{display:flex;flex-direction:column;gap:16px}.debug-sliders label{display:flex;flex-direction:column;gap:6px}.debug-sliders label span{display:flex;justify-content:space-between;font-size:.85rem;color:#ccc}.debug-sliders input[type=range]{width:100%;height:6px;background:#333;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.debug-sliders input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#8c8;border-radius:50%;cursor:pointer}.debug-sliders input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#8c8;border-radius:50%;cursor:pointer;border:none}.debug-actions{display:flex;justify-content:flex-end;padding-top:12px;border-top:1px solid #3a3a3a}.reset-button{padding:8px 16px;background:#333;border:1px solid #4a4a4a;border-radius:6px;color:#aaa;font-size:.85rem;cursor:pointer;transition:all .2s}.reset-button:hover{background:#3a3a3a;color:#fff;border-color:#5a5a5a}.scale-legend-overlay{position:fixed;bottom:20px;right:20px;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:12px 16px;min-width:120px;z-index:100;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d}.scale-legend-title{font-size:.75rem;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.scale-legend-bar{height:12px;border-radius:3px;margin-bottom:4px}.scale-legend-labels{display:flex;justify-content:space-between;font-size:.7rem;color:#888}.scale-legend-axes{display:flex;gap:12px}.axis-item{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#ccc;font-weight:500}.axis-color{width:12px;height:12px;border-radius:2px}
