.camera-3d-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#000000f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center}.camera-3d-container{width:100%;height:100%;position:relative;overflow:hidden}.camera-3d-canvas{width:100%;height:100%;display:block;cursor:default}.camera-3d-canvas.panning{cursor:grabbing}.camera-3d-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.camera-3d-close:hover{background:#ff6b9d4d;border-color:#ff6b9d;color:#ff6b9d}.camera-3d-panel{position:absolute;top:16px;left:16px;background:#0a0a14e6;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px;width:260px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-height:calc(100vh - 32px);overflow-y:auto}.camera-3d-title{font-size:13px;font-weight:600;margin-bottom:10px;color:#fff;display:flex;align-items:center;gap:6px}.camera-3d-title:before{content:"";width:3px;height:12px;background:linear-gradient(135deg,#ff6b9d,#c44569);border-radius:2px}.camera-3d-vector-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:10px}.camera-3d-vector-item{background:#ffffff0d;border-radius:6px;padding:6px 8px}.camera-3d-vector-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80;margin-bottom:2px}.camera-3d-vector-value{font-family:Roboto Mono,monospace;font-size:12px;font-weight:600}.camera-3d-vector-value.x{color:#ff6b6b}.camera-3d-vector-value.y{color:#4ecdc4}.camera-3d-vector-value.h{color:#ff6b9d}.camera-3d-vector-value.v{color:#00f5d4}.camera-3d-vector-value.d{color:#ffd60a}.camera-3d-vector-value.f{color:#a78bfa}.camera-3d-hint{font-size:10px;color:#fff6;line-height:1.5;margin-bottom:10px;padding:6px 8px;background:#ffffff08;border-radius:6px}.camera-3d-hint strong{color:#ffffffb3}.camera-3d-preset-section{margin-bottom:10px}.camera-3d-preset-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:#fff6;margin-bottom:6px}.camera-3d-preset-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.camera-3d-preset-btn{padding:5px 3px;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:#ffffff08;color:#888;font-size:10px;cursor:pointer;transition:all .2s}.camera-3d-preset-btn:hover{background:#ffffff14;color:#fff}.camera-3d-preset-btn.saved{border-color:#00f5d4;color:#00f5d4;background:#00f5d41a}.camera-3d-output{background:#0000004d;border-radius:6px;padding:6px 8px;margin-bottom:10px}.camera-3d-output-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:#fff6;margin-bottom:4px}.camera-3d-output-text{font-family:Roboto Mono,monospace;font-size:9px;color:#00f5d4;word-break:break-all;line-height:1.4;min-height:28px}.camera-3d-actions{display:flex;gap:8px}.camera-3d-btn{flex:1;padding:10px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.camera-3d-btn.cancel{background:#ffffff1a;color:#ffffffb3}.camera-3d-btn.cancel:hover{background:#ffffff26;color:#fff}.camera-3d-btn.generate{background:linear-gradient(135deg,#ff6b9d,#c44569);color:#fff}.camera-3d-btn.generate:hover:not(:disabled){background:linear-gradient(135deg,#ff7baa,#d45679);transform:translateY(-1px);box-shadow:0 4px 12px #ff6b9d66}.camera-3d-btn.generate:disabled{opacity:.5;cursor:not-allowed}.panorama-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000}.panorama-viewer-container{width:100%;height:100%;cursor:grab;-webkit-user-select:none;user-select:none}.panorama-viewer-container:active{cursor:grabbing}.panorama-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fffc;font-size:14px;background:#000c}.panorama-loading-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:#fffc;border-radius:50%;animation:panorama-spin 1s linear infinite}@keyframes panorama-spin{to{transform:rotate(360deg)}}.panorama-controls{position:absolute;bottom:32px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:#0009;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:9999px}.panorama-controls button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background:transparent;color:#ffffffb3;cursor:pointer;transition:all .2s ease}.panorama-controls button:hover{background:#ffffff1a;color:#fff}.panorama-fov-label{min-width:48px;text-align:center;color:#ffffffb3;font-size:13px;font-variant-numeric:tabular-nums}.panorama-controls-divider{width:1px;height:24px;background:#fff3;margin:0 8px}.panorama-close-btn{position:absolute;top:24px;right:24px;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:none;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);color:#fffc;cursor:pointer;transition:all .2s ease}.panorama-close-btn:hover{background:#000c;color:#fff;transform:scale(1.05)}.panorama-hint{position:absolute;bottom:100px;left:50%;transform:translate(-50%);padding:8px 16px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;color:#fff9;font-size:12px;pointer-events:none;opacity:1;animation:panorama-hint-fade 5s forwards}@keyframes panorama-hint-fade{0%,60%{opacity:1}to{opacity:0}}.panorama-share-container{position:absolute;top:20px;right:70px;z-index:10}.panorama-share-btn{min-width:70px;height:auto;padding:10px 16px;border-radius:24px;background:linear-gradient(135deg,#6366f1e6,#8b5cf6e6);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;box-shadow:0 4px 15px #6366f166}.panorama-share-btn:hover{background:linear-gradient(135deg,#8184ff,#a782ff);transform:scale(1.05);box-shadow:0 6px 20px #6366f199}.panorama-share-btn-label{font-size:12px;font-weight:500;letter-spacing:.5px}.panorama-share-menu{position:absolute;top:54px;right:0;min-width:180px;padding:12px;background:#0f0f14f2;border:1px solid rgba(255,255,255,.1);border-radius:12px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 10px 40px #00000080;animation:shareMenuFadeIn .2s ease-out}@keyframes shareMenuFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panorama-share-title{font-size:12px;color:#fff9;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.panorama-share-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#fff;font-size:13px;cursor:pointer;transition:all .2s ease}.panorama-share-option:hover{background:#6366f14d}.panorama-share-hint{margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);font-size:11px;color:#fff6;text-align:center}.panorama-qr-container{display:flex;flex-direction:column;align-items:center;padding:12px;margin:10px 0;background:#fffffff2;border-radius:8px}.panorama-qr-image{width:150px;height:150px;border-radius:4px}.panorama-qr-label{margin-top:8px;font-size:11px;color:#333;font-weight:500}
