*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:none}
*::-webkit-scrollbar{display:none}
:root{
--bg:#0f1117;--surface:#1a1d27;--surface2:#242836;--surface3:#2e3344;
--border:#363b4e;--border-hover:#4a5068;
--text:#e8eaed;--text2:#9aa0b4;--text3:#6b7185;
--primary:#4f8cff;--primary-hover:#3a7af0;--primary-bg:rgba(79,140,255,.1);
--accent:#ff6b4a;--accent-bg:rgba(255,107,74,.1);
--success:#4ade80;--warning:#fbbf24;
--danger:#f87171;--danger-bg:rgba(248,113,113,.1);
--radius:10px;--radius-sm:6px;--radius-lg:14px;
}
body{font-family:-apple-system,'Malgun Gothic',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;scrollbar-width:none}
body::-webkit-scrollbar{display:none}
body:has(#step5.active){overflow:hidden}
.app{max-width:1100px;margin:0 auto;padding:20px}

.header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:24px;border-bottom:1px solid var(--border)}
.header h1{font-size:1.4rem;font-weight:700}
.header h1 span{color:var(--primary)}
.header-sub{font-size:.82rem;color:var(--text3);margin-top:2px}

.stepper{display:flex;gap:4px;margin-bottom:28px;background:var(--surface);border-radius:var(--radius-lg);padding:6px;border:1px solid var(--border)}
.step-item{flex:1;display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius);cursor:pointer;transition:all .2s}
.step-item:hover{background:var(--surface2)}
.step-item.active{background:var(--primary-bg);border:1px solid rgba(79,140,255,.3)}
.step-item.completed .step-num{background:var(--success);color:#000}
.step-num{width:26px;height:26px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0}
.step-item.active .step-num{background:var(--primary);color:#fff}
.step-label{font-size:.8rem;font-weight:500;white-space:nowrap}
.step-item.active .step-label{color:var(--primary)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}
.card-title{font-size:1.05rem;font-weight:600;margin-bottom:4px}
.card-desc{font-size:.83rem;color:var(--text2);margin-bottom:20px}

.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.83rem;font-weight:500;margin-bottom:6px;color:var(--text2)}
.form-input{width:100%;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;font-family:inherit;transition:all .2s}
.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,140,255,.15)}

.btn{padding:9px 18px;border-radius:var(--radius-sm);font-size:.83rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent;font-family:inherit;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover)}
.btn-outline{background:transparent;color:var(--text2);border-color:var(--border)}
.btn-outline:hover{background:var(--surface2);color:var(--text)}
.btn-danger-sm{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:5px 10px;font-size:.75rem;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;transition:all .2s}
.btn-danger-sm:hover{background:var(--danger-bg)}

.footer-nav{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--border);margin-top:16px}

.tab-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px;min-height:50px}
.tab-preview-label{font-size:.75rem;color:var(--text3);margin-bottom:10px}
.tab-preview-bar{display:flex;gap:0;align-items:center}
.tab-preview-item{padding:8px 16px;cursor:default;border-bottom:2px solid transparent;transition:all .2s}
.tab-preview-item.active-tab{border-bottom-color:currentColor}

.type-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.type-row{display:flex;flex-direction:column;gap:5px;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s}
.type-row:hover{border-color:var(--border-hover)}
.type-row-top{display:flex;align-items:center;justify-content:space-between}
.type-row-num{font-size:.8rem;color:var(--text3);font-weight:500}
.type-row-controls{display:flex;align-items:center;gap:8px}
.type-row input[type=text]{padding:6px 10px;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.82rem;font-family:inherit;width:100%;transition:all .2s}
.type-row input[type=text]:focus{outline:none;border-color:var(--primary)}
.type-row input[type=color]{-webkit-appearance:none;width:30px;height:30px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:transparent;padding:2px}
.type-row input[type=color]::-webkit-color-swatch-wrapper{padding:0}
.type-row input[type=color]::-webkit-color-swatch{border:none;border-radius:3px}

