:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.landing{background:#fff;flex-direction:column;min-height:100svh;font-family:system-ui,-apple-system,sans-serif;display:flex}.landing-header{border-bottom:1px solid #eee;align-items:center;gap:14px;padding:14px 32px;display:flex}.landing-logo{color:#111;letter-spacing:-1px;font-size:26px;font-weight:800}.back-btn{cursor:pointer;color:#666;background:0 0;border:1px solid #ddd;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:border-color .15s,color .15s;display:flex}.back-btn:hover{color:#111;border-color:#999}.landing-main{flex:1;grid-template-columns:1fr auto 1fr;min-height:0;display:grid}.landing-left,.landing-right{padding:48px 40px}.landing-heading{color:#111;margin:0 0 28px;font-size:26px;font-weight:700;line-height:1.3}.heading-accent{color:#c8880a}.heading-accent-grey{color:#666}.upload-drop{text-align:center;cursor:pointer;background:#fafafa;border:2px dashed #d8d8d8;border-radius:12px;margin-bottom:14px;padding:36px 24px;transition:border-color .2s,background .2s}.upload-drop:hover,.upload-drop.over{background:#f0fdff;border-color:#4dd8e0}.upload-drop-icon{color:#b0b0b0;margin:0 auto 14px;display:block}.upload-drop.over .upload-drop-icon{color:#4dd8e0}.upload-drop-main{color:#111;margin:0 0 5px;font-size:16px;font-weight:600}.upload-drop-sub{color:#999;margin:0;font-size:13px}.link-text{color:#4dd8e0;text-decoration:underline}.qr-card{text-align:center;background:#fafafa;border:1px solid #eee;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:24px;display:flex}.qr-label{color:#111;margin:0;font-size:15px;font-weight:600}.qr-sub{color:#999;margin:0;font-size:13px}.landing-divider{flex-direction:column;justify-content:center;align-items:center;padding:0 16px;display:flex}.landing-divider span{color:#bbb;background:#fff;padding:8px 0;font-size:14px;position:relative}.landing-divider:before{content:"";background:#eee;width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.room-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.room-item{cursor:pointer;text-align:left;background:0 0;border:none;padding:0}.room-item:hover .room-thumb-img,.room-item:hover .room-thumb-placeholder{transform:scale(1.03)}.room-thumb-wrap{aspect-ratio:4/3;background:#f0f0f0;border-radius:10px;margin-bottom:7px;overflow:hidden}.room-thumb-img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.room-thumb-placeholder{width:100%;height:100%;transition:transform .2s}.room-item-label{color:#666;font-size:13px;display:block}.visualizer{background:#0e0f16;flex-direction:column;height:100svh;font-family:system-ui,-apple-system,sans-serif;display:flex}.topbar{background:#fff;border-bottom:1px solid #e8e8e8;flex-shrink:0;align-items:center;gap:2px;height:52px;padding:0 12px;display:flex}.topbar-logo{color:#111;letter-spacing:-.5px;white-space:nowrap;padding:0 8px;font-size:17px;font-weight:800}.topbar-sep{background:#e4e4e4;flex-shrink:0;width:1px;height:26px;margin:0 6px}.topbar-spacer{flex:1}.topbar-btn{color:#444;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;padding:6px 11px;font-size:13px;transition:background .15s;display:flex}.topbar-btn:hover{background:#f2f2f2}.topbar-btn.primary{color:#b87800;background:#fdf4e3;border:1px solid #b8780040;font-weight:500}.topbar-btn.primary:hover{background:#f5e8c8}.vis-main{flex:1;min-height:0;display:flex}.sidebar{background:#fff;border-right:1px solid #e8e8e8;flex-direction:column;flex-shrink:0;width:340px;display:flex;overflow:hidden}.sidebar-tabs{border-bottom:1px solid #e8e8e8;padding:0 12px;display:flex}.sidebar-tab{color:#999;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:13px 10px;font-size:13px;font-weight:500;transition:color .15s;display:flex}.sidebar-tab.active{color:#111;border-bottom-color:#111}.sidebar-search{border-bottom:1px solid #f0f0f0;gap:8px;padding:10px 12px;display:flex}.search-input-wrap{color:#999;background:#f5f5f5;border-radius:7px;flex:1;align-items:center;gap:7px;padding:7px 10px;display:flex}.search-input-wrap input{color:#333;background:0 0;border:none;outline:none;width:100%;font-size:13px}.search-input-wrap input::placeholder{color:silver}.filter-btn{color:#555;cursor:pointer;white-space:nowrap;background:#f5f5f5;border:none;border-radius:7px;align-items:center;gap:5px;padding:7px 10px;font-size:13px;display:flex}.filter-btn:hover{background:#ebebeb}.sidebar-toolbar{color:#aaa;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:7px 14px;font-size:12px;display:flex}.view-btns{gap:2px;display:flex}.view-btn{cursor:pointer;color:#ccc;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s;display:flex}.view-btn.active{color:#444}.view-btn:hover:not(.active){color:#999}.sidebar-notice{color:#c08800;background:#fffbf0;border-bottom:1px solid #f5e8c0;padding:8px 14px;font-size:12px}.product-list{flex:1;overflow-y:auto}.product-list.list .product-item{cursor:pointer;border-bottom:1px solid #f5f5f5;align-items:flex-start;gap:12px;padding:12px 14px;transition:background .15s;display:flex}.product-list.list .product-item:hover{background:#fafafa}.product-list.list .product-item.active{background:#f0fdff;border-left:3px solid #4dd8e0}.product-list.list .product-item.dimmed{opacity:.45;cursor:not-allowed}.product-list.grid{background:#f0f0f0;grid-template-columns:1fr 1fr;gap:1px;display:grid}.product-list.grid .product-item{cursor:pointer;text-align:center;background:#fff;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;transition:background .15s;display:flex}.product-list.grid .product-item:hover{background:#fafafa}.product-list.grid .product-item.active{outline-offset:-2px;background:#f0fdff;outline:2px solid #4dd8e0}.product-list.grid .product-item.dimmed{opacity:.4;cursor:not-allowed}.product-list.grid .product-thumb-canvas{border-radius:6px;width:80px;height:80px}.product-thumb-canvas{pointer-events:none;border:1px solid #eee;border-radius:6px;flex-shrink:0;width:64px;height:64px;display:block}.product-info{flex:1;min-width:0}.product-vendor{color:#bbb;margin:0 0 2px;font-size:11px}.product-name{color:#111;text-overflow:ellipsis;white-space:nowrap;margin:0 0 3px;font-size:13px;font-weight:500;overflow:hidden}.product-size{color:#888;margin:0 0 5px;font-size:12px}.product-link{color:#4dd8e0;cursor:pointer;font-size:12px}.wall-status{text-align:center;padding:32px 20px}.wall-status-icon{color:#aaa;background:#f2f2f2;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 14px;display:flex}.wall-status-icon.ready{color:#22c55e;background:#e8fdf0}.wall-status-label{color:#111;margin:0 0 8px;font-size:15px;font-weight:600}.wall-status-desc{color:#888;margin:0 0 20px;font-size:13px;line-height:1.6}.wall-status-btn{color:#444;cursor:pointer;background:#f5f5f5;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:13px;display:inline-flex}.wall-status-btn:hover{background:#ebebeb}.sidebar-opacity{border-top:1px solid #f0f0f0;flex-shrink:0;padding:14px}.sidebar-opacity label{color:#888;justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.opacity-val{color:#4dd8e0;font-weight:600}.opacity-slider{accent-color:#4dd8e0;cursor:pointer;width:100%}.canvas-area{background:#0e0f16;flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.canvas-inner{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.canvas-blur-bg{filter:blur(28px);opacity:.7;background-position:50%;background-size:cover;position:absolute;inset:-20px}.canvas-frame{flex-shrink:0;position:relative}.canvas-three{position:absolute;inset:0}.canvas-three canvas{display:block;width:100%!important;height:100%!important}.canvas-overlay{z-index:2;background:0 0;width:100%;height:100%;position:absolute;inset:0}.poster-ring{pointer-events:none;z-index:1;border:2px dashed #ffffffbf;border-radius:50%;position:absolute;box-shadow:0 0 0 1px #00000040,inset 0 0 0 1px #0000001a}.poster-ring-handle{pointer-events:none;z-index:1;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;box-shadow:0 2px 8px #00000059}.canvas-flash{color:#fff;pointer-events:none;white-space:nowrap;background:#000000b8;border-radius:20px;padding:10px 20px;font-size:13px;position:absolute;bottom:60px;left:50%;transform:translate(-50%)}.canvas-footer-bar{background:#12131a;border-top:1px solid #1e1f2c;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:9px 16px;display:flex}.canvas-hint{color:#686888;font-size:12px}.canvas-clear-btn{color:#9090b0;cursor:pointer;background:0 0;border:1px solid #2a2b3a;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:12px;transition:border-color .15s,color .15s}.canvas-clear-btn:hover{color:#4dd8e0;border-color:#4dd8e0}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes cardSlideOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(12px)scale(.97)}}.segment-loading-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0e2899;justify-content:center;align-items:center;animation:.25s forwards overlayFadeIn;display:flex;position:fixed;inset:0}.segment-loading-overlay.fading-out{animation:.3s forwards overlayFadeOut}.segment-loading-overlay.fading-out .segment-loading-box{animation:.3s forwards cardSlideOut}.segment-loading-box{background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:8px;padding:36px 48px 32px;animation:.3s forwards cardSlideIn;display:flex;box-shadow:0 24px 64px #0000004d,0 4px 16px #0000001a}.segment-loading-box p{color:#0f1b6b;letter-spacing:.01em;margin:0;font-size:15px;font-weight:600}.bottom-bar{background:#fff;border-top:1px solid #e8e8e8;flex-shrink:0;align-items:center;gap:16px;height:66px;padding:0 18px;display:flex}.bottom-product{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.bottom-swatch{border:1px solid #eee;border-radius:6px;flex-shrink:0;width:44px;height:44px;display:block}.bottom-product-info{min-width:0}.bottom-vendor{color:#bbb;font-size:11px;display:block}.bottom-name{color:#111;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;display:block;overflow:hidden}.bottom-actions{gap:8px;display:flex}.bottom-btn{color:#444;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e0e0e0;border-radius:7px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;transition:background .15s;display:flex}.bottom-btn:hover{background:#f5f5f5}.bottom-btn.accent{color:#b87800;background:#fdf4e3;border-color:#b8780040;font-weight:500}.bottom-btn.accent:hover{background:#f5e8c8}
