*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow:hidden;background:#000;color:#fff;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}a-scene{position:absolute;width:100%;height:100%;top:0;left:0}a-scene.hidden{display:none}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1a1a;display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s}.loading-screen.visible{opacity:1;visibility:visible}.loading-screen.hidden{display:none}.loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;height:100%;position:relative}.logo{width:240px;height:auto;margin-bottom:.05rem;animation:logoPosition 2s infinite;position:absolute;top:50%;left:50%;transform:translate(-50%,-80%)}@keyframes logoPosition{0%,to{transform:translate(-50%,-80%) scale(1)}50%{transform:translate(-50%,-80%) scale(1.05)}}.init-loading-text{color:#ffffff73;font-size:.85rem;font-weight:400;letter-spacing:1px;position:absolute;top:50%;left:50%;transform:translate(-50%,.5rem)}.tap-instruction{color:#f7f2f2;font-size:1rem;font-weight:500;letter-spacing:2px;text-transform:uppercase;position:absolute;top:50%;left:50%;transform:translate(-50%,.5rem);animation:fadeInOut 2s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.6}50%{opacity:1}}.loading-tips-container{position:absolute;top:50%;left:50%;transform:translate(-50%,3.5rem);width:90%;max-width:320px;text-align:center;min-height:3rem;display:flex;align-items:center;justify-content:center}.loading-tip{color:#ffffffb3;font-size:.85rem;font-weight:400;line-height:1.5;letter-spacing:.3px;margin:0;opacity:0;transform:translateY(8px);transition:opacity .5s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.4,0,.2,1)}.loading-tip.fade-in{opacity:1;transform:translateY(0)}.loading-tip.fade-out{opacity:0;transform:translateY(-8px)}.loading-tips-container.hidden{display:none}.ar-logo{position:absolute;top:calc(20px + env(safe-area-inset-top,0px));left:20px;width:62px;height:auto;z-index:100;opacity:.9;pointer-events:auto;cursor:pointer;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.start-ar-btn{background:linear-gradient(135deg,#fffffff2,#ffffffd9);color:#1a1a1a;border:none;padding:1rem 3rem;border-radius:50px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 30px #0003,0 0 #ffffff80;position:relative;overflow:hidden;letter-spacing:.5px;text-transform:uppercase;min-width:200px;opacity:80%}.start-ar-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff26;transform:translate(-50%,-50%);transition:width .6s,height .6s}.start-ar-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 40px #0000004d,0 0 0 8px #ffffff1a;background:linear-gradient(135deg,#fff,#fffffff2)}.start-ar-btn:active{transform:translateY(-1px) scale(.98);box-shadow:0 4px 15px #0003,0 0 0 4px #fff3}.start-ar-btn:active:before{width:300px;height:200px}.start-ar-btn .btn-text{position:relative;z-index:1}.start-ar-btn.hidden{display:none}.loading-state{display:flex;flex-direction:column;align-items:center;width:100%;max-width:300px}.loading-state.hidden{display:none}.loading-spinner{width:60px;height:60px;border:2px solid rgba(255,255,255,.1);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1rem;margin-bottom:1.5rem;color:#fff;opacity:.95;font-weight:500;text-align:center}.progress-bar{width:100%;max-width:280px;height:2px;background:#ffffff26;border-radius:2px;overflow:hidden;margin:0 auto .75rem;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#fffc,#fff);border-radius:2px;transition:width .3s ease;width:0;box-shadow:0 0 10px #ffffff80}.progress-text{font-size:.85rem;color:#ffffffb3;font-weight:500;letter-spacing:.5px}.unsupported-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f093fb,#f5576c);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s}.unsupported-screen.visible{opacity:1;visibility:visible}.unsupported-screen.hidden{display:none}.unsupported-content{background:#fffffff2;color:#333;padding:2rem;border-radius:12px;max-width:400px;text-align:center;box-shadow:0 10px 40px #0003}.unsupported-content h2{margin-bottom:1rem;color:#f5576c}.unsupported-content p{margin-bottom:1.5rem;line-height:1.5}.supported-browsers{text-align:left;margin-bottom:1.5rem}.supported-browsers h3{font-size:1rem;margin:1rem 0 .5rem;color:#667eea}.supported-browsers ul{list-style:none;padding-left:1rem}.supported-browsers li:before{content:"✓ ";color:#4caf50;font-weight:700}.try-anyway-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:25px;font-size:1rem;cursor:pointer;transition:transform .2s}.try-anyway-btn:hover{transform:translateY(-2px)}.ui-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000}.ui-overlay.hidden{display:none}.ui-overlay>*{pointer-events:auto}.ui-btn{background:#0f1723cc;color:#fff;border:2px solid rgba(6,182,212,.5);padding:.75rem 1.25rem;border-radius:14px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 16px #0003,0 1px 3px #00000026;display:inline-flex;align-items:center;gap:.5rem;letter-spacing:.01em}.ui-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 24px #0000004d,0 0 8px #06b6d433;background:#0f1723f2;border-color:#06b6d4cc}.ui-btn:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #0003}.ui-btn svg{width:18px;height:18px;stroke-width:2px;opacity:.9;color:#fff}.ui-btn:disabled,.ui-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;transform:none}.loading-hidden{display:none!important}.close-app-btn{position:absolute;top:calc(20px + env(safe-area-inset-top,0px));right:20px;z-index:200;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#00000073;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease}.close-app-btn:hover{background:#000000a6}.close-app-btn:active{transform:scale(.9)}.close-app-btn.hidden{display:none!important}.gallery-btn{position:absolute;top:calc(70px + env(safe-area-inset-top,0px));right:20px}.gallery-btn.hidden{display:none!important}.gallery-btn svg{width:20px;height:20px;stroke-width:2px}.log-btn{position:absolute;top:calc(190px + env(safe-area-inset-top,0px));right:20px;display:none!important}.log-btn.log-btn-revealed{display:flex!important}.log-btn svg{width:20px;height:20px;stroke-width:2px}.virtual-tour-btn{position:absolute;top:calc(130px + env(safe-area-inset-top,0px));right:20px;background:#10b981d9!important;border-color:#10b981!important}.virtual-tour-btn.hidden{display:none!important}.virtual-tour-btn svg{width:20px;height:20px;stroke-width:2px}.virtual-tour-btn:hover{background:#059669f2!important}.virtual-tour-btn:active{background:#047857!important}.room-btn{position:absolute;top:calc(130px + env(safe-area-inset-top,0px));right:20px}.room-btn.hidden{display:none!important}.room-btn svg{width:20px;height:20px;stroke-width:2px}.focus-btn{position:absolute;top:calc(190px + env(safe-area-inset-top,0px));right:20px}.focus-btn.hidden{display:none!important}.focus-btn svg{width:20px;height:20px;stroke-width:2px}.focus-btn.focus-active{background:#06b6d44d!important;border-color:#06b6d4e6!important}.focus-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;z-index:1800;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;pointer-events:auto}.focus-popup-overlay.visible{opacity:1;visibility:visible}.focus-popup-overlay.hidden{display:none}.focus-popup{background:#0f1723eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;width:85%;max-width:340px;display:flex;flex-direction:column;box-shadow:0 12px 48px #0006;border:2px solid rgba(6,182,212,.5);animation:slideUp .25s ease;overflow:hidden}.focus-popup-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(6,182,212,.2)}.focus-popup-header h3{font-size:1rem;font-weight:700;color:#fff;margin:0}.focus-popup-close{background:none;border:none;font-size:1.5rem;color:#ffffffb3;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.focus-popup-close:hover{background:#ffffff1a;color:#fff}.focus-popup-options{display:flex;gap:8px;flex-wrap:wrap;padding:1rem 1.25rem}.focus-option-btn{background:#06b6d41a;color:#ffffffe6;border:2px solid rgba(6,182,212,.5);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.focus-option-btn:hover{transform:translateY(-1px);background:#06b6d44d;border-color:#06b6d4cc}.focus-option-btn:active{transform:translateY(0);background:#06b6d480}.focus-option-btn.active{background:#06b6d466;border-color:#06b6d4;color:#fff;font-weight:600}.room-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;z-index:1800;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;pointer-events:auto}.room-popup-overlay.visible{opacity:1;visibility:visible}.room-popup-overlay.hidden{display:none}.room-popup{background:#0f1723eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;width:85%;max-width:340px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 12px 48px #0006;border:2px solid rgba(6,182,212,.5);animation:slideUp .25s ease;overflow:hidden}.room-popup-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(6,182,212,.2)}.room-popup-header h3{font-size:1rem;font-weight:700;color:#fff;margin:0}.room-popup-close{background:none;border:none;font-size:1.5rem;color:#ffffffb3;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.room-popup-close:hover{background:#ffffff1a;color:#fff}.room-popup-buttons{display:flex;gap:8px;flex-wrap:wrap;padding:1rem 1.25rem;overflow-y:auto;max-height:calc(70vh - 60px)}.room-btn-item{background:#06b6d41a;color:#ffffffe6;border:2px solid rgba(6,182,212,.5);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.room-btn-item:hover{transform:translateY(-1px);background:#06b6d44d;border-color:#06b6d4cc}.room-btn-item:active{transform:translateY(0);background:#06b6d480}.room-btn-item.current-room{background:#06b6d466;border-color:#06b6d4;box-shadow:0 0 8px #06b6d480}.room-floor-header{width:100%;padding:6px 4px 4px;margin-top:4px;font-size:.75rem;font-weight:700;color:#06b6d4d9;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid rgba(6,182,212,.2);pointer-events:none;-webkit-user-select:none;user-select:none}.room-floor-header:first-child{margin-top:0}.exit-1to1-btn{position:fixed!important;top:20px;left:50%;transform:translate(-50%);background:#ef4444e6!important;border-color:#ef4444!important;z-index:1000}.exit-1to1-btn:hover{background:#dc2626f2!important}.exit-1to1-btn:active{background:#b91c1c!important}.exit-1to1-btn.hidden{display:none!important}.current-room-label{position:fixed;top:60px;left:50%;transform:translate(-50%);background:#0f1723d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;font-size:.85rem;font-weight:600;padding:6px 16px;border-radius:20px;border:1px solid rgba(6,182,212,.5);z-index:1000;white-space:nowrap;pointer-events:none;letter-spacing:.02em}.current-room-label.hidden{display:none}.refresh-btn{width:48px;height:48px;min-width:48px;border-radius:50%;background:#0f1723cc;border:2px solid rgba(6,182,212,.5);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 16px #0003,0 1px 3px #00000026;padding:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.refresh-btn:hover{transform:scale(1.08);box-shadow:0 8px 24px #0000004d,0 0 8px #06b6d433;background:#0f1723f2;border-color:#06b6d4cc}.refresh-btn:active{transform:scale(.92);box-shadow:0 2px 8px #0003}.refresh-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.refresh-btn svg{stroke:currentColor;transition:transform .3s ease}.refresh-btn.refreshing svg{animation:refresh-spin .8s linear infinite}@keyframes refresh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.log-panel{position:absolute;top:60px;left:20px;right:20px;bottom:100px;background:#0a0f19eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(6,182,212,.3);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;z-index:1000}.log-panel.hidden{display:none}.log-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#06b6d414;border-bottom:1px solid rgba(6,182,212,.2)}.log-header h3{margin:0;font-size:14px;font-weight:600;color:#fff}.log-actions{display:flex;gap:8px}.log-action-btn{background:#06b6d426;color:#fff;border:1px solid rgba(6,182,212,.3);padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:background .2s}.log-action-btn:hover{background:#06b6d44d}.log-panel,.log-header,.log-actions,.log-action-btn,.log-content,.log-entry,.log-timestamp,.log-event-name,.log-message,.log-data{user-select:text;-webkit-user-select:text}.log-action-btn{touch-action:manipulation}.log-content{flex:1;overflow-y:auto;padding:12px;font-family:Monaco,Menlo,Consolas,monospace;font-size:11px;line-height:1.5;touch-action:pan-y;-webkit-touch-callout:default}.log-entry{padding:6px 8px;margin-bottom:4px;border-radius:4px;background:#ffffff0d;border-left:3px solid #667eea}.log-entry.info{border-left-color:#3b82f6}.log-entry.success{border-left-color:#22c55e}.log-entry.warning{border-left-color:#f59e0b}.log-entry.error{border-left-color:#ef4444}.log-entry.event{border-left-color:#a855f7}.log-timestamp{color:#888;font-size:10px;margin-right:8px}.log-event-name{color:#a855f7;font-weight:600;margin-right:8px}.log-message{color:#fff}.log-data{color:#6ee7b7;font-size:10px;margin-top:4px;padding-left:12px;white-space:pre-wrap;word-break:break-all}.controls-panel{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:row;gap:10px;flex-wrap:nowrap;justify-content:center;max-width:90%}.layer-toggle-btn.hidden{display:none!important}.layer-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;z-index:1800;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;pointer-events:auto}.layer-popup-overlay.visible{opacity:1;visibility:visible}.layer-popup-overlay.hidden{display:none}.layer-popup{background:#0f1723eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;width:85%;max-width:340px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 12px 48px #0006;border:2px solid rgba(6,182,212,.5);animation:slideUp .25s ease;overflow:hidden}.layer-popup-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(6,182,212,.2)}.layer-popup-header h3{font-size:1rem;font-weight:700;color:#fff;margin:0}.layer-popup-close{background:none;border:none;font-size:1.5rem;color:#ffffffb3;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.layer-popup-close:hover{background:#ffffff1a;color:#fff}.layer-popup-buttons{display:flex;gap:8px;flex-wrap:wrap;padding:1rem 1.25rem;overflow-y:auto;max-height:calc(70vh - 60px)}.layer-btn{background:#06b6d41a;color:#ffffffe6;border:2px solid rgba(6,182,212,.5);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.layer-btn.active{background:#06b6d499;color:#fff;border-color:#06b6d4cc}.layer-btn:hover{transform:translateY(-1px)}.gallery-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease}.gallery-modal.visible{opacity:1;visibility:visible}.gallery-modal.hidden{display:none}.gallery-content{background:#0f1723f2;border:1px solid rgba(6,182,212,.3);border-radius:16px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;padding:1.5rem;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.gallery-content h2{color:#fff;margin-bottom:1.5rem;font-size:1.5rem}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;color:#ffffffb3;cursor:pointer;transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#fff}.model-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.model-card{background:#06b6d414;border:1px solid rgba(6,182,212,.2);border-radius:12px;padding:.75rem;cursor:pointer;transition:all .3s ease;text-align:center}.model-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000004d;border-color:#06b6d480}.model-card.selected{background:#06b6d44d;border-color:#06b6d4b3;color:#fff}.model-thumbnail{width:100%;aspect-ratio:1;background:#0000004d;border-radius:8px;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;overflow:hidden}.model-thumbnail img{width:100%;height:100%;object-fit:cover}.placeholder-icon{width:60%;height:60%;color:#ccc}.model-card.selected .placeholder-icon{color:#fffc}.model-name{font-size:.9rem;font-weight:500;color:#ffffffe6;margin-bottom:.25rem}.model-card.selected .model-name{color:#fff}.model-info{display:flex;justify-content:center;gap:.5rem}.layer-badge{background:#06b6d426;color:#06b6d4e6;padding:.2rem .5rem;border-radius:10px;font-size:.75rem}.model-card.selected .layer-badge{background:#fff3;color:#fff}.model-card.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;transform:none!important}.surface-status{position:absolute;top:calc(20px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);background:#000000d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.5rem 1rem;border-radius:50px;display:flex;align-items:center;gap:.625rem;box-shadow:0 4px 20px #0000004d,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.1);z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.875rem}.surface-status.immersive-mode{top:calc(92px + env(safe-area-inset-top,0px))}.surface-status.detected{background:#000000d9;border-color:#06b6d480}.status-indicator{width:10px;height:10px;border-radius:50%;background:#f59e0b;position:relative}.status-indicator.searching{background:#f59e0b;animation:pulse-amber 1.5s ease-in-out infinite}.status-indicator.detected{background:#06b6d4;animation:pulse-cyan 2s ease-in-out infinite;box-shadow:0 0 10px #06b6d499}@keyframes pulse-amber{0%,to{box-shadow:0 0 #f59e0bb3}50%{box-shadow:0 0 0 8px #f59e0b00}}@keyframes pulse-cyan{0%,to{box-shadow:0 0 4px #06b6d499}50%{box-shadow:0 0 12px #06b6d4cc}}.status-text{font-size:.8rem;font-weight:500;color:#fffffff2;letter-spacing:.02em}.instructions{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:transparent;padding:1rem 1.5rem;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);max-width:90%;z-index:99}.instructions.visible{opacity:1;visibility:visible}.instructions p{margin:0;font-size:.95rem;font-weight:500;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);text-align:center}.instructions.instruction-blur-panel{background:#00000059;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 24px #0003}.instruction-icon{width:24px;height:24px;flex-shrink:0;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.toast-container{position:absolute;bottom:100px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:.75rem;align-items:center;z-index:1500;pointer-events:none;width:calc(100% - 40px);max-width:400px}.toast{background:#1e1e1ef2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;padding:.875rem 1.25rem;border-radius:14px;box-shadow:0 8px 32px #00000040,0 2px 8px #00000026;opacity:0;transform:translateY(20px) scale(.95);transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.75rem;pointer-events:auto;width:100%;border:1px solid rgba(255,255,255,.1)}.toast.visible{opacity:1;transform:translateY(0) scale(1)}.toast-icon{width:32px;height:32px;min-width:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.toast-icon svg{width:18px;height:18px}.toast-content{flex:1}.toast-title{font-size:.9rem;font-weight:600;margin-bottom:.125rem}.toast-message{font-size:.8rem;opacity:.85}.toast-success{background:linear-gradient(135deg,#06b6d4eb,#0891b2eb);border:2px solid rgba(6,182,212,.7)}.toast-success .toast-icon{background:#fff3;color:#fff}.toast-success .toast-title{color:#fff}.toast-success .toast-message{color:#fffffff2}.toast-error{background:linear-gradient(135deg,#ef4444f2,#dc2626f2);border-color:#fff3}.toast-error .toast-icon{background:#fff3}.toast-warning{background:linear-gradient(135deg,#f59e0bf2,#d97706f2);border-color:#fff3}.toast-warning .toast-icon{background:#fff3}.toast-info{background:linear-gradient(135deg,#06b6d4eb,#0891b2eb);border:2px solid rgba(6,182,212,.7)}.toast-info .toast-icon{background:#fff3}.debug-info{position:absolute;top:20px;left:20px;background:#000c;color:#0f0;font-family:Courier New,monospace;font-size:.8rem;padding:.5rem;border-radius:4px;line-height:1.4}.debug-info.hidden{display:none}.debug-info span{color:#fff}.debug-info .active{color:#0f0}.model-loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:280px;height:400px;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 12px 48px #00000059}.loading-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center center;background-repeat:no-repeat;background-color:#1a1a2e;opacity:0;transition:opacity 1.2s ease-in-out;z-index:0}.loading-bg.loading-bg-active{opacity:1}.loading-bottom-content{position:relative;z-index:1;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.65) 40%,rgba(0,0,0,.8) 100%);padding:1.25rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.model-loading-indicator .spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.model-loading-indicator p{color:#ffffffe6;font-size:.85rem;font-weight:500;margin:0}.model-loading-indicator .progress{width:100%;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.model-loading-indicator .progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#a78bfa);transition:width .3s ease;margin:0;max-width:none;border-radius:2px}.model-loading-indicator .progress-bar.indeterminate{width:100%!important;background:linear-gradient(90deg,transparent 0%,#667eea 30%,#a78bfa 50%,#667eea 70%,transparent 100%);background-size:200% 100%;animation:indeterminate-progress 1.5s ease-in-out infinite}@keyframes indeterminate-progress{0%{background-position:200% 0}to{background-position:-200% 0}}.model-loading-indicator .progress-percent{font-size:1.1rem;font-weight:600;color:#fff}.model-loading-indicator.fade-out{opacity:0;transform:translate(-50%,-50%) scale(.9);transition:all .3s ease}.cancel-load-btn{position:absolute;top:10px;right:10px;z-index:2;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease}.cancel-load-btn:hover{background:#0000008c}.cancel-load-btn:active{transform:scale(.9)}.cancel-load-btn svg{stroke:currentColor}@media (max-width: 480px){.controls-panel{bottom:10px;max-width:95%}.ui-btn{padding:.6rem 1.2rem;font-size:.85rem}.gallery-content{padding:1rem}.model-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}@media (orientation: landscape){.controls-panel{position:absolute;bottom:10px;left:auto;right:10px;top:auto;transform:none;flex-direction:row;gap:8px;max-width:none;justify-content:flex-end}.controls-panel .ui-btn{padding:.55rem 1rem;font-size:.8rem}.controls-panel .refresh-btn{width:42px;height:42px;min-width:42px}.gallery-btn{top:calc(50px + env(safe-area-inset-top,0px));right:10px;padding:.5rem 1rem;font-size:.8rem}.close-app-btn{top:calc(8px + env(safe-area-inset-top,0px));right:10px}.ar-logo{top:calc(8px + env(safe-area-inset-top,0px));left:10px;width:48px}.instructions{bottom:10px;left:50%;transform:translate(-50%);max-width:60%}.toast-container{bottom:60px;max-width:50%}.surface-status{top:calc(10px + env(safe-area-inset-top,0px))}.gallery-content{max-width:70vw;max-height:90vh}.model-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.model-loading-indicator{width:220px;height:320px}.log-panel{left:10px;right:100px;top:50px;bottom:10px}.logo{width:240px;margin-bottom:.1rem}.loading-content{position:relative;width:100%;height:100%}.tap-instruction{font-size:1rem;margin-top:.3rem}}body.force-landscape-ui .controls-panel{position:absolute;bottom:10px;left:auto;right:10px;top:auto;transform:none;flex-direction:row;gap:8px;max-width:none;justify-content:flex-end}body.force-landscape-ui .controls-panel .ui-btn{padding:.55rem 1rem;font-size:.8rem}body.force-landscape-ui .controls-panel .refresh-btn{width:42px;height:42px;min-width:42px}body.force-landscape-ui .gallery-btn{top:calc(50px + env(safe-area-inset-top,0px));right:10px;padding:.5rem 1rem;font-size:.8rem}body.force-landscape-ui .close-app-btn{top:calc(8px + env(safe-area-inset-top,0px));right:10px}body.force-landscape-ui .ar-logo{top:calc(8px + env(safe-area-inset-top,0px));left:10px;width:48px}body.force-landscape-ui .instructions{bottom:10px;left:50%;transform:translate(-50%);max-width:60%}body.force-landscape-ui .toast-container{bottom:60px;max-width:50%}body.force-landscape-ui .surface-status{top:calc(10px + env(safe-area-inset-top,0px))}body.force-landscape-ui .gallery-content{max-width:70vw;max-height:90vh}body.force-landscape-ui .model-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}body.force-landscape-ui .model-loading-indicator{width:220px;height:320px}body.force-landscape-ui .log-panel{left:10px;right:100px;top:50px;bottom:10px}@media (orientation: landscape) and (max-height: 480px){.controls-panel{right:8px;gap:6px}.controls-panel .ui-btn{padding:.45rem .8rem;font-size:.75rem;border-radius:10px}.controls-panel .refresh-btn{width:36px;height:36px;min-width:36px}.gallery-btn{padding:.4rem .8rem;font-size:.75rem}.ar-logo{width:40px}.instructions{bottom:8px;padding:.6rem 1rem}.instructions p{font-size:.8rem}.logo{width:240px;margin-bottom:.02rem}.loading-content{position:relative;width:100%;height:100%}.tap-instruction{font-size:1rem;margin-top:.2rem}}body.force-short-landscape-ui .controls-panel{right:8px;gap:6px}body.force-short-landscape-ui .controls-panel .ui-btn{padding:.45rem .8rem;font-size:.75rem;border-radius:10px}body.force-short-landscape-ui .controls-panel .refresh-btn{width:36px;height:36px;min-width:36px}body.force-short-landscape-ui .gallery-btn{padding:.4rem .8rem;font-size:.75rem}body.force-short-landscape-ui .ar-logo{width:40px}body.force-short-landscape-ui .instructions{bottom:8px;padding:.6rem 1rem}body.force-short-landscape-ui .instructions p{font-size:.8rem}
