:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;position:relative}.main-content{display:flex;flex:1;overflow:hidden;position:relative;width:100%;height:100%}.canvas-container{flex:1;position:relative;overflow:hidden;min-width:0;width:100%;height:100%}.babylon-canvas{outline:none;border:none;display:block;width:100%;height:100%;position:absolute;top:0;left:0}.top-toolbar{background:#2c3e50;color:#fff;padding:0;box-shadow:0 2px 8px #00000026;z-index:1000;position:relative}.toolbar-menu{display:flex;height:48px;align-items:center;padding:0 15px;gap:0}.toolbar-brand{font-size:1.2em;font-weight:700;color:#ecf0f1;margin-right:30px;letter-spacing:.5px}.toolbar-status{display:flex;align-items:center;gap:20px;margin-right:30px;padding:0 15px;background:#ffffff1a;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.status-item{display:flex;align-items:center;gap:6px;font-size:11px}.status-label{color:#bdc3c7;font-weight:500}.status-value{color:#ecf0f1;font-weight:600;padding:2px 6px;border-radius:3px;background:#ffffff1a}.status-value.select{background:#95a5a6}.status-value.move{background:#3498db}.status-value.rotate{background:#e74c3c}.status-value.scale{background:#f39c12}.status-value.on{background:#27ae60}.status-value.off{background:#7f8c8d}.toolbar-item{position:relative;display:inline-block}.toolbar-button{background:none;border:none;color:#ecf0f1;padding:12px 16px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;border-radius:4px;display:flex;align-items:center;gap:6px}.toolbar-button:hover{background:#34495e;color:#3498db}.toolbar-button.active{background:#3498db;color:#fff}.toolbar-button .dropdown-arrow{font-size:10px;margin-left:4px}.dropdown-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 8px 24px #00000026;min-width:220px;max-width:320px;z-index:1001;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-section{padding:12px 0;border-bottom:1px solid #eee}.dropdown-section:last-child{border-bottom:none}.dropdown-section-title{font-size:11px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;padding:0 16px 8px;margin-bottom:8px}.dropdown-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 16px}.dropdown-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:10px;font-weight:500;color:#495057;text-align:center;min-height:60px}.dropdown-button:hover{background:#e9ecef;border-color:#3498db;color:#3498db}.dropdown-button.active{background:#e3f2fd;border-color:#3498db;color:#1976d2}.dropdown-icon{font-size:16px;margin-bottom:4px}.dropdown-controls{padding:12px 16px}.control-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.control-row:last-child{margin-bottom:0}.control-label{font-size:11px;color:#666;font-weight:500;min-width:50px}.control-input{width:60px;padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:11px;text-align:center}.control-input:focus{outline:none;border-color:#3498db}.control-checkbox{display:flex;align-items:center;gap:6px;font-size:11px;color:#495057;cursor:pointer}.control-checkbox input[type=checkbox]{margin:0;cursor:pointer}.color-picker{width:32px;height:24px;border:1px solid #ddd;border-radius:3px;cursor:pointer;padding:0;outline:none}.color-picker::-webkit-color-swatch{border:none;border-radius:2px}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker-large{width:60px;height:40px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:0;outline:none}.color-picker-large::-webkit-color-swatch{border:none;border-radius:3px}.color-picker-large::-webkit-color-swatch-wrapper{padding:0}.hex-input{width:80px;padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:11px;font-family:monospace;text-transform:uppercase}.hex-input:focus{outline:none;border-color:#3498db}.rgb-inputs{display:flex;gap:4px}.rgb-input{width:40px;padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:11px;text-align:center}.rgb-input:focus{outline:none;border-color:#3498db}.material-chips{display:flex;gap:4px;flex-wrap:wrap}.material-chip{width:20px;height:20px;border-radius:50%;border:1px solid #ddd;cursor:pointer;transition:transform .2s ease}.material-chip:hover{transform:scale(1.1)}.material-chip.active{border-width:2px;border-color:#3498db;transform:scale(1.1)}.dropdown-actions{display:flex;gap:6px;padding:0 16px}.dropdown-action{flex:1;padding:6px 12px;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;color:#495057;text-align:center;transition:all .2s ease}.dropdown-action:hover{background:#e9ecef;border-color:#adb5bd}.dropdown-action.danger{color:#dc3545;border-color:#dc3545}.dropdown-action.danger:hover{background:#f8d7da}.dropdown-action:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.camera-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:0 16px}.camera-button{padding:8px 4px;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:10px;font-weight:500;color:#495057;text-align:center;transition:all .2s ease}.camera-button:hover{background:#e9ecef;border-color:#3498db}.selection-info{background:#f8f9fa;padding:12px 16px;border-radius:4px;margin:0 16px;font-size:11px}.selection-info.has-selection{background:#e3f2fd;border:1px solid #bbdefb}.selected-object-name{font-weight:600;color:#1976d2;margin-bottom:4px}.selected-object-details{color:#424242;line-height:1.3}.no-selection-text{color:#666;font-style:italic}.ai-sidebar{width:360px;min-width:360px;max-width:360px;background:#fff;border-left:1px solid #e9ecef;box-shadow:-2px 0 10px #0000001a;overflow-y:auto;z-index:1001;display:flex;flex-direction:column;transition:all .3s ease;position:relative;flex-shrink:0}.ai-sidebar.collapsed{width:50px;min-width:50px;max-width:50px}.ai-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e9ecef;background:#f8f9fa;min-height:60px;flex-shrink:0}.ai-sidebar.collapsed .ai-sidebar-header{padding:16px 11px;justify-content:center}.ai-sidebar.collapsed .ai-sidebar-header h3{display:none}.ai-sidebar-header h3{margin:0;color:#2c3e50;font-size:1.2em;font-weight:600;flex:1}.sidebar-toggle{background:#3498db;border:none;color:#fff;width:28px;height:28px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s ease;flex-shrink:0}.sidebar-toggle:hover{background:#2980b9;transform:scale(1.05)}.ai-sidebar-content{padding:20px;flex:1;display:flex;flex-direction:column;gap:20px}.ai-control-group{display:flex;flex-direction:column;gap:12px}.ai-control-group label{font-weight:600;color:#2c3e50;font-size:13px;margin:0}.selection-mode-hint{font-size:11px;color:#6c757d;font-style:italic;padding:8px 12px;background:#f8f9fa;border-radius:4px;border-left:3px solid #3498db}.ai-text-input{width:100%;min-height:100px;padding:12px;border:1px solid #e9ecef;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;transition:all .2s ease;background:#fff;color:#2c3e50}.ai-text-input::placeholder{color:#95a5a6}.ai-text-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;color:#2c3e50}.ai-text-input:disabled{background-color:#f8f9fa;cursor:not-allowed;color:#6c757d}.ai-submit-button{width:100%;padding:12px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.ai-submit-button:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.ai-submit-button:disabled{background:#bdc3c7;cursor:not-allowed;transform:none}.ai-response-log{max-height:280px;overflow-y:auto;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px}.ai-log-entry{padding:10px 12px;margin:8px 0;border-radius:6px;font-size:12px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;border-left:3px solid transparent}.ai-log-entry:first-child{margin-top:0}.ai-log-entry:last-child{margin-bottom:0}.ai-log-entry.user{background:#e8f4fd;border-left-color:#3498db;color:#2c3e50}.ai-log-entry.ai{background:#e8f5e8;border-left-color:#27ae60;color:#2c3e50}.ai-log-entry.error{background:#fdf2f2;border-left-color:#e74c3c;color:#c0392b;font-weight:500}.ai-log-entry.ai-log-empty{background:#f8f9fa;border-left-color:#bdc3c7;color:#7f8c8d;font-style:italic;text-align:center}.scene-objects{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow-y:auto;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px}.scene-object{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-size:12px;transition:all .2s ease;cursor:pointer;position:relative}.scene-object:hover{background:#e9ecef;border-color:#adb5bd}.scene-object.selected{background:#e3f2fd;border-color:#3498db;border-width:2px}.scene-object.selected .object-type{color:#1976d2;font-weight:700}.scene-object.selected .object-id{color:#1976d2}.scene-object.locked{background:#ffebee;border-color:#ffcdd2}.scene-object.locked .object-type{color:#d32f2f}.scene-object.hidden{opacity:.5;background:#f5f5f5}.object-type{font-weight:600;color:#2c3e50;text-transform:capitalize}.object-id{color:#7f8c8d;font-family:monospace;flex:1}.object-controls{display:flex;gap:4px;align-items:center}.object-control-btn{background:none;border:none;cursor:pointer;font-size:12px;padding:2px 4px;border-radius:3px;transition:background-color .2s ease}.object-control-btn:hover{background:#0000001a}.object-control-btn.hidden{opacity:.4}.object-control-btn.locked{color:#d32f2f}.object-color{width:16px;height:16px;border-radius:50%;border:1px solid #e9ecef}.no-objects{text-align:center;color:#7f8c8d;font-style:italic;padding:24px;font-size:12px;background:#fff;border-radius:4px;border:1px dashed #bdc3c7}.object-stats{background:#fff;padding:8px 12px;border-radius:6px;text-align:center;border:1px solid #e9ecef;font-size:11px;color:#6c757d}.keyboard-shortcuts{display:grid;grid-template-columns:1fr 1fr;gap:6px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px;max-height:160px;overflow-y:auto}.shortcut-item{display:flex;align-items:center;gap:6px;padding:2px 4px;font-size:10px}.shortcut-key{background:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;padding:2px 4px;font-family:monospace;font-size:9px;color:#495057;font-weight:500;min-width:32px;text-align:center}.shortcut-desc{color:#6c757d;font-size:9px;flex:1}.clear-all-button{width:100%;padding:10px 12px;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-all-button:hover:not(:disabled){background:#c0392b;transform:translateY(-1px)}.clear-all-button:disabled{background:#bdc3c7;cursor:not-allowed;transform:none}.loading-indicator{text-align:center;padding:24px;color:#7f8c8d;font-style:italic;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.api-key-setup{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.api-key-container{background:#fff;padding:40px;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:500px;width:100%;text-align:center}.api-key-container h2{color:#2c3e50;margin-bottom:20px;font-size:2em}.api-key-container p{color:#7f8c8d;margin-bottom:20px;line-height:1.6}.api-key-input{width:100%;padding:15px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;margin-bottom:20px;transition:border-color .3s ease}.api-key-input:focus{outline:none;border-color:#3498db}.api-key-submit{width:100%;padding:15px;background:#3498db;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s ease;margin-bottom:15px}.api-key-submit:hover:not(:disabled){background:#2980b9}.api-key-submit:disabled{background:#bdc3c7;cursor:not-allowed}.api-key-note{font-size:12px;color:#95a5a6;font-style:italic}@media (max-width: 768px){.app-container,.main-content{flex-direction:column}.ai-sidebar{width:100%;height:350px;border-left:none;border-top:1px solid #e9ecef;box-shadow:0 -2px 10px #0000001a}.ai-sidebar.collapsed{width:100%;height:50px}.ai-sidebar-header{padding:12px 15px;min-height:50px}.ai-sidebar-header h3{font-size:1.1em}.ai-sidebar-content{padding:15px;gap:15px}.ai-text-input{min-height:80px}.ai-response-log,.scene-objects{max-height:120px}.toolbar-menu{flex-wrap:wrap;height:auto;min-height:48px;padding:8px 15px}.toolbar-brand{margin-right:15px;margin-bottom:8px}.toolbar-status{display:none}.dropdown-menu{position:fixed;top:auto;left:50%;transform:translate(-50%);max-width:90vw}.dropdown-menu.show{transform:translate(-50%) translateY(0)}}.nurbs-properties{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px;margin-top:8px}.nurbs-info{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:8px;background:#fff;border-radius:4px;border:1px solid #e9ecef}.nurbs-info-item{display:flex;justify-content:space-between;align-items:center;font-size:11px}.nurbs-label{color:#6c757d;font-weight:500}.nurbs-value{color:#2c3e50;font-weight:600;font-family:monospace}.nurbs-control-section{margin-bottom:12px;padding:8px;background:#fff;border-radius:4px;border:1px solid #e9ecef}.nurbs-section-title{font-size:11px;font-weight:600;color:#495057;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid #e9ecef}.nurbs-quality-control{display:flex;align-items:center;gap:8px}.nurbs-quality-slider{flex:1;height:4px;background:#e9ecef;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none}.nurbs-quality-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#3498db;border-radius:50%;cursor:pointer;border:2px solid #ffffff;box-shadow:0 2px 4px #0003}.nurbs-quality-slider::-moz-range-thumb{width:16px;height:16px;background:#3498db;border-radius:50%;cursor:pointer;border:2px solid #ffffff;box-shadow:0 2px 4px #0003}.nurbs-quality-value{font-size:11px;font-weight:600;color:#2c3e50;font-family:monospace;min-width:20px;text-align:center}.control-points-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.control-point-item{padding:8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;transition:all .2s ease}.control-point-item.selected{background:#e3f2fd;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.control-point-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.control-point-label{font-size:10px;font-weight:600;color:#495057;font-family:monospace}.control-point-selected-indicator{color:#27ae60;font-size:12px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.control-point-coords{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}.control-point-coord{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.control-point-coord label{font-size:9px;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.control-point-input{width:100%;padding:4px 6px;border:1px solid #dee2e6;border-radius:3px;font-size:10px;font-family:monospace;text-align:center;transition:border-color .2s ease}.control-point-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.control-point-item.selected .control-point-input{border-color:#3498db;background:#fff}.nurbs-export-controls{display:flex;gap:8px}.nurbs-export-button{flex:1;padding:8px 12px;background:#28a745;color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.nurbs-export-button:hover{background:#218838;transform:translateY(-1px)}.nurbs-export-button:active{transform:translateY(0)}.nurbs-help{margin-top:8px;padding:8px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;font-size:10px;line-height:1.4}.nurbs-help small{margin:0}.control-point-sphere{cursor:pointer}.control-point-sphere:hover{transform:scale(1.1)}.control-points-list::-webkit-scrollbar{width:4px}.control-points-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.control-points-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.control-points-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){.nurbs-properties{padding:8px}.control-point-coords{grid-template-columns:1fr;gap:6px}.control-point-coord{flex-direction:row;align-items:center;justify-content:space-between}.control-point-coord label{min-width:20px}.control-point-input{width:60px}.control-points-list{max-height:150px}}
