*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f14;--surface: #1a1a24;--surface-hover: #22222e;--border: #2a2a3a;--text: #e4e4ef;--text-muted: #8888a0;--primary: #6c5ce7;--primary-hover: #7d6ff0;--danger: #e74c3c;--danger-hover: #ff6b5a;--success: #27ae60;--radius: 8px;--font: system-ui, -apple-system, sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;cursor:pointer;transition:background .15s}.btn:hover{background:var(--surface-hover)}.btn--primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-hover)}.btn--danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn--danger:hover{background:var(--danger-hover)}.btn--secondary{background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;text-decoration:underline;font:inherit}.input{padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;width:100%}.input:focus{outline:2px solid var(--primary);outline-offset:-1px}select.input{cursor:pointer}.layout{min-height:100vh;display:flex;flex-direction:row}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:100vh;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 12px;border-bottom:1px solid var(--border)}.sidebar__logo{font-size:16px;font-weight:700;color:var(--text)}.sidebar__close{display:none;background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px}.sidebar__nav{display:flex;flex-direction:column;padding:12px 8px;gap:2px}.sidebar__link{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius);color:var(--text-muted);font-size:14px;transition:background .15s,color .15s}.sidebar__link:hover{background:var(--surface-hover);color:var(--text)}.sidebar__footer{margin-top:auto;padding:12px 8px;border-top:1px solid var(--border)}.blur-toggle{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:13px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:background .15s;width:100%;background:none;border:none;font-family:inherit;text-align:left}.blur-toggle:hover{background:var(--surface-hover);color:var(--text)}.blur-toggle--active{color:var(--primary)}.sidebar__overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}.sidebar__overlay--visible{display:block}.layout__body{flex:1;display:flex;flex-direction:column;min-width:0}.header{display:none;align-items:center;gap:16px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.header__menu-btn{background:none;border:none;color:var(--text);font-size:22px;cursor:pointer;line-height:1;padding:0}.header__logo{font-size:16px;font-weight:700;color:var(--text)}.page-toolbar{display:flex;align-items:center;gap:12px;padding:10px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.page-toolbar__title{font-size:18px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main{flex:1;padding:24px;width:100%}@media(max-width:768px){.layout{flex-direction:column}.sidebar{position:fixed;top:0;left:-100%;height:100%;min-height:100%;z-index:100;transition:left .25s ease;width:240px}.sidebar--open{left:0}.sidebar__close{display:block}.header{display:flex}.main{padding:16px}.page-toolbar{padding:10px 16px}}.home h1{font-size:24px;margin-bottom:24px}.home__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.spine-list__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.spine-list__header h1{font-size:24px}.spine-list__search{margin-bottom:20px;max-width:400px}.spine-list__empty{color:var(--text-muted);padding:40px 0;text-align:center}.spine-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.spine-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,transform .15s;color:var(--text)}.spine-card:hover{border-color:var(--primary);transform:translateY(-2px)}.spine-card__preview{height:140px;display:flex;align-items:center;justify-content:center;background:var(--bg);font-size:40px;color:var(--text-muted);position:relative;overflow:hidden}.spine-card__preview .spine-preview{position:absolute;inset:0}.spine-card__preview .spine-preview__canvas-wrap{aspect-ratio:unset;height:100%}.spine-card__info{padding:12px}.spine-card__name{font-size:14px;font-weight:600;margin-bottom:4px}.spine-card__meta{font-size:12px;color:var(--text-muted)}.spine-upload{max-width:600px}.spine-upload h1{margin-bottom:24px;font-size:24px}.upload-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500}.form-actions{display:flex;gap:12px;justify-content:flex-end}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.drop-zone:hover,.drop-zone--active{border-color:var(--primary);background:#6c5ce70d}.drop-zone__text{color:var(--text-muted);font-size:14px}.drop-zone__file{display:none;font-size:13px;margin-top:8px;color:var(--primary);word-break:break-all}.spine-detail__header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.spine-detail__title{font-size:24px;flex:1}.spine-detail__actions{display:flex;gap:8px}.spine-detail__body{display:grid;grid-template-columns:1fr 380px;gap:24px}@media(max-width:768px){.spine-detail__body{grid-template-columns:1fr}}.spine-detail__info{display:flex;flex-direction:column;min-height:0;overflow:hidden}.spine-detail__info dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:14px}.spine-detail__info dt{color:var(--text-muted);font-weight:500}.spine-detail__info dd{word-break:break-word}.spine-preview{display:flex;flex-direction:column}.spine-preview__canvas-wrap{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:3 / 4}.spine-preview__canvas-wrap canvas{width:100%;height:100%;display:block}.spine-preview__error{padding:40px;text-align:center;color:var(--text-muted)}.spine-detail__section{margin-top:20px}.spine-detail__section h2{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--text-muted)}.spine-detail__anim-list{display:flex;flex-wrap:wrap;gap:6px}.spine-detail__anim-btn{padding:4px 10px;font-size:12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.spine-detail__anim-btn:hover{background:var(--surface-hover)}.spine-detail__anim-btn--active{background:var(--primary);border-color:var(--primary);color:#fff}.spine-detail__anim-track{font-size:10px;opacity:.7}.spine-detail__skin-list{display:flex;flex-direction:column;gap:4px}.spine-detail__skin-toggle{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;padding:3px 0}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius);font-size:14px;color:#fff;opacity:0;transform:translate(40px);transition:opacity .3s,transform .3s}.toast--visible{opacity:1;transform:translate(0)}.toast--success{background:var(--success)}.toast--error{background:var(--danger)}.toast--info{background:var(--primary)}.blur-mode canvas{image-rendering:pixelated;filter:hue-rotate(180deg) saturate(2)}.blur-mode .spine-card__preview{filter:blur(40px) brightness(.4) hue-rotate(180deg) saturate(.3)}.confirm-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999}.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;max-width:380px;width:90%;text-align:center}.confirm-box p{margin-bottom:20px;font-size:15px;line-height:1.5}.confirm-box__actions{display:flex;gap:10px;justify-content:center}.error{color:var(--danger)}.btn--sm{padding:4px 10px;font-size:12px}.expressions-section{margin-top:24px}.expressions-section h2{font-size:18px;margin-bottom:12px}.expr-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:20px}.expr-table th{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text-muted);font-weight:500}.expr-table td{padding:8px 10px;border-bottom:1px solid var(--border)}.expr-table tr:hover td{background:var(--surface-hover)}.expr-table__actions{display:flex;gap:6px}.expr-add-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.expr-add-form h3{font-size:15px;margin-bottom:12px}.expr-add-form__fields{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.expr-add-form__fields .input{flex:1;min-width:120px}.expr-add-form__fields .btn{flex-shrink:0}.outfits-section{margin-top:24px}.outfits-section h2{font-size:18px;margin-bottom:12px}.outfit-add-form__fields{display:flex;flex-direction:column;gap:10px}.outfit-add-form__fields .input{max-width:300px}.outfit-skin-checkboxes{display:flex;flex-wrap:wrap;gap:8px}.outfit-skin-checkbox{display:flex;align-items:center;gap:4px;font-size:13px;cursor:pointer;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .15s}.outfit-skin-checkbox:hover{border-color:var(--primary)}.outfit-skin-checkbox input[type=checkbox]{cursor:pointer}.outfit-skin-group{width:100%;font-size:12px;color:var(--text-muted);margin-top:4px}.edit-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:12px;gap:0;flex-shrink:0}.edit-tab{flex:1;padding:8px 4px;font-size:13px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s;text-align:center}.edit-tab:hover{color:var(--text)}.edit-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.edit-tab-content{flex:1;overflow-y:auto;min-height:0}.outfit-edit-inline{padding:12px;display:flex;flex-direction:column;gap:10px;border:1px solid var(--border);border-radius:var(--radius);margin:4px 0;background:var(--surface)}.outfit-edit-inline__actions{display:flex;gap:8px;justify-content:flex-end}.spine-tabs{display:flex;align-items:center;gap:4px;margin-bottom:12px;flex-wrap:wrap}.spine-tab{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.spine-tab--active{border-color:var(--primary)}.spine-tab__btn{padding:6px 12px;font-size:13px;font-weight:500;background:var(--surface);border:none;color:var(--text);cursor:pointer;transition:background .15s}.spine-tab__btn:hover{background:var(--surface-hover)}.spine-tab--active .spine-tab__btn{background:var(--primary);color:#fff}.spine-tab__remove{padding:4px 6px;border-radius:0;border:none;border-left:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:11px;line-height:1;cursor:pointer;transition:color .15s}.spine-tab__remove:hover{color:var(--danger)}.spine-tab--add{border-style:dashed}.spine-add-select{padding:5px 8px;font-size:13px;color:var(--text-muted);border:none;background:transparent;cursor:pointer}.spine-add-select:focus{outline:none}.scene-editor__meta{max-width:600px;margin-bottom:20px}.step-card{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;background:var(--surface);transition:box-shadow .15s}.step-card[draggable=true]{cursor:grab}.step-card--dragging{opacity:.5}.step-card:hover{box-shadow:0 0 0 1px var(--border)}.step-card__header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff05;border-bottom:1px solid var(--border)}.step-card__type{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.step-card__actions{margin-left:auto;display:flex;gap:4px}.step-card__body{padding:10px 12px}.step-fields{display:flex;flex-direction:column;gap:6px}.step-fields textarea{resize:vertical;min-height:40px}.choice-option .step-card{margin-bottom:6px}.choice-option .step-card__header{padding:6px 10px}.step-card--active{outline:2px solid var(--primary);outline-offset:-1px;box-shadow:0 0 12px #6c5ce74d}.scene-editor__layout{display:flex;gap:24px}.scene-editor__main{flex:1;min-width:0;order:1}.scene-editor__test-panel{flex:1;min-width:0;order:2;position:sticky;top:24px;align-self:flex-start;max-height:calc(100vh - 48px);display:flex;flex-direction:column}.test-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 48px)}.test-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.test-panel__header h3{font-size:15px;font-weight:600}.test-vn{position:relative;aspect-ratio:16 / 9;background:#1a1a2e;border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden}.test-vn__stage{position:absolute;inset:0}.test-vn__stage canvas{display:block;width:100%;height:100%;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.test-vn__overlay{position:absolute;inset:0;display:flex;align-items:flex-end;pointer-events:none}.test-vn__overlay>*{pointer-events:auto}.test-dialog{padding:16px 20px;width:100%}.test-dialog__speaker{font-weight:700;color:#f0c040;margin-bottom:6px;font-size:14px}.test-dialog__text{color:#e4e4ef;font-size:14px;line-height:1.5}.test-dialog__nav{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.test-dialog__nav-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);color:#e4e4ef;font-size:18px;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;touch-action:manipulation}.test-dialog__nav-btn:hover:not(:disabled){background:#ffffff29}.test-dialog__nav-btn:disabled{opacity:.3;cursor:default}.test-choice{padding:16px 20px;width:100%}.test-choice__prompt{color:#e4e4ef;font-size:14px;margin-bottom:10px;text-align:center}.test-choice__options{display:flex;flex-direction:column;gap:6px}.test-choice__btn{padding:10px 16px;background:#6c5ce733;border:1px solid rgba(108,92,231,.4);border-radius:var(--radius);color:#e4e4ef;font-size:13px;cursor:pointer;transition:background .15s;font-family:inherit;text-align:left}.test-choice__btn:hover{background:#6c5ce766}.test-vn__ended{text-align:center;color:var(--text-muted);padding:20px}.test-vn__ended p{margin-bottom:12px}.test-panel__info{overflow-y:auto;padding:12px 16px;flex:1;min-height:0}.test-info__section{margin-bottom:14px}.test-info__section h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.test-info__step{display:flex;align-items:center;gap:8px}.test-info__badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase}.test-info__idx{font-size:12px;color:var(--text-muted);font-weight:500}.test-info__detail{font-size:12px;color:var(--text)}.test-info__ended{color:var(--text-muted);font-style:italic}.test-info__char{display:flex;align-items:center;gap:8px;font-size:13px;padding:2px 0}.test-info__pos{font-size:11px;color:var(--text-muted);background:var(--bg);padding:1px 6px;border-radius:3px}.test-info__vars{display:flex;flex-direction:column;gap:2px}.test-info__var{display:flex;justify-content:space-between;font-size:13px;padding:2px 0}.test-info__var code{font-size:12px;color:var(--primary)}.test-info__val{color:var(--text);font-weight:500}.test-info__history{max-height:140px;overflow-y:auto}.test-info__hist-entry{font-size:12px;color:var(--text-muted);padding:2px 0;border-bottom:1px solid var(--border)}.test-info__hist-entry strong{color:var(--text)}.transform-gizmo{position:absolute;pointer-events:none;z-index:10;-webkit-user-select:none;user-select:none}.transform-gizmo__box{position:absolute;inset:0;border:2px dashed rgba(108,92,231,.8);cursor:move;pointer-events:auto}.transform-gizmo__handle{position:absolute;width:12px;height:12px;background:var(--primary);border:2px solid #fff;border-radius:2px;pointer-events:auto;transform:translate(-50%,-50%)}.transform-gizmo__handle--tl{top:0;left:0;cursor:nwse-resize}.transform-gizmo__handle--tr{top:0;right:0;cursor:nesw-resize;transform:translate(50%,-50%)}.transform-gizmo__handle--bl{bottom:0;left:0;cursor:nesw-resize;transform:translate(-50%,50%)}.transform-gizmo__handle--br{bottom:0;right:0;cursor:nwse-resize;transform:translate(50%,50%)}.step-transform-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 6px;border-radius:3px;background:#6c5ce733;color:var(--primary);margin-left:6px}.step-transform-reset{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:11px;padding:0 2px}.step-transform-reset:hover{color:var(--danger)}@media(max-width:768px){.scene-editor__layout{flex-direction:column;gap:0}.scene-editor__test-panel{width:100%;position:static;max-height:400px;order:0}.scene-editor__main{order:1}}
