:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{min-width:320px;min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex}h1{margin:0 0 1rem;font-size:2em;line-height:1.1}h2{margin:0 0 .75rem;font-size:1.5em;line-height:1.2}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}button,a{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:inline-flex}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media (min-width:768px){h1{font-size:2.5em}h2{font-size:1.75em}}@media (min-width:1024px){h1{font-size:3em}h2{font-size:2em}}.navigation{z-index:1000;background-color:#1a1a1a;border-bottom:1px solid #333;width:100%;position:sticky;top:0}.nav-container{justify-content:space-between;align-items:center;max-width:1600px;margin:0 auto;padding:1rem;display:flex}.nav-logo{color:#fff;font-size:1.25rem;font-weight:600;text-decoration:none;transition:color .3s}.nav-logo:hover{color:#646cff}.nav-toggle{cursor:pointer;z-index:1001;background:0 0;border:none;flex-direction:column;gap:4px;padding:.5rem;display:flex}.nav-toggle-icon{background-color:#fff;width:24px;height:2px;transition:all .3s}.nav-menu{background-color:#1a1a1a;flex-direction:column;gap:1rem;width:70%;max-width:300px;height:100vh;padding:5rem 2rem 2rem;transition:right .3s ease-in-out;display:flex;position:fixed;top:0;right:-100%;box-shadow:-2px 0 8px #0000004d}.nav-menu-open{right:0}.nav-link{color:#fff;text-align:left;border-radius:4px;padding:.75rem 1rem;font-size:1rem;text-decoration:none;transition:background-color .3s,color .3s}.nav-link:hover{color:#646cff;background-color:#2a2a2a}.nav-link-active{color:#fff;background-color:#646cff}.nav-link-active:hover{background-color:#535bf2}.nav-button{cursor:pointer;background:0 0;border:none;width:100%;font-family:inherit;font-size:1rem}@media (min-width:768px){.nav-toggle{display:none}.nav-menu{width:auto;max-width:none;height:auto;box-shadow:none;background-color:#0000;flex-direction:row;gap:.5rem;padding:0;position:static}.nav-link{padding:.5rem 1rem}.nav-button{width:auto}}@media (min-width:1024px){.nav-container{padding:1rem 2rem}.nav-menu{gap:1rem}.nav-logo{font-size:1.5rem}}@media (prefers-color-scheme:light){.navigation{background-color:#f9f9f9;border-bottom-color:#e0e0e0}.nav-logo,.nav-link{color:#213547}.nav-toggle-icon{background-color:#213547}.nav-menu{background-color:#f9f9f9}.nav-link:hover{color:#646cff;background-color:#e8e8e8}.nav-link-active{color:#fff;background-color:#646cff}}@media (max-width:767px){.nav-link{align-items:center;min-height:44px;display:flex}.nav-toggle{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:flex}}.layout{flex-direction:column;width:100%;min-height:100vh;transition:padding .3s;display:flex}.layout-main{box-sizing:border-box;flex:1;width:100%;max-width:100%;padding:1rem;transition:padding .3s,max-width .3s}@media (min-width:768px){.layout-main{padding:1.5rem}}@media (min-width:1024px){.layout-main{max-width:1400px;margin:0 auto;padding:2rem}}@media (min-width:1440px){.layout-main{max-width:1600px}}.layout-main img,.layout-main video,.layout-main iframe{max-width:100%;height:auto}.tour-card{cursor:pointer;background:#fff;border-radius:8px;flex-direction:column;height:100%;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000001a}.tour-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.tour-card-image{background:#f0f0f0;width:100%;height:200px;overflow:hidden}.tour-card-image img{object-fit:cover;width:100%;height:100%}.tour-card-placeholder{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;width:100%;height:100%;font-size:14px;font-weight:500;display:flex}.tour-card-content{flex-direction:column;flex:1;padding:16px;display:flex}.tour-card-title{color:#333;margin:0 0 8px;font-size:18px;font-weight:600}.tour-card-description{color:#666;text-overflow:ellipsis;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}@media (max-width:768px){.tour-card-image{height:160px}.tour-card-title{font-size:16px}.tour-card-description{font-size:13px}.tour-card{min-height:44px}}.tour-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;max-width:1400px;margin:0 auto;padding:24px;transition:padding .3s,gap .3s;display:grid}.tour-grid-status{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:300px;padding:48px 24px;display:flex}.tour-grid-status p{color:#666;margin:0;font-size:16px}.tour-grid-status.error p{color:#d32f2f}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;width:48px;height:48px;margin-bottom:16px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.retry-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:4px;margin-top:16px;padding:10px 24px;font-size:14px;font-weight:500;transition:background .2s}.retry-button:hover{background:#5568d3}.retry-button:active{transform:scale(.98)}@media (min-width:1200px){.tour-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:900px) and (max-width:1199px){.tour-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:600px) and (max-width:899px){.tour-grid{grid-template-columns:repeat(2,1fr);gap:20px;padding:20px}}@media (max-width:599px){.tour-grid{grid-template-columns:1fr;gap:16px;padding:16px}.retry-button{min-height:44px}}.landing-page{background:#f5f5f5;min-height:100vh}.landing-header{color:#fff;text-align:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:48px 24px}.landing-header h1{margin:0 0 8px;font-size:36px;font-weight:700}.landing-header p{opacity:.9;margin:0;font-size:18px}@media (max-width:768px){.landing-header{padding:32px 16px}.landing-header h1{font-size:28px}.landing-header p{font-size:16px}}.hotspot-overlay-backdrop{z-index:1000;background-color:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.hotspot-overlay-content{background-color:#fff;border-radius:8px;width:100%;max-width:500px;padding:2rem;animation:.3s ease-out slideIn;position:relative;box-shadow:0 4px 20px #0000004d}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.hotspot-overlay-close{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:40px;height:40px;font-size:2rem;transition:background-color .2s,color .2s;display:flex;position:absolute;top:.5rem;right:.5rem}.hotspot-overlay-close:hover{color:#333;background-color:#f0f0f0}.hotspot-overlay-title{color:#333;margin-bottom:1rem;padding-right:2rem;font-size:1.5rem}.hotspot-overlay-body{color:#666;line-height:1.6}.hotspot-overlay-body p{margin-bottom:1rem}.hotspot-overlay-navigate{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.hotspot-overlay-navigate:hover{background-color:#0056b3}@media (max-width:768px){.hotspot-overlay-content{max-width:90%;padding:1.5rem}.hotspot-overlay-title{font-size:1.25rem}.hotspot-overlay-close{min-width:44px;min-height:44px}.hotspot-overlay-navigate{width:100%;min-height:44px}}.pannellum-viewer-wrapper{width:100%;height:100%;transition:width .3s,height .3s;position:relative}.pannellum-viewer{width:100%;height:100%;transition:width .3s,height .3s}.pannellum-loading,.pannellum-error{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.pannellum-loading .spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:50px;height:50px;margin-bottom:1rem;animation:1s linear infinite spin}.pannellum-error p{margin-bottom:1.5rem;font-size:1.1rem}.custom-hotspot{cursor:pointer;background-color:#fffc;border:3px solid #007bff;border-radius:50%;width:30px;height:30px;transition:all .3s;position:relative}.custom-hotspot:hover,.custom-hotspot.hotspot-hovered{background-color:#007bff;transform:scale(1.2);box-shadow:0 0 20px #007bffcc}.hotspot-tooltip{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;background-color:#000000e6;border-radius:4px;margin-bottom:10px;padding:.5rem 1rem;font-size:.9rem;transition:opacity .3s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.custom-hotspot:hover .hotspot-tooltip,.custom-hotspot.hotspot-hovered .hotspot-tooltip{opacity:1}.hotspot-tooltip:after{content:"";border:6px solid #0000;border-top-color:#000000e6;position:absolute;top:100%;left:50%;transform:translate(-50%)}@media (max-width:768px){.custom-hotspot{width:44px;height:44px}}.pnlm-controls{z-index:10}.iframe-viewer-container{width:100%;height:100%;transition:width .3s,height .3s;display:flex;position:relative}.iframe-viewer{border:none;width:100%;height:100%;transition:width .3s,height .3s;display:block}@media (max-width:768px){.iframe-viewer-container{height:100%}}.tour-viewer-container{background-color:#000;width:100%;height:calc(100vh - 60px);position:relative}.tour-viewer-loading,.tour-viewer-error,.tour-viewer-expired{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:2rem;display:flex}.spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:50px;height:50px;margin-bottom:1rem;animation:1s linear infinite spin}.tour-viewer-error p,.tour-viewer-expired p{margin-bottom:1.5rem;font-size:1.1rem}.tour-viewer-expired h2{margin-bottom:1rem;font-size:2rem}.retry-button,.back-button{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.retry-button:hover,.back-button:hover{background-color:#0056b3}@media (max-width:768px){.tour-viewer-container{height:calc(100vh - 50px)}.retry-button,.back-button{min-width:120px;min-height:44px}}.login-form-container{justify-content:center;align-items:center;min-height:60vh;padding:2rem 1rem;display:flex}.login-form{background:#fff;border-radius:8px;width:100%;max-width:400px;padding:2rem;box-shadow:0 2px 8px #0000001a}.login-form-title{text-align:center;color:#333;margin:0 0 1.5rem;font-size:1.75rem;font-weight:600}.login-form-error{color:#c33;background-color:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:1.5rem;padding:.75rem;font-size:.875rem}.login-form-field{margin-bottom:1.25rem}.login-form-label{color:#555;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.login-form-input{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}.login-form-input:focus{border-color:#4a90e2;outline:none;box-shadow:0 0 0 3px #4a90e21a}.login-form-input:disabled{cursor:not-allowed;background-color:#f5f5f5}.login-form-input-error{border-color:#c33}.login-form-input-error:focus{border-color:#c33;box-shadow:0 0 0 3px #cc33331a}.login-form-field-error{color:#c33;margin-top:.25rem;font-size:.75rem;display:block}.login-form-submit{color:#fff;cursor:pointer;background-color:#4a90e2;border:none;border-radius:4px;width:100%;padding:.875rem;font-size:1rem;font-weight:500;transition:background-color .2s}.login-form-submit:hover:not(:disabled){background-color:#357abd}.login-form-submit:disabled{cursor:not-allowed;background-color:#ccc}@media (max-width:768px){.login-form-container{padding:1rem}.login-form{padding:1.5rem}.login-form-title{font-size:1.5rem}.login-form-submit{min-height:44px}}.admin-dashboard{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.dashboard-header h1{color:#333;margin:0;font-size:2rem}.btn-primary{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.btn-primary:hover{background-color:#0056b3}.loading,.error{text-align:center;color:#666;padding:3rem;font-size:1.1rem}.error{color:#dc3545}.error button{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;margin-top:1rem;padding:.5rem 1rem}.empty-state{text-align:center;color:#666;background-color:#f8f9fa;border-radius:8px;padding:3rem}.tours-table{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.tours-table table{border-collapse:collapse;width:100%}.tours-table thead{background-color:#f8f9fa}.tours-table th{text-align:left;color:#495057;border-bottom:2px solid #dee2e6;padding:1rem;font-weight:600}.tours-table td{vertical-align:middle;border-bottom:1px solid #dee2e6;padding:1rem}.tours-table tr.expired{background-color:#fff3cd}.tours-table tbody tr:hover{background-color:#f8f9fa}.tour-title{align-items:center;gap:.75rem;font-weight:500;display:flex}.tour-thumbnail{object-fit:cover;border:1px solid #dee2e6;border-radius:4px;width:60px;height:45px}.badge{text-transform:capitalize;border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.badge-native{color:#0c5460;background-color:#d1ecf1}.badge-embedded{color:#155724;background-color:#d4edda}.status-badge{border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.status-badge.active{color:#155724;background-color:#d4edda}.status-badge.expired{color:#721c24;background-color:#f8d7da}.action-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.action-buttons button{cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.btn-edit{color:#fff;background-color:#007bff}.btn-edit:hover{background-color:#0056b3}.btn-hotspots{color:#fff;background-color:#6f42c1}.btn-hotspots:hover{background-color:#5a32a3}.btn-renew{color:#fff;background-color:#28a745}.btn-renew:hover:not(:disabled){background-color:#218838}.btn-delete:hover:not(:disabled){background-color:#c82333}.action-buttons button:disabled{opacity:.6;cursor:not-allowed}@media (max-width:1024px){.tours-table{overflow-x:auto}.tours-table table{min-width:800px}}@media (max-width:768px){.admin-dashboard{padding:1rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-header h1{font-size:1.5rem}.btn-primary{width:100%;min-height:44px}.action-buttons{flex-direction:column}.action-buttons button{width:100%;min-height:44px}}.tour-form-container{max-width:800px;margin:0 auto;padding:2rem}.tour-form-container h2{color:#333;margin-bottom:1.5rem}.tour-form-loading{text-align:center;color:#666;padding:2rem}.tour-form-error{color:#c33;background-color:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.tour-form{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.form-group label{color:#333;margin-bottom:.5rem;font-weight:600;display:block}.form-group input[type=text],.form-group textarea{border:1px solid #ddd;border-radius:4px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus,.form-group textarea:focus{border-color:#4a90e2;outline:none}.form-group input.error,.form-group textarea.error{border-color:#c33}.error-message{color:#c33;margin-top:.25rem;font-size:.875rem;display:block}.field-hint{color:#666;margin-top:.25rem;font-size:.875rem}.tour-type-selector{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.tour-type-option{cursor:pointer;border:2px solid #ddd;border-radius:8px;align-items:flex-start;padding:1rem;transition:all .2s;display:flex}.tour-type-option:hover{background-color:#f8f9fa;border-color:#4a90e2}.tour-type-option.selected{background-color:#e8f4fd;border-color:#4a90e2}.tour-type-option input[type=radio]{cursor:pointer;margin-top:.25rem;margin-right:.75rem}.tour-type-content strong{color:#333;margin-bottom:.25rem;display:block}.tour-type-content p{color:#666;margin:0;font-size:.875rem}.image-upload-area{text-align:center;background-color:#fafafa;border:2px dashed #ddd;border-radius:8px;padding:2rem;transition:all .2s}.image-upload-area.drag-active{background-color:#e8f4fd;border-color:#4a90e2}.image-upload-area.error{border-color:#c33}.upload-prompt p{color:#666;margin:.5rem 0}.file-input-label{color:#fff;cursor:pointer;background-color:#4a90e2;border-radius:4px;padding:.75rem 1.5rem;font-weight:600;transition:background-color .2s;display:inline-block}.file-input-label:hover{background-color:#357abd}.file-input-label input[type=file]{display:none}.upload-hint{color:#999;font-size:.875rem}.image-preview{position:relative}.image-preview img{border-radius:4px;max-width:100%;max-height:300px;margin-bottom:1rem}.remove-image-btn{color:#fff;cursor:pointer;background-color:#dc3545;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;transition:background-color .2s}.remove-image-btn:hover{background-color:#c82333}.remove-image-btn:disabled{cursor:not-allowed;background-color:#ccc}.image-replacement-note{color:#666;margin-top:.5rem;font-size:.875rem;font-style:italic}.form-actions{border-top:1px solid #eee;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background-color:#4a90e2}.btn-primary:hover:not(:disabled){background-color:#357abd}.btn-secondary{color:#fff;background-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;background-color:#ccc}@media (max-width:768px){.tour-form-container{padding:1rem}.tour-form{padding:1.5rem}.tour-type-selector{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;min-height:44px}.file-input-label{justify-content:center;align-items:center;min-height:44px;display:flex}.remove-image-btn,.tour-type-option{min-height:44px}}.hotspot-config-panel{z-index:1000;background-color:#fff;border-radius:8px;flex-direction:column;width:350px;max-height:calc(100% - 40px);display:flex;position:absolute;top:20px;right:20px;box-shadow:0 4px 12px #0000004d}.hotspot-config-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.hotspot-config-header h3{color:#333;margin:0;font-size:18px}.close-button{color:#999;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:28px;line-height:1;display:flex}.close-button:hover{color:#333}.hotspot-config-body{flex:1;padding:20px;overflow-y:auto}.form-group{margin-bottom:16px}.form-group label{color:#333;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:8px 12px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db1a}.form-textarea{resize:vertical;min-height:80px}.form-info{background-color:#f8f9fa;border-radius:4px;margin-top:12px;padding:10px}.form-info p{color:#666;margin:0;font-size:12px}.hotspot-config-footer{border-top:1px solid #e0e0e0;gap:10px;padding:16px 20px;display:flex}.btn-save,.btn-delete{cursor:pointer;border:none;border-radius:4px;flex:1;padding:10px 16px;font-size:14px;font-weight:500;transition:background-color .2s}.btn-save{color:#fff;background-color:#3498db}.btn-save:hover{background-color:#2980b9}.btn-delete{color:#fff;background-color:#e74c3c}.btn-delete:hover{background-color:#c0392b}@media (max-width:768px){.hotspot-config-panel{width:calc(100% - 40px);max-width:350px;top:10px;right:10px}.close-button{min-width:44px;min-height:44px}.btn-save,.btn-delete{min-height:44px}}@media (max-width:480px){.hotspot-config-panel{width:calc(100% - 20px);max-width:none;top:10px;left:10px;right:10px}.hotspot-config-footer{flex-direction:column}.btn-save,.btn-delete{width:100%;min-height:44px}}.hotspot-editor-container{flex-direction:column;width:100%;height:100%;display:flex}.hotspot-editor-instructions{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #ddd;padding:12px 20px}.hotspot-editor-instructions p{color:#333;margin:0;font-size:14px}.hotspot-editor-wrapper{flex:1;position:relative;overflow:hidden}.hotspot-editor-viewer{width:100%;height:100%}.hotspot-editor-loading,.hotspot-editor-error{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px;display:flex}.hotspot-editor-loading .spinner{border:4px solid #f3f3f3;border-top-color:#3498db;border-radius:50%;width:50px;height:50px;margin-bottom:20px;animation:1s linear infinite spin}.hotspot-editor-error p{color:#e74c3c;margin-bottom:20px;font-size:16px}.retry-button{color:#fff;cursor:pointer;background-color:#3498db;border:none;border-radius:4px;padding:10px 20px;font-size:14px}.retry-button:hover{background-color:#2980b9}.custom-hotspot-edit{cursor:pointer;background-color:#3498db;border:3px solid #fff;border-radius:50%;width:30px;height:30px;transition:all .2s;position:relative;box-shadow:0 2px 8px #0000004d}.custom-hotspot-edit:hover{background-color:#2980b9;transform:scale(1.2)}.hotspot-marker-edit.hotspot-selected .custom-hotspot-edit{background-color:#e74c3c;border-color:#c0392b;transform:scale(1.3)}.hotspot-label-edit{color:#fff;white-space:nowrap;pointer-events:none;background-color:#000c;border-radius:4px;padding:4px 8px;font-size:12px;position:absolute;bottom:-25px;left:50%;transform:translate(-50%)}@media (max-width:768px){.hotspot-editor-instructions p{font-size:12px}.custom-hotspot-edit{width:44px;height:44px}.retry-button{min-height:44px}}.hotspot-editor-page{flex-direction:column;height:100vh;display:flex}.hotspot-editor-header{color:#fff;background-color:#2c3e50;padding:16px 24px;box-shadow:0 2px 4px #0000001a}.header-content{align-items:center;gap:20px;max-width:1400px;margin:0 auto;display:flex}.hotspot-editor-header h1{flex:1;margin:0;font-size:24px}.back-button{color:#fff;cursor:pointer;background-color:#34495e;border:none;border-radius:4px;padding:8px 16px;font-size:14px;transition:background-color .2s}.back-button:hover{background-color:#415b76}.saving-indicator{color:#3498db;font-size:14px;font-style:italic}.hotspot-editor-content{flex:1;overflow:hidden}.hotspot-editor-page-loading,.hotspot-editor-page-error{flex-direction:column;justify-content:center;align-items:center;height:100vh;padding:40px;display:flex}.hotspot-editor-page-loading .spinner{border:4px solid #f3f3f3;border-top-color:#3498db;border-radius:50%;width:50px;height:50px;margin-bottom:20px;animation:1s linear infinite spin}.hotspot-editor-page-error p{color:#e74c3c;text-align:center;margin-bottom:20px;font-size:16px}@media (max-width:768px){.hotspot-editor-header{padding:12px 16px}.header-content{flex-direction:column;align-items:flex-start;gap:10px}.hotspot-editor-header h1{font-size:20px}}.app{min-height:100vh}
