.error-boundary{display:flex;flex-direction:column;justify-content:center;align-items:center;height:400px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;color:#666}.error-boundary h3{margin:0 0 10px;font-size:18px}.error-boundary p{margin:0 0 15px;font-size:14px}.error-reload-button{padding:8px 16px;background:#1976d2;color:white;border:none;border-radius:4px;cursor:pointer;font-size:14px}.error-reload-button:hover{background:#1565c0}.mesa-container{width:100vw;display:flex;background-color:#e2e8f0;overflow:hidden;margin:0;padding:0;position:relative}.controls-panel,.mesa-container{height:calc(100vh - 64px);min-height:calc(100vh - 64px)}.controls-panel{width:350px;min-width:350px;max-width:350px;max-height:calc(100vh - 64px);background:rgba(255,255,255,.98);padding:20px;border-right:1px solid #e0e0e0;overflow-y:auto;box-shadow:2px 0 10px rgba(0,0,0,.1);flex-shrink:0;z-index:100}.controls-panel::-webkit-scrollbar{width:8px}.controls-panel::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.controls-panel::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#0f172a,#1e3a8a);border-radius:10px}.controls-panel::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#1e293b,#1e40af)}.controls-section{margin-bottom:16px}.controls-section-small{margin-bottom:12px}.controls-title{margin:0 0 8px;font-size:14px}.main-title{margin:0 0 20px;font-size:20px;font-weight:600;color:#1f2937;text-align:center;padding:20px 12px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:10px;border:1px solid #cbd5e1;line-height:1.4}.color-grid{grid-template-columns:repeat(5,1fr);gap:10px;max-width:340px;margin-bottom:12px}.color-button{width:54px;height:54px;padding:0;border:none;border-radius:8px}.color-button:hover{transform:scale(1.05);box-shadow:0 2px 8px rgba(0,0,0,.2)}.color-button.selected{border:2px solid red}.color-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:15px!important}.color-row .color-button{flex:1;min-width:50px;max-width:55px;height:36px;padding:4px 6px;font-size:10px;font-weight:500}.range-control{display:flex;align-items:center;gap:10px;margin-bottom:8px}.range-label{font-size:12px}.range-input{width:120px}.range-value{font-size:11px;color:#666;min-width:35px}.range-description{font-size:11px;color:#888}.camera-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:8px}.camera-button{padding:6px 8px;background-color:#f0f0f0;color:#333;border:1px solid #ccc;border-radius:4px;font-size:10px;font-weight:500;cursor:pointer;transition:all .2s}.camera-button.selected{background-color:#1565c0;color:white}.debug-button{padding:6px 12px;background-color:#f0f0f0;color:black;border:1px solid #ccc;border-radius:4px;font-size:11px;cursor:pointer}.debug-button.active{background-color:#007acc;color:white}.debug-info{margin-top:10px;padding:8px;background-color:#f8f8f8;border-radius:4px;font-size:10px;border:1px solid #e0e0e0}.debug-title{font-weight:700;margin-bottom:5px}.debug-description{color:#666;margin-bottom:8px}.debug-details{font-size:9px;color:#888}.model-container{flex:1;justify-content:flex-start;padding:0 24px 16px;min-height:100vh;position:relative;height:100%;max-width:none;background:linear-gradient(135deg,#f8fafc,#e2e8f0);overflow:hidden}.model-container,.model-title{display:flex;flex-direction:column;align-items:center;width:100%}.model-title{margin-bottom:0;text-align:center;justify-content:center}.breadcrumb-nav{display:flex;align-items:center;justify-content:center;position:relative}.breadcrumb-list{display:flex;align-items:center;list-style:none;margin:0;padding:0;overflow:hidden}.breadcrumb-item{display:flex;align-items:center;position:relative}.breadcrumb-content{display:flex;align-items:center;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s ease;min-height:20px}.breadcrumb-content:hover{color:#1f2937}.breadcrumb-icon{font-size:16px!important;margin-right:8px;color:#6b7280;transition:color .2s ease}.breadcrumb-content:hover .breadcrumb-icon{color:#4f46e5}.breadcrumb-text{white-space:nowrap;font-weight:500}.breadcrumb-separator{font-size:16px!important;color:#9ca3af;margin:0 4px;flex-shrink:0}@media (max-width:1024px){.breadcrumb-list{flex-wrap:wrap;border:none;box-shadow:none;background:transparent}.breadcrumb-item{margin:4px 0}.breadcrumb-item:not(:last-child){border-right:none}.breadcrumb-content{background:#ffffff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 1px 3px rgba(0,0,0,.1);margin-right:8px}.breadcrumb-separator{display:none}}@media (max-width:768px){.breadcrumb-content{padding:8px 12px;font-size:12px}.breadcrumb-icon{font-size:14px!important;margin-right:6px}}.canvas-container{width:100%;height:calc(100vh - 240px);min-height:420px;max-height:72vh;background:linear-gradient(135deg,#ffffff,#f8fafc 50%,#e2e8f0);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.8);border:1px solid rgba(226,232,240,.8);position:relative;padding:0;display:flex;align-items:center;justify-content:center;aspect-ratio:16/9;backdrop-filter:blur(10px);text-align:center;contain:layout style paint}.canvas-3d,.canvas-container{overflow:hidden;box-sizing:border-box;margin:0 auto;max-width:100%;transform:translateZ(0)}.canvas-3d{background:linear-gradient(135deg,#ffffff,#f8fafc);width:100%!important;height:100%!important;display:block;max-height:100%;object-fit:contain;object-position:center center;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;will-change:transform;position:absolute;top:0;left:0;right:0;bottom:0}@media (min-width:2560px){.canvas-container{height:calc(100vh - 144px);max-height:96vh;min-height:840px}}@media (min-width:1920px){.canvas-container{height:calc(100vh - 160px);max-height:96vh;min-height:780px}}@media (min-width:1200px) and (max-width:1919px){.canvas-container{height:calc(100vh - 176px);max-height:90vh;min-height:720px}}@media (min-width:992px) and (max-width:1199px){.canvas-container{height:calc(100vh - 192px);max-height:84vh;min-height:540px}}@media (min-width:768px) and (max-width:991px){.canvas-container{height:calc(100vh - 224px);max-height:78vh;min-height:480px;width:100%;aspect-ratio:4/3}}@media (min-width:481px) and (max-width:767px){.canvas-container{height:calc(100vh - 256px);max-height:72vh;min-height:420px;width:100%;aspect-ratio:16/10}}@media (min-width:320px) and (max-width:480px){.canvas-container{height:calc(100vh - 280px);max-height:66vh;min-height:360px;width:100%;aspect-ratio:4/3}}@media (max-width:319px){.canvas-container{height:calc(100vh - 304px);max-height:60vh;min-height:300px;width:100%;aspect-ratio:1/1}}@media (max-height:600px){.canvas-container{height:calc(100vh - 160px);min-height:240px;max-height:60vh}}@media (min-height:601px) and (max-height:800px){.canvas-container{height:calc(100vh - 200px);min-height:360px;max-height:72vh}}@media (min-height:1080px){.canvas-container{height:calc(100vh - 240px);min-height:600px;max-height:84vh}}@media (min-height:1440px){.canvas-container{height:calc(100vh - 280px);min-height:720px;max-height:90vh}}.zoom-controls{position:absolute;bottom:24px;right:24px;z-index:20;display:flex;flex-direction:column;gap:2px;pointer-events:none;transform:translateZ(0)}.zoom-panel{background:rgba(255,255,255,.98);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.9);overflow:hidden;border:1px solid rgba(226,232,240,.6);backdrop-filter:blur(12px);transition:all .3s cubic-bezier(.4,0,.2,1)}.zoom-panel:hover{box-shadow:0 12px 40px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.9);transform:translateY(-2px)}.zoom-button{width:48px;height:48px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#1e3a8a;border:none;border-bottom:1px solid rgba(226,232,240,.4);pointer-events:auto;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.zoom-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent,rgba(30,58,138,.1));opacity:0;transition:opacity .3s ease}.zoom-button:last-child{border-bottom:none}.zoom-button:hover{background:rgba(30,58,138,.08);color:#1e40af;transform:scale(1.05)}.zoom-button:hover:before{opacity:1}.zoom-button:active{transform:scale(.98);background:rgba(30,58,138,.12)}@media (max-width:768px){.zoom-controls{bottom:15px;right:15px}.zoom-button{width:36px;height:36px;font-size:14px}}@media (max-width:480px){.zoom-controls{bottom:10px;right:10px}.zoom-button{width:32px;height:32px;font-size:12px}}@media (hover:none) and (pointer:coarse){.zoom-button{width:44px;height:44px;font-size:16px}.zoom-button:hover{background:transparent;transform:none}.zoom-button:active{background:rgba(21,101,192,.2)}}.loading-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#1e3a8a;font-size:16px;font-weight:600;padding:24px 32px;background:rgba(255,255,255,.96);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.1);border:1px solid rgba(226,232,240,.8);backdrop-filter:blur(12px);animation:loadingPulse 2s ease-in-out infinite}@keyframes loadingPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.9}50%{transform:translate(-50%,-50%) scale(1.02);opacity:1}}.loading-container-column{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}.loading-subtitle{margin-top:10px;font-size:14px;opacity:.7}.canvas-controls{position:absolute;bottom:20px;left:20px;background:rgba(255,255,255,.96);padding:12px 16px;border-radius:10px;font-size:12px;color:#475569;box-shadow:0 8px 24px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.8);border:1px solid rgba(226,232,240,.6);backdrop-filter:blur(12px);pointer-events:none;transition:all .3s ease;font-weight:500}.canvas-controls:hover{background:rgba(255,255,255,.98);box-shadow:0 12px 32px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.08)}.quick-info{margin-top:20px;display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.info-card{padding:8px 16px;background:white;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.05);border:1px solid #f0f0f0}.info-label{font-size:12px;color:#666}.info-value{font-size:12px;font-weight:600;color:#333}.tabletop-selector{display:flex;flex-direction:column;gap:8px}.tabletop-dropdown{width:100%;padding:8px 12px;border:2px solid red;border-radius:6px;background-color:white;font-size:14px;font-family:inherit;color:#374151;transition:all .2s ease;cursor:pointer}.tabletop-dropdown:hover{border-color:#9ca3af;box-shadow:0 1px 3px rgba(0,0,0,.1)}.tabletop-dropdown:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}.color-button{padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;background-color:white;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center;min-height:40px;display:flex;align-items:center;justify-content:center}.color-button:hover{border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.color-button.selected{border-color:red;background-color:#eff6ff;color:#1e40af;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.height-buttons{display:flex;flex-wrap:wrap;gap:0}.height-button{padding:8px 12px;background-color:#f0f0f0;color:black;border:1.2px solid #bbb;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:38px;margin:0 3px 5px 0;box-sizing:border-box}.height-button.selected{border:2px solid red}@media (min-width:1920px){.canvas-container{height:calc(100vh - 200px);max-height:80vh;width:100%}.controls-panel{width:380px;min-width:380px;max-width:380px;height:auto;min-height:100vh;max-height:100vh}.mesa-container{width:100vw;height:calc(100vh - 64px)}}@media (min-width:1200px) and (max-width:1919px){.canvas-container{height:calc(100vh - 160px);max-height:90vh;width:100%}.controls-panel{width:430px;min-width:430px;max-width:430px;height:auto;min-height:100vh;max-height:100vh;margin-bottom:50px}.mesa-container{width:100vw;height:calc(100vh - 64px)}}@media (min-width:992px) and (max-width:1199px){.canvas-container{height:calc(100vh - 176px);max-height:84vh;min-height:480px;width:100%}.controls-panel{width:320px;min-width:320px;max-width:320px;height:auto;min-height:100vh;max-height:100vh}.mesa-container{width:100vw;height:calc(100vh - 64px)}}@media (min-width:768px) and (max-width:991px){.canvas-container{height:calc(100vh - 240px);max-height:72vh;min-height:420px;width:100%}.mesa-container{flex-direction:column;width:100vw;height:auto;min-height:100vh}.controls-panel{min-width:100%;max-width:100%;height:auto;min-height:300px;max-height:40vh;overflow-y:auto}.controls-panel,.model-container{width:100%;padding:15px}}@media (min-width:481px) and (max-width:767px){.canvas-container{height:calc(100vh - 280px);max-height:66vh;min-height:360px;width:100%}.mesa-container{flex-direction:column;width:100vw;height:auto;min-height:100vh}.controls-panel{width:100%;min-width:100%;max-width:100%;height:auto;min-height:250px;max-height:35vh;overflow-y:auto;padding:12px}.model-container{width:100%;padding:12px 8px}}@media (min-width:320px) and (max-width:480px){.canvas-container{height:calc(100vh - 304px);max-height:60vh;min-height:336px;width:100%}.mesa-container{flex-direction:column;width:100vw;height:auto;min-height:100vh}.controls-panel{width:100%;min-width:100%;max-width:100%;height:auto;min-height:220px;max-height:30vh;overflow-y:auto;padding:10px}.model-container{width:100%;padding:10px 5px}}@media (max-width:319px){.canvas-container{height:calc(100vh - 320px);max-height:54vh;min-height:300px;width:100%}.mesa-container{flex-direction:column;width:100vw;height:auto;min-height:100vh}.controls-panel{width:100%;min-width:100%;max-width:100%;height:auto;min-height:200px;max-height:25vh;overflow-y:auto;padding:8px}.model-container{width:100%;padding:8px 3px}}@media (min-width:2560px){.canvas-container{height:calc(100vh - 144px);max-height:96vh;width:100%}}@media (max-height:800px){.canvas-container{height:calc(100vh - 120px);min-height:360px}}@media (max-height:600px){.canvas-container{height:calc(100vh - 120px);min-height:240px}.model-title{margin-bottom:2px}.breadcrumb-content{font-size:11px;padding:4px 8px}.breadcrumb-icon{font-size:11px!important;margin-right:3px}}.threejs-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#1565c0;font-size:14px;font-weight:500;z-index:1000}.control-icon{margin-right:8px;vertical-align:middle;opacity:.5;font-size:18px;color:#9ca3af}.controls-title-bold{font-weight:700}