*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-panel: #0f1629;--text-primary: #e0e0e0;--text-secondary: #8892a4;--accent: #4fc3f7;--accent-hover: #29b6f6;--danger: #ef5350;--border: #2a3050;--radius: 8px;--toolbar-height: 48px;--statusbar-height: 28px;--panel-width: 280px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw}#loading-overlay{position:fixed;inset:0;background:#0a0a1ed9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:16px;font-size:14px;color:var(--text-secondary)}.loading-progress{margin-top:8px;font-size:12px;color:var(--accent)}#drop-overlay{position:fixed;inset:0;background:#4fc3f71a;border:3px dashed var(--accent);display:flex;align-items:center;justify-content:center;z-index:999;pointer-events:none}.drop-content{text-align:center;color:var(--accent)}.drop-content svg{margin-bottom:12px;opacity:.8}.drop-content p{font-size:18px;font-weight:500}#toolbar{position:fixed;top:0;left:0;right:0;height:var(--toolbar-height);background:var(--bg-panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:100}.toolbar-left{display:flex;align-items:center;gap:10px}.app-title{font-size:16px;font-weight:600;letter-spacing:.5px}.app-badge{background:var(--accent);color:#000;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.5px}.toolbar-right{display:flex;gap:4px}.toolbar-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:all .2s}.toolbar-btn:hover{background:#ffffff14;color:var(--text-primary)}#annotation-list-panel{position:fixed;top:var(--toolbar-height);left:0;bottom:var(--statusbar-height);width:var(--panel-width);background:var(--bg-panel);border-right:1px solid var(--border);z-index:80;overflow-y:auto;display:flex;flex-direction:column;transition:transform .3s ease}.panel-add-btn{background:var(--accent);color:#000;border:none;width:26px;height:26px;border-radius:6px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1}.panel-add-btn:hover{background:var(--accent-hover)}#annotation-list-body{flex:1;overflow-y:auto;padding:4px 0}.empty-hint{text-align:center;color:var(--text-secondary);font-size:13px;padding:32px 16px;line-height:1.6}.annotation-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border)}.annotation-item:hover{background:#4fc3f70f}.annotation-item.active{background:#4fc3f71f;border-left:3px solid var(--accent)}.annotation-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.annotation-dot.type-info{background:#4fc3f7}.annotation-dot.type-warning{background:#ffb74d}.annotation-dot.type-danger{background:#ef5350}.annotation-dot.type-custom{background:#ab47bc}.annotation-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#annotation-edit-panel{position:fixed;top:var(--toolbar-height);right:0;bottom:var(--statusbar-height);width:var(--panel-width);background:var(--bg-panel);border-left:1px solid var(--border);z-index:85;overflow-y:auto;transition:transform .3s ease}#annotation-edit-panel.panel-hidden{transform:translate(100%)}.control-group input[type=text],.control-group input[type=number],.control-group textarea,.control-group select{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text-primary);font-size:13px;outline:none;transition:border-color .2s;font-family:inherit;margin-top:4px}.control-group input[type=text]:focus,.control-group input[type=number]:focus,.control-group textarea:focus,.control-group select:focus{border-color:var(--accent)}.control-group textarea{resize:vertical;min-height:60px}.control-group select{cursor:pointer}.control-group input[type=color]{width:40px;height:30px;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);cursor:pointer;padding:2px;margin-top:4px}.coord-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.coord-item{display:flex;align-items:center;gap:4px;background:var(--bg-secondary);border-radius:6px;padding:4px 8px}.coord-label{font-size:11px;font-weight:600;color:var(--accent);min-width:14px}.coord-item input{width:100%;background:transparent;border:none;color:var(--text-primary);font-size:12px;outline:none;padding:4px 0}.edit-actions{display:flex;flex-direction:column;gap:8px}.action-btn.primary{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.action-btn.primary:hover{background:var(--accent-hover)}.action-btn.active-clip{background:var(--danger);color:#fff;border-color:var(--danger)}.action-btn.danger-outline{background:transparent;color:var(--danger);border:1px solid var(--danger)}.action-btn.danger-outline:hover{background:#ef53501a}.annotation-label-3d{pointer-events:none;user-select:none;text-align:center}.annotation-label-3d .label-pin{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.8);margin:0 auto 4px}.annotation-label-3d .label-text{background:#0f1629d9;padding:3px 8px;border-radius:4px;font-size:12px;white-space:nowrap;border:1px solid rgba(79,195,247,.3)}.annotation-label-3d.editing .label-pin{width:16px;height:16px;border-width:3px;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #4fc3f780}50%{box-shadow:0 0 0 8px #4fc3f700}}#canvas-container{position:fixed;top:var(--toolbar-height);left:var(--panel-width);right:0;bottom:var(--statusbar-height);transition:left .3s ease}#canvas-container canvas{width:100%!important;height:100%!important;display:block}#welcome-panel{position:fixed;top:var(--toolbar-height);left:var(--panel-width);right:0;bottom:var(--statusbar-height);display:flex;align-items:center;justify-content:center;z-index:50;background:#1a1a2e99;backdrop-filter:blur(2px);transition:left .3s ease}body.mode-display #welcome-panel{left:0}.welcome-content{text-align:center;max-width:480px;padding:40px}.welcome-icon{margin-bottom:24px;color:var(--accent);opacity:.6}.welcome-content h2{font-size:22px;font-weight:600;margin-bottom:8px}.welcome-content>p{color:var(--text-secondary);font-size:14px;margin-bottom:32px}.welcome-actions{display:flex;flex-direction:column;gap:16px}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:32px 24px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.upload-area:hover{border-color:var(--accent);background:#4fc3f70d}.upload-area svg{margin-bottom:12px;opacity:.5}.upload-area p{font-size:14px}.upload-area .link{color:var(--accent);cursor:pointer;text-decoration:underline}.url-input-area{display:flex;gap:8px}.url-input-area input{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;color:var(--text-primary);font-size:13px;outline:none;transition:border-color .2s}.url-input-area input:focus{border-color:var(--accent)}.url-input-area input::placeholder{color:var(--text-secondary)}.url-input-area button{background:var(--accent);color:#000;border:none;border-radius:var(--radius);padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.url-input-area button:hover{background:var(--accent-hover)}.demo-links{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.demo-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--accent);padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.demo-btn:hover{border-color:var(--accent);background:#4fc3f71a}#control-panel{position:fixed;top:var(--toolbar-height);right:0;bottom:var(--statusbar-height);width:var(--panel-width);background:var(--bg-panel);border-left:1px solid var(--border);z-index:80;overflow-y:auto;transition:transform .3s ease}#control-panel.panel-hidden{transform:translate(100%)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-header h3{font-size:14px;font-weight:600}.panel-close{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.panel-close:hover{color:var(--text-primary)}.panel-body{padding:8px 0}.panel-section{padding:12px 16px;border-bottom:1px solid var(--border)}.panel-section h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);margin-bottom:12px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.info-item{background:var(--bg-secondary);border-radius:6px;padding:8px 10px}.info-label{display:block;font-size:10px;color:var(--text-secondary);margin-bottom:2px}.info-value{display:block;font-size:13px;font-weight:500;color:var(--accent)}.control-group{margin-bottom:12px}.control-group:last-child{margin-bottom:0}.control-group>label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--text-primary)}.control-group>label span{color:var(--accent);font-weight:500}.control-group input[type=checkbox]{accent-color:var(--accent)}.control-group input[type=range]{width:100%;margin-top:6px;accent-color:var(--accent)}.color-options{display:flex;gap:6px;margin-top:6px}.color-btn{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:border-color .2s}.color-btn:hover{border-color:#ffffff4d}.color-btn.active{border-color:var(--accent)}.action-btn{width:100%;padding:8px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.action-btn:hover{border-color:var(--accent);background:#4fc3f71a}.action-btn.danger{color:var(--danger)}.action-btn.danger:hover{border-color:var(--danger);background:#ef53501a}#status-bar{position:fixed;bottom:0;left:0;right:0;height:var(--statusbar-height);background:var(--bg-panel);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:20px;font-size:11px;color:var(--text-secondary);z-index:100}.hidden{display:none!important}.mode-toggle{display:flex;background:var(--bg-secondary);border-radius:6px;overflow:hidden;border:1px solid var(--border)}.mode-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-secondary);padding:5px 10px;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.mode-btn:hover{color:var(--text-primary);background:#ffffff0d}.mode-btn.active{background:var(--accent);color:#000;font-weight:600}.toolbar-separator{width:1px;height:24px;background:var(--border);margin:0 4px;align-self:center}body.mode-display #annotation-list-panel{transform:translate(-100%);pointer-events:none;visibility:hidden}body.mode-display #canvas-container{left:0}body.mode-display #status-hint{display:none}body.mode-display .annotation-label-3d.editing .label-pin{animation:none}body.mode-display #tour-nav:not(.hidden){display:flex}body.mode-edit #tour-nav{display:none!important}body.mode-display #btn-toggle-panel{opacity:.3;pointer-events:none}body.mode-display .annotation-marker-hitarea:hover{cursor:pointer}#annotation-info-card{position:fixed;z-index:200;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:16px 20px;min-width:200px;max-width:320px;box-shadow:0 8px 32px #00000080;pointer-events:auto;animation:cardFadeIn .2s ease}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.info-card-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;line-height:1;padding:2px}.info-card-close:hover{color:var(--text-primary)}.info-card-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.info-card-type.type-info{background:#4fc3f733;color:#4fc3f7}.info-card-type.type-warning{background:#ffb74d33;color:#ffb74d}.info-card-type.type-danger{background:#ef535033;color:#ef5350}.info-card-title{font-size:15px;font-weight:600;margin-bottom:6px;padding-right:20px}.info-card-desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.info-card-station{margin-top:8px;font-size:11px;color:var(--accent);font-weight:600}.left-panel-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.left-tab{flex:1;padding:10px 0;background:none;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.left-tab:hover{color:var(--text-primary)}.left-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.left-tab-content .panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border)}.left-tab-content .panel-header h3{font-size:13px;font-weight:600}.poi-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border)}.poi-item:hover{background:#4fc3f70f}.poi-item.active{background:#4fc3f71f;border-left:3px solid var(--accent)}.poi-item.dragging{opacity:.5;background:#4fc3f71a}.poi-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.poi-icon.icon-landmark{color:#4fc3f7}.poi-icon.icon-viewpoint{color:#66bb6a}.poi-icon.icon-entrance{color:#ffa726}.poi-icon.icon-custom{color:#ab47bc}.poi-number{font-size:10px;font-weight:700;color:var(--text-secondary);min-width:18px}.poi-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poi-drag-handle{cursor:grab;color:var(--border);font-size:12px;padding:0 4px}.poi-drag-handle:hover{color:var(--text-secondary)}#poi-edit-panel{position:fixed;top:var(--toolbar-height);right:0;bottom:var(--statusbar-height);width:var(--panel-width);background:var(--bg-panel);border-left:1px solid var(--border);z-index:85;overflow-y:auto;transition:transform .3s ease}#poi-edit-panel.panel-hidden{transform:translate(100%)}.poi-camera-info{display:flex;justify-content:space-between;align-items:center}.poi-camera-info .info-label{font-size:11px;color:var(--text-secondary)}.poi-camera-info .info-value{font-size:11px;color:var(--accent);font-family:monospace}.poi-label-3d{pointer-events:none;user-select:none;text-align:center}.poi-label-3d .poi-marker-icon{font-size:20px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.poi-label-3d .poi-number-label{background:#0f1629e6;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:700;color:#fff;margin-top:2px;border:1px solid rgba(79,195,247,.3)}.poi-label-3d.editing .poi-marker-icon{animation:poiPulse 1.2s ease-in-out infinite}@keyframes poiPulse{0%,to{transform:scale(1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}50%{transform:scale(1.3);filter:drop-shadow(0 0 8px rgba(79,195,247,.6))}}#tour-nav{position:fixed;bottom:48px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;padding:8px 16px;z-index:150;box-shadow:0 4px 20px #0006;animation:cardFadeIn .3s ease}.tour-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.tour-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}.tour-info{display:flex;flex-direction:column;align-items:center;min-width:120px}.tour-title{font-size:13px;font-weight:600;color:var(--text-primary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tour-progress{font-size:11px;color:var(--text-secondary)}#poi-info-card{position:fixed;z-index:200;background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:16px 20px;min-width:200px;max-width:320px;box-shadow:0 8px 32px #00000080;pointer-events:auto;animation:cardFadeIn .2s ease}.info-card-type.type-landmark{background:#4fc3f733;color:#4fc3f7}.info-card-type.type-viewpoint{background:#66bb6a33;color:#66bb6a}.info-card-type.type-entrance{background:#ffa72633;color:#ffa726}.info-card-type.type-custom{background:#ab47bc33;color:#ab47bc}body.mode-display .edit-only-section{display:none!important}.transform-row{display:flex;gap:6px;align-items:center;margin-top:4px}.transform-row input[type=number],.transform-row input[type=range]{flex:1}.mini-btn{background:var(--accent);color:#000;border:none;width:28px;height:28px;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.mini-btn:hover{background:var(--accent-hover)}.hint-text{font-size:11px;color:var(--text-secondary);line-height:1.4}#clip-overlay{position:fixed;inset:0;z-index:500;cursor:crosshair}#clip-rect{position:absolute;border:2px dashed #ef5350;background:#ef53501a;pointer-events:none;display:none}#clip-rect.active{display:block}#control-panel::-webkit-scrollbar,#annotation-list-body::-webkit-scrollbar,#annotation-edit-panel::-webkit-scrollbar,#poi-edit-panel::-webkit-scrollbar,#poi-list-body::-webkit-scrollbar{width:4px}#control-panel::-webkit-scrollbar-track,#annotation-list-body::-webkit-scrollbar-track,#annotation-edit-panel::-webkit-scrollbar-track,#poi-edit-panel::-webkit-scrollbar-track,#poi-list-body::-webkit-scrollbar-track{background:transparent}#control-panel::-webkit-scrollbar-thumb,#annotation-list-body::-webkit-scrollbar-thumb,#annotation-edit-panel::-webkit-scrollbar-thumb,#poi-edit-panel::-webkit-scrollbar-thumb,#poi-list-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media(max-width:768px){:root{--panel-width: 260px}.welcome-content{padding:24px 16px}.url-input-area{flex-direction:column}}