.size-control{display:flex;align-items:center;gap:4px}
.size-control span{font-size:.78rem;color:var(--text3);min-width:35px;text-align:center}
.size-btn{width:28px;height:28px;border-radius:4px;background:var(--surface3);border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s}
.size-btn:hover{background:var(--border);color:#fff}

.add-type-btn{width:100%;padding:12px;border:2px dashed var(--border);border-radius:var(--radius);background:transparent;color:var(--text2);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}
.add-type-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}

.step-content{display:none}
.step-content.active{display:block}
#step5.active{display:flex;flex-direction:column;position:fixed;inset:8px 12px 12px 12px;z-index:1000;background:var(--bg);padding:0;max-width:none;border-radius:8px;box-shadow:0 4px 24px rgba(0,0,0,.3)}

.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 8px 8px 0;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}
.ed-toolbar-left{width:150px;flex-shrink:0;padding:0 4px}
.ed-toolbar-right{display:flex;align-items:center;gap:6px;padding-right:8px}

.ed-type-select{width:100%;padding:7px 8px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.78rem;font-family:inherit;cursor:pointer}
.ed-type-select:focus{outline:none;border-color:var(--primary)}

.editor-wrap{display:flex;flex:1;overflow:hidden}

.editor-left{width:150px;min-width:150px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface)}
.editor-left-header{padding:8px 10px;border-bottom:1px solid var(--border);background:var(--surface2);font-size:.78rem;font-weight:600;color:var(--text2)}
.editor-scene-list{flex:1;overflow-y:auto;padding:4px}
.ed-scene-item{display:flex;flex-direction:column;padding:4px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;border:2px solid transparent;margin-bottom:3px}
.ed-scene-item:hover{background:var(--surface2)}
.ed-scene-item.active{border-color:var(--primary);background:var(--primary-bg)}
.ed-scene-thumb{width:100%;aspect-ratio:16/9;background:var(--surface3);border-radius:4px;overflow:hidden}
.ed-scene-thumb img{width:100%;height:100%;object-fit:cover}
.ed-scene-name{font-size:.68rem;color:var(--text2);text-align:center;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ed-scene-item.active .ed-scene-name{color:var(--primary);font-weight:600}

.editor-center{flex:1;display:flex;flex-direction:column;min-width:200px}
.editor-panel-header{padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:.78rem;font-weight:600;color:var(--text2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.editor-map-area{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg);cursor:default}
.editor-map-area img{max-width:100%;max-height:100%;object-fit:contain;transform-origin:center center;transition:transform .1s ease-out;will-change:transform}
.ed-map-empty{color:var(--text3);font-size:.85rem}
.ed-map-info{font-size:.7rem;color:var(--text3)}

#mapPointsLayer{position:absolute;inset:0;pointer-events:none;z-index:2}
.map-point{position:absolute;pointer-events:auto;cursor:pointer;transform:translate(-50%,-50%);z-index:3;transition:transform .1s}
.map-point-dot{width:18px;height:18px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center}
.map-point-dot span{font-size:.55rem;font-weight:700;color:#fff}
.map-point.active .map-point-dot{background:var(--accent);transform:scale(1.3);box-shadow:0 0 0 3px rgba(255,107,74,.4)}
.map-point-label{position:absolute;left:50%;top:100%;transform:translateX(-50%);white-space:nowrap;font-size:.58rem;color:#fff;background:rgba(0,0,0,.7);padding:1px 5px;border-radius:3px;margin-top:2px;pointer-events:none}

.map-scene-popup{position:absolute;z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px;box-shadow:0 4px 16px rgba(0,0,0,.5);min-width:140px;max-height:240px;display:flex;flex-direction:column}
.map-popup-title{font-size:.72rem;font-weight:600;color:var(--text2);padding:4px 6px;border-bottom:1px solid var(--border);margin-bottom:4px}
.map-popup-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.map-popup-item{padding:6px 8px;font-size:.75rem;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}
.map-popup-item:hover{background:var(--primary-bg);color:var(--primary)}
.map-popup-item.placed{opacity:.4;cursor:default}
.map-popup-cancel{margin-top:4px;padding:5px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text3);font-size:.72rem;cursor:pointer;font-family:inherit}
.map-popup-cancel:hover{background:var(--surface2);color:var(--text)}

.ed-map-mode-msg{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);z-index:5;background:rgba(79,140,255,.9);color:#fff;padding:5px 14px;border-radius:20px;font-size:.72rem;font-weight:500;pointer-events:auto;display:flex;align-items:center;gap:8px}
.auto-link-btn{padding:3px 10px;border:1px solid rgba(255,255,255,.5);border-radius:12px;background:rgba(255,255,255,.15);color:#fff;font-size:.72rem;cursor:pointer;white-space:nowrap;transition:all .15s}
.auto-link-btn:hover{background:rgba(255,255,255,.3);border-color:#fff}
.scale-point{position:absolute;width:12px;height:12px;background:#ff6b35;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);z-index:5;pointer-events:none;box-shadow:0 0 6px rgba(255,107,53,.6)}
.map-point.link-start .map-point-dot{background:#4f8cff;transform:scale(1.4);box-shadow:0 0 0 4px rgba(79,140,255,.5);animation:linkPulse 1s infinite}
@keyframes linkPulse{0%,100%{box-shadow:0 0 0 4px rgba(79,140,255,.5)}50%{box-shadow:0 0 0 8px rgba(79,140,255,.2)}}

.editor-divider{width:8px;background:var(--surface3);cursor:col-resize;flex-shrink:0;transition:background .15s}
.editor-divider:hover{background:var(--primary)}

.editor-right{flex:1;display:flex;flex-direction:column;min-width:200px}
.editor-viewer-area{flex:1;position:relative;background:#111}
.ed-viewer-info{font-size:.7rem;color:var(--text3)}

.editor-bottom{display:none}
.ed-toolbar-sep{width:1px;height:20px;background:var(--border);margin:0 6px}
.ed-work-tab{padding:6px 12px;font-size:.75rem;font-weight:500;color:var(--text3);cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .2s;font-family:inherit;background:var(--surface2)}
.ed-work-tab:hover{color:var(--text2);background:var(--surface3)}
.ed-work-tab.active{color:var(--primary);background:var(--primary-bg);border-color:var(--primary);font-weight:600}

.poi-panel{width:100%}
.poi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.poi-toggle-btn{background:none;border:none;color:var(--text2);font-size:.72rem;font-family:inherit;cursor:pointer;padding:4px 0}
.poi-toggle-btn:hover{color:var(--text)}
.poi-add-btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 10px;font-size:.68rem;font-family:inherit;cursor:pointer}
.poi-add-btn:hover{background:var(--primary-hover)}
.poi-list{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}
.poi-empty{font-size:.68rem;color:var(--text3);text-align:center;padding:8px 0}
.poi-item{display:flex;align-items:center;gap:5px;padding:3px 4px;border-radius:4px;cursor:pointer;transition:background .15s}
.poi-item:hover{background:var(--surface2)}
.poi-marker-mini{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:#fff;flex-shrink:0}
.poi-text-input{flex:1;padding:3px 6px;background:var(--surface3);border:1px solid var(--border);border-radius:3px;color:var(--text);font-size:.68rem;font-family:inherit;min-width:0}
.poi-text-input:focus{outline:none;border-color:var(--primary)}
.poi-del-btn{background:none;border:none;color:var(--danger);font-size:.7rem;cursor:pointer;padding:2px 4px;flex-shrink:0}
.poi-del-btn:hover{color:#fff}
.poi-placing-msg{font-size:.7rem;color:var(--warning);padding:4px 0;text-align:center}
.poi-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999;display:flex;align-items:center;justify-content:center}
.poi-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;width:380px;max-width:90vw;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.poi-modal-title{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:14px}
.poi-modal-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.poi-modal-row label{font-size:.75rem;color:var(--text2);white-space:nowrap;min-width:70px}
.poi-modal-input{flex:1;padding:6px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.8rem;font-family:inherit}
.poi-modal-input:focus{outline:none;border-color:var(--primary)}
.poi-modal-short{max-width:60px;text-align:center}
.poi-modal-color{width:32px;height:32px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:1px;background:transparent}
.poi-modal-range{width:80px;accent-color:var(--primary);cursor:pointer}
.poi-modal-preview{display:flex;justify-content:center;padding:12px 0;margin:4px 0}
.poi-preview-marker{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.3);transition:all .15s}
.poi-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}
.poi-modal-section{font-size:.75rem;font-weight:700;color:var(--primary);padding:6px 0 4px;margin-top:6px;border-top:1px solid var(--border)}
.poi-modal-section:first-of-type{border-top:none;margin-top:0}
.poi-modal-desc-preview{text-align:center;padding:6px 0;background:rgba(0,0,0,.3);border-radius:var(--radius-sm);margin:4px 0}
.poi-toggle-btn{position:absolute;top:70px;left:10px;z-index:12;width:36px;height:36px;background:rgba(0,0,0,.5);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;border:1px solid rgba(255,255,255,.15)}
.poi-toggle-btn:hover{background:rgba(0,0,0,.7)}
.poi-badge{position:absolute;top:-5px;right:-5px;width:18px;height:18px;background:#de6600;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:700;border:1.5px solid rgba(0,0,0,.5)}
.poi-dropdown{position:absolute;top:70px;left:10px;width:350px;max-height:50%;overflow-y:auto;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.1);border-radius:8px;z-index:13;transform:scale(0);opacity:0;transform-origin:top left;transition:transform .2s ease,opacity .2s ease}
.poi-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-bottom:1px solid rgba(255,255,255,.1);color:#fff;font-size:.95rem;font-weight:600}
.poi-dropdown-close{cursor:pointer;color:rgba(255,255,255,.5);font-size:14px;padding:2px 4px}
.poi-dropdown-close:hover{color:#fff}
.poi-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}
.poi-dropdown-item:hover{background:rgba(255,255,255,.08)}
.poi-dropdown-marker{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.poi-dropdown-text{flex:1;font-size:12px;color:#fff;white-space:normal;word-break:break-all;line-height:1.4}
.poi-dropdown-edit{color:rgba(130,170,255,.8);font-size:13px;cursor:pointer;padding:2px 4px;flex-shrink:0}
.poi-dropdown-edit:hover{color:#fff}
.poi-dropdown-del{color:rgba(255,100,100,.7);font-size:12px;cursor:pointer;padding:2px 4px;flex-shrink:0}
.poi-dropdown-del:hover{color:#ff5555}
.poi-crosshair-overlay{position:absolute;inset:0;pointer-events:none;z-index:10}
.poi-crosshair-v{position:absolute;left:50%;top:0;bottom:0;width:1px;background:rgba(255,255,255,.5);transform:translateX(-50%)}
.poi-crosshair-h{position:absolute;top:50%;left:0;right:0;height:1px;background:rgba(255,255,255,.5);transform:translateY(-50%)}
.poi-add-center-btn{position:absolute;left:50%;top:calc(50% + 20px);transform:translateX(-50%);pointer-events:auto;background:rgba(79,140,255,.9);color:#fff;border:none;padding:6px 16px;border-radius:20px;font-size:.78rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.3);transition:all .15s;font-family:inherit}
.poi-add-center-btn:hover{background:rgba(79,140,255,1);transform:translateX(-50%) scale(1.05)}
.ed-work-info{font-size:.68rem;color:var(--text3);padding:4px 0}

.empty-state{text-align:center;padding:40px 20px;color:var(--text3)}
.empty-state p{font-size:.88rem;margin-bottom:4px}
.empty-state span{font-size:.78rem}

.type-col-labels{display:none}

.upload-type-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0}
.upload-type-body{padding:16px;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);background:var(--surface)}
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;cursor:pointer;position:relative;transition:all .2s}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--primary);background:var(--primary-bg)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-top:12px}
.file-card{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:6px;position:relative}
.file-card:hover{border-color:var(--border-hover)}
.file-remove{position:absolute;top:10px;left:10px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;cursor:pointer;font-size:.65rem;display:flex;align-items:center;justify-content:center;z-index:1}
.file-tag{position:absolute;top:10px;right:10px;font-size:.6rem;font-weight:600;padding:2px 6px;border-radius:3px}
.file-tag.pano{background:rgba(79,140,255,.15);color:#4f8cff}
.file-tag.map{background:rgba(255,107,74,.15);color:#ff6b4a}
.file-tag.depth{background:rgba(160,120,255,.15);color:#a078ff}
.upload-summary-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;margin-bottom:4px;font-size:.78rem}
.upload-summary-type{color:#fff;font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.upload-summary-cell{color:var(--text2);white-space:nowrap}
.file-thumb{width:100%;aspect-ratio:16/9;border-radius:4px;overflow:hidden;margin-bottom:4px;background:var(--surface3)}
.file-thumb img{width:100%;height:100%;object-fit:cover}
.file-name{font-size:.72rem;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.text-setting-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:18px}
.text-setting-main{flex:1;min-width:0}
.text-style-controls{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-bottom:1px}
.style-control-item{display:flex;align-items:center;gap:3px}
.style-control-item input[type=color]{-webkit-appearance:none;width:34px;height:34px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:transparent;padding:2px}
.style-control-item input[type=color]::-webkit-color-swatch-wrapper{padding:0}
.style-control-item input[type=color]::-webkit-color-swatch{border:none;border-radius:3px}
.text-size-val{font-size:.75rem;color:var(--text3);min-width:32px;text-align:center}

.logo-upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;cursor:pointer;position:relative;transition:all .2s}
.logo-upload-zone:hover,.logo-upload-zone.dragover{border-color:var(--primary);background:var(--primary-bg)}
.logo-upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.logo-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}
.logo-preview-wrap img{max-width:300px;max-height:120px;object-fit:contain;border-radius:6px;background:var(--surface3);padding:8px}
.logo-remove-btn{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger);padding:5px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;font-family:inherit;transition:all .2s}
.logo-remove-btn:hover{background:var(--danger);color:#fff}

.logo-settings-row{display:flex;gap:16px;align-items:stretch}
.logo-settings-row .logo-upload-zone{flex:1;min-width:0;margin:0}
.logo-controls-panel{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius)}
.logo-ctrl-group{display:flex;flex-direction:column;gap:8px}
.logo-ctrl-label{font-size:.78rem;font-weight:600;color:var(--text2)}
.logo-scale-control{display:flex;align-items:center;gap:4px;justify-content:center}
.logo-scale-val{font-size:.78rem;color:var(--text3);min-width:40px;text-align:center}
.logo-range{width:100%;height:4px;-webkit-appearance:none;background:var(--surface3);border-radius:2px;outline:none;cursor:pointer}
.logo-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer}
.logo-align-selector{display:flex;gap:4px}
.logo-align-btn{flex:1;padding:7px 0;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text3);font-size:.75rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;text-align:center}
.logo-align-btn:hover{color:var(--text2);border-color:var(--border-hover)}
.logo-align-btn.active{background:var(--primary-bg);border-color:var(--primary);color:var(--primary);font-weight:600}

#step3 .card-desc{display:none}
.step3-layout{display:flex;gap:20px;height:calc(100vh - 140px)}
.step3-left{flex:1;display:flex;flex-direction:column;min-width:0}
.step3-right{width:200px;flex-shrink:0}
.step3-thumb-selector{display:flex;flex-direction:column;gap:8px}
.step3-thumb-btn{padding:14px;background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);color:var(--text2);font-size:.88rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.step3-thumb-btn:hover{border-color:var(--border-hover)}
.step3-thumb-btn.selected{border-color:var(--primary);background:var(--primary-bg);color:var(--primary);font-weight:600}
.step3-thumb-icon{font-size:1.1rem}

.thumb-position-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.thumb-option{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s}
.thumb-option:hover{border-color:var(--border-hover)}
.thumb-option.selected{border-color:var(--primary);background:var(--primary-bg)}
.thumb-option-icon{width:100%;max-width:160px}
.thumb-mock-screen{width:100%;aspect-ratio:16/10;background:var(--surface3);border-radius:4px;position:relative;overflow:hidden}
.thumb-mock-bar-v{position:absolute;right:4px;top:4px;bottom:4px;width:16px;background:var(--primary);border-radius:3px;opacity:.5}
.thumb-mock-bar-h{position:absolute;left:4px;right:4px;bottom:4px;height:16px;background:var(--primary);border-radius:3px;opacity:.5}
.thumb-option.selected .thumb-mock-bar-v,.thumb-option.selected .thumb-mock-bar-h{opacity:.9}
.thumb-option-label{font-size:.9rem;font-weight:600}
.thumb-option-desc{font-size:.76rem;color:var(--text3)}

.hl-type-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.hl-tab{padding:8px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-size:.83rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}
.hl-tab:hover{background:var(--surface3)}
.hl-tab.active{background:var(--primary-bg);border-color:currentColor;font-weight:600}

.hl-scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.hl-scene-card{background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);padding:6px;position:relative;cursor:grab;transition:all .2s}
.hl-scene-card:hover{border-color:var(--border-hover)}
.hl-scene-card.unchecked{opacity:.4}
.hl-scene-card.dragging{opacity:.3}
.hl-scene-card.drag-over{border-color:var(--primary);box-shadow:0 0 0 2px rgba(79,140,255,.3)}
.hl-scene-card.start-scene{border-color:var(--primary);box-shadow:0 0 0 2px rgba(232,116,14,.3)}
.hl-card-start{position:absolute;bottom:4px;left:4px;z-index:1;background:rgba(232,116,14,.9);color:#fff;font-size:.6rem;padding:2px 5px;border-radius:3px}
.hl-card-top{position:relative}
.hl-card-thumb{width:100%;aspect-ratio:16/9;background:var(--surface3);border-radius:4px;overflow:hidden;cursor:pointer}
.hl-card-thumb img{width:100%;height:100%;object-fit:cover}
.hl-card-check{position:absolute;top:4px;left:4px;z-index:1}
.hl-card-check input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}
.hl-card-order{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.65);color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:3px;z-index:1}
.hl-card-file{font-size:.68rem;color:var(--text3);margin-top:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.hl-card-name{margin-top:4px}
.hl-name-input{width:100%;padding:6px 8px;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.8rem;font-family:inherit;transition:all .2s;text-align:center}
.hl-name-input:focus{outline:none;border-color:var(--primary)}

.hl-info{display:flex;gap:16px;padding:12px 0 0;font-size:.75rem;color:var(--text3)}

#step1.active{display:flex;flex-direction:column;height:calc(100vh - 140px)}
.step1-layout{display:flex;gap:20px;flex:1;min-height:0;align-items:flex-start}
.step1-left{width:45%;flex-shrink:0;display:flex;flex-direction:column;min-width:0;height:100%}
.step1-right{flex:1;min-width:0;max-height:100%;overflow-y:auto;scrollbar-width:none}
.step1-right::-webkit-scrollbar{display:none}
.step1-left .card{flex-shrink:0}
.step1-divider{display:flex;align-items:center;gap:10px;margin:8px 0;flex-shrink:0}
.step1-divider-line{flex:1;height:1px;background:var(--border)}
.step1-divider span{font-size:.75rem;color:var(--text3);white-space:nowrap}
.step1-type-scroll{margin-bottom:12px}

@media(max-width:768px){
.stepper{overflow-x:auto}
.step-label{font-size:.7rem}
.step1-layout{flex-direction:column}
#step1.active{height:auto}
.step1-left{width:100%}
.type-col-labels{display:none}
.thumb-position-selector{grid-template-columns:1fr}
.text-setting-row{flex-direction:column;align-items:stretch;gap:8px}
.text-style-controls{justify-content:flex-end}
.logo-settings-row{flex-direction:column}
.logo-controls-panel{width:100%}
}
