*{margin:0;padding:0;box-sizing:border-box}.player-bar,.sidebar__scroll,.editor__timeline,.settings-panel__scroll{scrollbar-width:none}.player-bar::-webkit-scrollbar,.sidebar__scroll::-webkit-scrollbar,.editor__timeline::-webkit-scrollbar,.settings-panel__scroll::-webkit-scrollbar{display:none}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-card: #16213e;--text-primary: #e0e0e0;--text-secondary: #a0a0b0;--accent: #4ECDC4;--accent-hover: #45b7b0;--danger: #FF6B6B;--stage-bg: #1a1a2e;--stage-wing: #0a0a15;--border: rgba(255,255,255,.06);--border-strong: rgba(255,255,255,.1)}:root.light{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-card: #e8e8ed;--text-primary: #1a1a2e;--text-secondary: #6b6b80;--accent: #2ba89e;--accent-hover: #239088;--danger: #e05555;--stage-bg: #e0e0e8;--stage-wing: #c8c8d0;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.15)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh}.dashboard{max-width:900px;margin:0 auto;padding:40px 20px}.dashboard__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard__title{font-size:24px;font-weight:700}.dashboard__subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px}.btn{padding:8px 18px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s}.btn--primary{background:var(--accent);color:#000}.btn--primary:hover{background:var(--accent-hover)}.btn--danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-strong)}.btn--ghost:hover{border-color:var(--text-secondary);color:var(--text-primary)}.note-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.note-card{background:var(--bg-card);border-radius:10px;padding:0;cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.note-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.note-card__thumbnail{line-height:0}.note-card__thumbnail canvas{width:100%;height:auto;display:block}.note-card__title{font-size:16px;font-weight:600;margin-bottom:8px;padding:12px 16px 0}.note-card__meta{font-size:12px;color:var(--text-secondary);padding:0 16px 14px}.note-card__delete{position:absolute;top:8px;right:8px;background:#00000080;border:none;color:#fff;cursor:pointer;font-size:14px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:1}.note-card:hover .note-card__delete{opacity:1}.note-card__delete:hover{color:var(--danger)}.empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary)}.empty-state__icon{font-size:48px;margin-bottom:16px}.editor{display:grid;grid-template-columns:1fr 0px 40px;grid-template-rows:auto 1fr auto auto;height:100vh;height:100dvh;gap:0;overflow:hidden;width:100%;transition:grid-template-columns .25s ease}.editor--sidebar-open{grid-template-columns:1fr 220px 40px}.editor>*{min-width:0;min-height:0}body:has(.editor){overflow:hidden;position:fixed;width:100%;height:100%;height:100dvh;touch-action:none}html:has(.editor){overflow:hidden}.editor__header{grid-column:1 / -1;display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.editor__back{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px}.editor__title-input{background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:16px;font-weight:600;padding:4px 8px;border-radius:4px;width:200px}.editor__title-input:focus{border-color:var(--accent);outline:none}.editor__actions{margin-left:auto;display:flex;gap:8px}.player-bar{grid-column:1 / -1;display:flex;align-items:center;gap:12px;padding:0 16px;height:40px;background:var(--bg-secondary);border-top:1px solid var(--border);overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;white-space:nowrap}.player-bar__time{font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.player-bar__time--sep{margin:0 1px}.player-bar__btn{background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:20px;padding:2px 6px;line-height:1;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.player-bar__btn:hover{color:var(--accent)}.player-bar__duration{cursor:pointer;border-bottom:1px dashed var(--text-secondary)}.player-bar__duration:hover{color:var(--accent)}.player-bar__music-name{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px;opacity:.7}.toolbar{display:flex;gap:6px;align-items:center}.toolbar__btn{background:var(--border);border:1px solid var(--border-strong);color:var(--text-secondary);padding:6px 10px;border-radius:4px;cursor:pointer;font-size:12px;min-height:32px}.toolbar__btn:hover{background:var(--border-strong);color:var(--text-primary)}.toolbar__btn--active{background:#4ecdc433;border-color:var(--accent);color:var(--accent)}.toolbar__separator{width:1px;height:20px;background:var(--border-strong);margin:0 4px}.editor__main{grid-row:2;grid-column:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:var(--bg-primary);overflow:hidden;min-width:0;min-height:0}.stage-container{position:relative;border-radius:10px}.stage-container--preview{box-shadow:0 0 0 2px var(--accent);z-index:1}.stage-container--swap{box-shadow:0 0 0 2px #f59e0b;z-index:1}.stage-wrap{transition:transform .4s ease}.stage-canvas{border-radius:8px;display:block;touch-action:none}.stage-3d-banner{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:50;background:#000000bf;color:var(--accent);font-size:12px;font-weight:600;padding:6px 18px;border-radius:20px;border:1px solid var(--accent);cursor:pointer;pointer-events:none;opacity:0;transition:opacity .25s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap}.stage-3d-banner--visible{opacity:1;pointer-events:auto}.stage-3d-banner--visible:hover{background:#000000d9}.stage-swap-banner{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:50;background:#000000bf;color:#f59e0b;font-size:12px;font-weight:600;padding:6px 18px;border-radius:20px;border:1px solid #F59E0B;cursor:pointer;pointer-events:none;opacity:0;transition:opacity .25s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap}.stage-swap-banner--visible{opacity:1;pointer-events:auto}.stage-swap-banner--visible:hover{background:#000000d9}.editor__sidebar{grid-row:2;grid-column:2;width:220px;min-width:220px;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.editor__sidebar--hidden{display:none}.sidebar-rail{grid-row:2;grid-column:3;display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:4px;background:var(--bg-secondary);border-left:1px solid var(--border);width:40px}.sidebar-rail__icon{width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;color:var(--text-secondary)}.sidebar-rail__icon:hover{background:var(--border-strong);color:var(--text-primary)}.sidebar-rail__icon--active{background:#4ecdc433;color:var(--accent)}.sidebar__tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar__tab{flex:1;padding:10px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500}.sidebar__tab:hover{color:var(--text-primary)}.sidebar__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar__panel{display:flex;flex-direction:column;flex:1;min-height:0}.sidebar__panel--hidden{display:none}.sidebar__panel-title{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border);flex-shrink:0}.preset-selection-info{font-size:12px;color:var(--accent);padding:8px 0 0;min-height:0}.preset-selection-info:empty{display:none}.preset-spacing{display:flex;align-items:center;gap:8px;padding:10px 0;-webkit-user-select:none;user-select:none}.preset-spacing span:not(.settings-label){font-size:14px;color:var(--text-primary);min-width:28px;text-align:center}.preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding-bottom:12px;-webkit-user-select:none;user-select:none}.preset-card{background:var(--border);border:1px solid var(--border-strong);border-radius:8px;cursor:pointer;overflow:hidden;transition:border-color .15s}.preset-card:hover{border-color:var(--accent)}.preset-card canvas{display:block;width:100%;height:80px}.preset-card__name{padding:4px 0;text-align:center;font-size:11px;color:var(--text-secondary)}.preset-card--custom{position:relative}.preset-card__delete{position:absolute;top:2px;right:2px;width:18px;height:18px;border:none;background:#00000080;color:var(--text-secondary);font-size:10px;border-radius:50%;cursor:pointer;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.preset-card--custom:hover .preset-card__delete{opacity:1}.preset-card__delete:hover{background:var(--danger);color:#fff}.preset-card__count{color:var(--accent);font-size:10px}.preset-card--mismatch .preset-card__count{color:var(--danger)}.preset-card--add{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:105px;border-style:dashed}.preset-card__add-icon{font-size:24px;color:var(--text-secondary);line-height:1}.sidebar__header{padding:12px 16px 8px;font-size:11px;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar__scroll{flex:1;overflow-y:auto;padding:8px 16px}.sidebar__actions{padding:8px 16px 12px;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--border)}.sidebar__actions--hidden{display:none}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}.sidebar-overlay--visible{display:block;touch-action:none}.sidebar__section{margin-bottom:20px}.sidebar__section-title{font-size:11px;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:10px}.dancer-list{display:flex;flex-direction:column;gap:4px}.dancer-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;position:relative;transition:background .1s}.dancer-item:hover{background:#ffffff0d}.dancer-item--selected{background:#4ecdc426}.dancer-item__number{font-size:11px;color:var(--text-secondary);min-width:16px;text-align:right;flex-shrink:0}.dancer-item__color-btn{width:18px;height:18px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.2);cursor:pointer}.dancer-item__color-btn:hover{border-color:#ffffff80}.color-palette-popup{position:absolute;left:0;top:100%;margin-top:4px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;padding:8px;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;z-index:100;box-shadow:0 4px 16px #0006}.color-palette__swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .1s,transform .1s}.color-palette__swatch:hover{transform:scale(1.15);border-color:#ffffff80}.color-palette__swatch--active{border-color:#fff}.color-palette__custom{grid-column:1 / -1;display:flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--text-secondary);padding-top:4px;border-top:1px solid var(--border);margin-top:2px}.color-palette__custom input[type=color]{width:24px;height:24px;border:none;padding:0;background:none;cursor:pointer}.dancer-item__name{font-size:13px;flex:1;background:none;border:none;color:var(--text-primary);padding:2px 4px;border-radius:3px;width:100%}.dancer-item__name:focus{outline:1px solid var(--accent)}.dancer-item__remove{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;opacity:0;transition:opacity .1s}.dancer-item:hover .dancer-item__remove{opacity:1}.editor__timeline{flex:1;overflow-x:auto;overflow-y:hidden;position:relative;-webkit-overflow-scrolling:touch;touch-action:pan-x}.timeline__scrollbar{height:16px;background:var(--border);position:relative;flex-shrink:0;cursor:pointer;border-top:1px solid var(--border)}.timeline__scrollbar-thumb{position:absolute;top:2px;height:12px;background:var(--text-secondary);border-radius:6px;cursor:grab;min-width:30px;opacity:.5}.timeline__scrollbar-thumb:hover{opacity:.8}.timeline__scrollbar-thumb:active{cursor:grabbing}.timeline__bottom-bar{display:flex;align-items:center;gap:8px;padding:4px 8px 30px;flex-shrink:0;border-top:1px solid var(--border)}.timeline__bottom-bar .timeline__scrollbar{flex:1;border-top:none}.timeline__zoom{display:flex;align-items:center;gap:4px;flex-shrink:0}.timeline__zoom-btn{width:32px;height:32px;border:1px solid var(--border-strong);border-radius:4px;background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1}.timeline__zoom-btn:hover{background:var(--border-strong)}.timeline__zoom-label{font-size:11px;color:var(--text-secondary);min-width:36px;text-align:center;font-variant-numeric:tabular-nums}.timeline{position:relative;height:100%;min-width:100%}.timeline__ruler{height:40px;position:relative;border-bottom:1px solid var(--border-strong);cursor:pointer;-webkit-user-select:none;user-select:none}.timeline__tick{position:absolute;bottom:0;color:var(--text-secondary);font-size:10px;pointer-events:none;display:flex;flex-direction:column;align-items:center}.timeline__tick-label{position:absolute;top:4px;font-size:10px;white-space:nowrap;transform:translate(-50%);font-variant-numeric:tabular-nums}.timeline__tick-line{position:absolute;bottom:0;width:1px;background:var(--border-strong)}.timeline__tick-line--major{height:14px;background:var(--text-secondary)}.timeline__tick-line--minor,.timeline__tick-line--sub{height:8px;background:var(--border-strong)}.editor__timeline-wrap{grid-column:1 / -1;display:flex;flex-direction:column;border-top:1px solid var(--border);background:var(--bg-secondary)}.timeline__waveform{position:absolute;top:48px;left:0;height:50px;pointer-events:none}.timeline__formations{position:relative;height:50px;margin-top:8px;cursor:pointer;margin-bottom:16px;-webkit-user-select:none;user-select:none}.formation-box{position:absolute;height:44px;background:#4ecdc41f;border:1px solid rgba(78,205,196,.5);border-radius:6px;cursor:grab;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-primary);-webkit-user-select:none;user-select:none;touch-action:none}.formation-box--active{background:#4ecdc459;border-color:var(--accent);box-shadow:0 0 8px #4ecdc44d}.formation-box--selected{background:#4ecdc459;border-width:2px}.formation-box__handle{position:absolute;top:50%;transform:translateY(-50%);width:8px;height:24px;border-radius:3px;background:#4ecdc499;border:1px solid rgba(78,205,196,.8);cursor:col-resize;opacity:0;pointer-events:none;transition:opacity .15s}.formation-box__handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:44px;cursor:col-resize}.formation-box--selected .formation-box__handle,.formation-box--active .formation-box__handle{opacity:1;pointer-events:auto}.formation-box__handle:hover{background:#ffb432cc!important;border-color:#ffb432}.formation-box__handle--left{left:-5px}.formation-box__handle--right{right:-5px}.transition-highlight{position:absolute;height:44px;background:#ffb43226;border:1px dashed rgba(255,180,50,.5);border-radius:4px;pointer-events:none}.timeline__marker{position:absolute;top:30px;width:2px;height:100%;background:var(--danger);pointer-events:none;z-index:10}.timeline__marker-handle{position:absolute;top:-9px;left:-8px;width:18px;height:18px;background:var(--danger);border-radius:50%;cursor:grab;pointer-events:all}.export-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:500;display:flex;align-items:center;justify-content:center}.export-overlay__box{background:var(--bg-card);border-radius:12px;padding:32px 48px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.export-overlay__text{font-size:16px;color:var(--text-primary)}.export-options{display:flex;gap:12px;margin:8px 0}.export-option-btn{padding:8px 16px!important;font-size:14px!important}.export-option--active{background:#4ecdc433!important;border-color:var(--accent)!important;color:var(--accent)!important}.export-overlay__progress{font-size:36px;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-card);color:var(--text-primary);padding:10px 20px;border-radius:8px;font-size:14px;box-shadow:0 4px 20px #0006;transition:transform .3s ease;z-index:1000}.toast--visible{transform:translate(-50%) translateY(0)}.settings-panel{position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-strong);z-index:250;display:flex;flex-direction:column;transform:translate(0);transition:transform .25s ease;box-shadow:-4px 0 20px #0000004d}.settings-panel--hidden{transform:translate(100%)}.settings-panel__header{padding:14px 16px;font-size:16px;font-weight:600;border-bottom:1px solid var(--border);flex-shrink:0}.settings-panel__scroll{flex:1;overflow-y:auto;padding:12px 16px}.settings-section{margin-bottom:18px}.settings-label{font-size:11px;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:8px}.settings-row{display:flex;align-items:center;gap:8px;justify-content:space-between}.settings-row span{font-size:12px;color:var(--text-primary)}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;cursor:pointer}.toggle-row span{font-size:13px;color:var(--text-primary)}.toggle-switch{width:36px;height:20px;border-radius:10px;background:var(--border-strong);position:relative;transition:background .2s;flex-shrink:0}.toggle-switch--on{background:var(--accent)}.toggle-switch__thumb{width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:left .2s}.toggle-switch--on .toggle-switch__thumb{left:18px}.settings-slider-row{display:flex;align-items:center;gap:8px;margin-top:8px}.settings-slider-label{font-size:11px;color:var(--text-secondary);min-width:24px;flex-shrink:0}.settings-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-strong);border-radius:2px;outline:none;cursor:pointer}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}.settings-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:none;cursor:pointer}.settings-slider-value{font-size:11px;color:var(--text-secondary);min-width:28px;text-align:right;font-variant-numeric:tabular-nums}.settings-divider{height:1px;background:var(--border-strong);margin:16px 0}.settings-sub{font-size:11px;color:var(--text-secondary);opacity:.7}.settings-music-name{font-size:11px;color:var(--text-secondary);max-width:140px;line-height:1.4;word-break:break-all}.settings-btn-sm{padding:6px 16px!important;font-size:12px!important;background:none!important;border:1px solid var(--border-strong)!important;border-radius:4px;color:var(--accent)!important;text-decoration:none;cursor:pointer;min-height:32px;white-space:nowrap}.preset-btn-box{padding:4px 12px!important;font-size:14px!important;background:var(--border)!important;border:1px solid var(--border-strong)!important;color:var(--text-primary)!important;text-decoration:none!important;border-radius:4px}.preset-btn-box:hover{background:var(--border-strong)!important}.settings-btn-sm:hover{color:var(--accent-hover)!important;background:var(--border)!important}.settings-options{display:flex;gap:6px;flex-wrap:wrap}.settings-option{padding:6px 12px;border:1px solid var(--border-strong);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .15s}.settings-option:hover{border-color:var(--accent);color:var(--text-primary)}.settings-option--active{background:#4ecdc426;border-color:var(--accent);color:var(--accent)}.inspector-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:48px 16px;color:var(--text-secondary)}.inspector-empty__text{font-size:13px;opacity:.6}.sidebar__scroll--hidden{display:none}.inspector-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;min-height:32px}.inspector-header__name{flex:1;width:100%;padding:0;border:none;background:transparent;color:var(--text-primary);font-size:13px;outline:none}.inspector-header__multi{font-size:13px;color:var(--text-secondary)}.inspector-row{display:flex;gap:6px}.inspector-field{display:flex;align-items:center;flex:1;background:var(--border);border-radius:8px;padding:0 10px;height:32px}.inspector-field__label{font-size:12px;color:var(--text-secondary);margin-right:6px;flex-shrink:0}.inspector-field__input{width:100%;padding:0;border:none;background:transparent;color:var(--text-primary);font-size:13px;outline:none;-moz-appearance:textfield}.inspector-field__input::-webkit-inner-spin-button,.inspector-field__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.inspector-field:focus-within{outline:1px solid var(--accent)}.inspector-field__input:disabled{color:var(--text-secondary);opacity:.5;cursor:default}.inspector-field__input::placeholder{color:var(--text-secondary);opacity:.5}.inspector-direction{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:calc((100% - 6px)/2)}.inspector-dir-btn{aspect-ratio:1;border:1px solid var(--border-strong);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.inspector-dir-btn:hover{border-color:var(--accent);color:var(--text-primary)}.inspector-dir-btn--active{background:#4ecdc426;border-color:var(--accent);color:var(--accent)}.inspector-direction--disabled .inspector-dir-btn{opacity:.4;cursor:default;pointer-events:none}.inspector-dir-center{aspect-ratio:1;border-radius:50%;background:var(--border);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.inspector-palette{display:flex;gap:6px;flex-wrap:wrap}.inspector-palette__swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s}.inspector-palette__swatch:hover{transform:scale(1.15)}.inspector-palette__swatch--active{border-color:var(--accent)}.inspector-palette__custom{background:var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-secondary);border:2px dashed var(--border-strong)}.inspector-palette__custom.inspector-palette__swatch--active{border-style:solid;border-color:var(--accent)}.inspector-palette__custom:hover{color:var(--text-primary)}.preset-popup{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:8px;padding:6px;display:flex;flex-wrap:wrap;gap:4px;z-index:100;box-shadow:0 4px 16px #0006;min-width:200px}.preset-popup__item{padding:6px 12px;background:var(--border);border:1px solid var(--border-strong);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:12px}.preset-popup__item:hover{background:#4ecdc433;border-color:var(--accent)}.shortcut-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:600;display:flex;align-items:center;justify-content:center}.shortcut-modal__box{background:var(--bg-card);border-radius:12px;padding:24px 32px;min-width:300px}.shortcut-modal__title{font-size:18px;font-weight:700;margin-bottom:16px}.shortcut-modal__list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.shortcut-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.shortcut-row kbd{background:var(--border-strong);border:1px solid var(--border-strong);border-radius:4px;padding:2px 8px;font-size:12px;font-family:monospace;color:var(--text-primary)}.shortcut-row span{font-size:13px;color:var(--text-secondary)}.shortcut-modal__close{width:100%}.sort-dropdown select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--border-strong);color:var(--text-secondary);padding:6px 28px 6px 10px;border-radius:6px;font-size:13px;cursor:pointer}.landing{min-height:100vh;display:flex;flex-direction:column}.landing__nav{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;position:sticky;top:0;background:color-mix(in srgb,var(--bg-primary) 90%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;border-bottom:1px solid var(--border)}.landing__logo{font-size:20px;font-weight:700;color:var(--accent)}.landing__hero{text-align:center;padding:120px 24px 60px;max-width:640px;margin:0 auto}.landing__title{font-size:44px;font-weight:800;line-height:1.25;color:var(--text-primary);margin-bottom:20px;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif}.landing__subtitle{font-size:17px;line-height:1.7;color:var(--text-secondary);margin-bottom:36px}.landing__cta{padding:14px 36px;font-size:16px;font-weight:600;border-radius:8px}.landing__note{margin-top:14px;font-size:13px;color:var(--text-secondary)}.landing__demo{width:100%;max-width:560px;margin:0 auto;padding:0 24px 60px;display:flex;justify-content:center}.demo-canvas{border-radius:8px;display:block}.landing__features{display:flex;flex-direction:column;gap:0;width:100%;max-width:520px;margin:0 auto;padding:0 24px 60px}.feature-row{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}.feature-row:last-child{border-bottom:none}.feature-row__icon{color:var(--accent);flex-shrink:0;margin-top:2px}.feature-row__text{display:flex;flex-direction:column;gap:4px}.feature-row__text strong{font-size:15px;color:var(--text-primary)}.feature-row__text span{font-size:14px;line-height:1.5;color:var(--text-secondary)}.landing__how{max-width:600px;margin:0 auto;padding:60px 24px 80px}.landing__section-title{font-size:28px;font-weight:700;color:var(--text-primary);text-align:left;margin-bottom:40px;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif}.steps{display:flex;flex-direction:column;gap:28px}.step{display:flex;gap:20px;align-items:flex-start}.step__number{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#000;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step__text strong{display:block;font-size:16px;color:var(--text-primary);margin-bottom:4px}.step__text p{font-size:14px;color:var(--text-secondary);line-height:1.5}.landing__cta-section{text-align:center;padding:60px 24px;background:var(--bg-secondary);border-top:1px solid var(--border)}.landing__cta-section h2{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif}.landing__cta-section p{color:var(--text-secondary);margin-bottom:24px}.landing__footer{text-align:center;padding:24px;font-size:13px;color:var(--text-secondary);border-top:1px solid var(--border)}@media (max-width: 768px){.landing__hero{padding:60px 20px 50px}.landing__title{font-size:28px}.landing__subtitle{font-size:15px}.landing__demo,.landing__features{padding:0 16px 40px}.landing__how{padding:20px 16px 50px}.landing__section-title{font-size:22px}.dashboard{padding:24px 16px}.dashboard__header{flex-direction:column;align-items:flex-start;gap:12px}.note-grid{grid-template-columns:1fr}.editor{grid-template-columns:1fr;grid-template-rows:auto 1fr auto auto;height:100vh;height:100dvh}.sidebar-rail{display:none}.editor__sidebar{grid-row:auto;grid-column:auto;position:fixed;bottom:0;left:0;right:0;width:auto;max-height:80vh;background:var(--bg-secondary);border-top:1px solid var(--border-strong);border-left:none;border-radius:16px 16px 0 0;padding:12px 16px 24px;overflow-y:auto;z-index:200;transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -4px 20px #0006}.editor__sidebar:before{content:"";display:block;width:36px;height:4px;background:#ffffff4d;border-radius:2px;margin:0 auto 12px}.editor__sidebar:not(.editor__sidebar--hidden){display:flex;transform:translateY(0)}.editor__sidebar.editor__sidebar--hidden{display:block;transform:translateY(100%)}.editor__main{padding:10px;order:2}.player-bar{order:3}.editor__timeline-wrap{order:4}.stage-canvas{width:100%!important;height:auto!important}.editor__header{flex-wrap:wrap;gap:8px;padding:8px 12px}.editor__title-input{width:120px;font-size:14px}.editor__actions{gap:4px}.editor__actions .btn{padding:6px 10px;font-size:12px}.player-bar{gap:6px;padding:0 10px;height:36px}.player-bar__time{font-size:11px}.toolbar{gap:4px;overflow-x:auto;flex-shrink:0}.toolbar__btn{padding:3px 7px;font-size:11px;white-space:nowrap}.editor__timeline{height:80px}.sidebar__section{margin-bottom:16px}.dancer-list{flex-direction:column;gap:8px}.dancer-item{padding:10px 12px;background:var(--border);border-radius:8px}.dancer-item__color{width:20px;height:20px}.dancer-item__name{font-size:15px;width:100%}.dancer-item__remove{opacity:1;font-size:18px}#add-dancer-btn{width:100%!important;padding:12px!important;font-size:14px!important;margin-top:8px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
