.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:400px;display:flex;flex-direction:column;gap:1.5rem}.login-logo{text-align:center}.login-logo-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.login-logo h1{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.login-tagline{color:var(--text-secondary);font-size:.85rem;margin-top:.25rem}.login-tabs{display:flex;background:var(--surface-raised);border-radius:8px;padding:3px;gap:3px}.login-tabs button{flex:1;padding:.5rem;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;font-size:.9rem;font-weight:500;transition:all .15s ease}.login-tabs button.active{background:var(--accent);color:#fff}.login-tabs button:not(.active):hover{color:var(--text-primary);background:var(--border)}.login-section{display:flex;flex-direction:column;gap:.75rem}.login-hint{color:var(--text-secondary);font-size:.88rem;text-align:center}.login-label{font-size:.88rem;color:var(--text-secondary);font-weight:500}.login-input{width:100%;padding:.65rem .875rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.95rem;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--text-secondary)}.btn-passkey{width:100%;padding:.75rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;transition:background .15s ease}.btn-passkey:hover:not(:disabled){background:var(--accent-hover)}.btn-passkey:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--error);font-size:.88rem;text-align:center;padding:.5rem;background:color-mix(in srgb,var(--error) 10%,transparent);border-radius:6px}.login-footer{color:var(--text-secondary);font-size:.78rem;text-align:center;line-height:1.5}.dev-login-section{display:flex;flex-direction:column;gap:.75rem}.dev-login-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.dev-login-divider:before,.dev-login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.btn-dev-login{width:100%;padding:.65rem 1rem;background:transparent;color:var(--text-secondary);border:1px dashed var(--border);border-radius:8px;font-size:.88rem;font-weight:500;transition:all .15s ease}.btn-dev-login:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-dev-login:disabled{opacity:.6;cursor:not-allowed}.dashboard{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:60px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.dashboard-brand{display:flex;align-items:center;gap:.5rem}.brand-icon{font-size:1.4rem}.brand-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.dashboard-user{display:flex;align-items:center;gap:1rem}.user-name{color:var(--text-secondary);font-size:.88rem}.dashboard-main{flex:1;padding:2rem;max-width:1100px;width:100%;margin:0 auto}.dashboard-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dashboard-title-row h2{font-size:1.4rem;font-weight:600;color:var(--text-primary)}.dashboard-empty{text-align:center;color:var(--text-secondary);padding:3rem}.dashboard-error{color:var(--error);margin-bottom:1rem;font-size:.88rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;color:var(--text-primary);text-decoration:none;transition:border-color .15s,transform .1s;cursor:pointer}.project-card:hover{border-color:var(--accent);transform:translateY(-1px);color:var(--text-primary)}.project-card-header{margin-bottom:.5rem}.project-card-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.project-card-desc{color:var(--text-secondary);font-size:.85rem;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.project-card-date{color:var(--text-secondary);font-size:.78rem}.project-card-actions{display:flex;gap:.35rem;opacity:0;transition:opacity .15s}.project-card:hover .project-card-actions{opacity:1}.project-card-error{color:var(--error);font-size:.8rem;margin:.25rem 0}.btn-action-sm{padding:.2rem .5rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:5px;font-size:.75rem;cursor:pointer;transition:color .12s,border-color .12s}.btn-action-sm:hover{color:var(--text-primary);border-color:var(--text-secondary)}.btn-action-danger:hover{color:var(--error);border-color:var(--error)}.btn-confirm-delete{padding:.2rem .5rem;background:var(--error);color:#fff;border:none;border-radius:5px;font-size:.75rem;font-weight:600;cursor:pointer}.btn-cancel-sm{padding:.2rem .5rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:5px;font-size:.75rem;cursor:pointer}.btn-save-sm{padding:.2rem .5rem;background:var(--accent);color:#fff;border:none;border-radius:5px;font-size:.75rem;font-weight:600;cursor:pointer}.btn-save-sm:disabled{opacity:.5;cursor:not-allowed}.project-rename-input{width:100%;padding:.4rem .6rem;background:var(--surface-raised);border:1px solid var(--accent);border-radius:6px;color:var(--text-primary);font-size:1rem;font-weight:600;outline:none}.project-rename-actions{display:flex;gap:.35rem;justify-content:flex-end;margin-top:.4rem}.create-project-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem;max-width:480px}.create-project-form h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.form-input{width:100%;padding:.6rem .875rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s;resize:vertical}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-secondary)}.form-error{color:var(--error);font-size:.85rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-ghost{padding:.4rem .75rem;background:transparent;color:var(--text-secondary);border:none;font-size:.85rem;border-radius:6px;transition:color .15s,background .15s}.btn-ghost:hover{color:var(--text-primary);background:var(--surface-raised)}.fse-backdrop{position:fixed;inset:0;z-index:100;background:var(--bg);display:flex;flex-direction:column}.fse-container{display:flex;flex-direction:column;height:100vh;width:100%;overflow:hidden}.fse-header{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;min-height:48px}.fse-back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s;flex-shrink:0}.fse-back:hover{color:var(--text-primary);border-color:var(--text-secondary)}.fse-title{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.fse-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.fse-body{flex:1;overflow:hidden;display:flex}.fse-body>*{flex:1;min-width:0}.tab-nav{display:flex;gap:2px;border-bottom:1px solid var(--border);padding:0 .25rem;flex-shrink:0}.tab-nav-btn{padding:.5rem .875rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.tab-nav-btn:hover{color:var(--text-primary)}.tab-nav-btn--active{color:var(--accent);border-bottom-color:var(--accent)}.ae-layout{display:grid;grid-template-columns:1fr 1fr;height:100%;overflow:hidden}.ae-preview-col{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;overflow-y:auto;border-right:1px solid var(--border);background:var(--bg)}.ae-preview-frame{border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--surface);flex-shrink:0}.ae-preview-img{width:100%;display:block;max-height:50vh;object-fit:contain}.ae-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 2rem;color:var(--text-secondary);font-size:.85rem;opacity:.5}.ae-preview-meta{display:flex;align-items:center;gap:.5rem}.ae-meta-type{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:.15rem .5rem;border-radius:4px}.ae-meta-name{font-size:.88rem;color:var(--text-secondary)}.ae-panel-col{display:flex;flex-direction:column;overflow:hidden;background:var(--surface)}.ae-tab-content{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.ae-tab-body{display:flex;flex-direction:column;gap:1rem}.ae-placeholder{color:var(--text-secondary);font-size:.88rem;font-style:italic;padding:2rem 0;text-align:center}.field-label{font-size:.82rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.field-label-hint{font-size:.75rem;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-secondary);opacity:.7}.field-input{width:100%;padding:.6rem .875rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s;resize:vertical}select.field-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238888a0' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.ae-style-picker{display:flex;flex-wrap:wrap;gap:.4rem}.ae-style-chip{display:flex;align-items:center;gap:.4rem;padding:.3rem .6rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:20px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.ae-style-chip:hover:not(:disabled){border-color:var(--accent);color:var(--text-primary)}.ae-style-chip.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent)}.ae-style-chip:disabled{opacity:.5;cursor:not-allowed}.ae-style-chip-thumb{width:18px;height:18px;border-radius:50%;object-fit:cover;flex-shrink:0}.ae-btn-generate{padding:.65rem 1.25rem;background:var(--surface-raised);color:var(--text-secondary);border:1px dashed var(--border);border-radius:8px;font-size:.88rem;font-weight:500;transition:color .15s,border-color .15s;align-self:flex-start;cursor:pointer}.ae-btn-generate:not(:disabled):hover{color:var(--text-primary);border-color:var(--accent)}.ae-btn-generate:disabled{opacity:.5;cursor:not-allowed}.ae-gallery-loading,.ae-gallery-empty{color:var(--text-secondary);font-size:.85rem;text-align:center;padding:2rem 0;font-style:italic}.ae-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.ae-gallery-item{border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--surface-raised);display:flex;flex-direction:column}.ae-gallery-img{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block}.ae-gallery-flags{display:flex;gap:2px;padding:4px}.ae-flag-btn{flex:1;padding:.2rem 0;font-size:.68rem;font-weight:600;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:background .12s,color .12s,border-color .12s;text-transform:uppercase;letter-spacing:.03em}.ae-flag-btn:hover{border-color:var(--accent);color:var(--accent)}.ae-flag-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ae-generate-actions{display:flex;flex-direction:column;gap:.75rem}.ae-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.78rem;opacity:.6}.ae-divider:before,.ae-divider:after{content:"";flex:1;height:1px;background:var(--border)}.ae-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:1.25rem 1rem;border:1.5px dashed var(--border);border-radius:10px;background:var(--surface-raised);color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.ae-dropzone:hover:not(.uploading){border-color:var(--accent);color:var(--text-primary)}.ae-dropzone.drag-over{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent)}.ae-dropzone.uploading{cursor:wait;opacity:.7}.ae-dropzone-text{font-size:.85rem;font-weight:500}.ae-dropzone-hint{font-size:.72rem;opacity:.6}.ae-btn-generate.generating{animation:pulse-border 1.2s ease-in-out infinite;color:var(--accent)}.ae-dropzone.uploading{animation:pulse-border 1.2s ease-in-out infinite}@media(max-width:768px){.ae-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.ae-preview-col{border-right:none;border-bottom:1px solid var(--border);max-height:40vh}}.search-filter-bar{display:flex;flex-direction:column;gap:.5rem}.search-filter-row{display:flex;gap:.4rem;align-items:center}.search-input-wrap{position:relative;flex:1;min-width:0}.search-icon{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);font-size:.8rem;pointer-events:none;opacity:.5}.search-input{width:100%;padding:.45rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color .15s}.search-input::placeholder{color:var(--text-secondary);opacity:.6}.search-input:focus{border-color:var(--accent)}.search-clear-btn{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:0 .3rem;line-height:1}.search-clear-btn:hover{color:var(--text-primary)}.filter-btn-wrap{position:relative}.filter-btn{padding:.45rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:.35rem;transition:border-color .15s,color .15s}.filter-btn:hover{border-color:var(--accent);color:var(--text-primary)}.filter-btn--active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.filter-btn-count{background:var(--accent);color:#fff;font-size:.68rem;font-weight:700;padding:.08rem .35rem;border-radius:10px;min-width:1.1rem;text-align:center}.filter-dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:500;background:var(--surface-raised);border:1px solid var(--border);border-radius:10px;padding:.35rem;min-width:170px;box-shadow:0 8px 32px #00000059;animation:sfb-fade-in .1s ease-out}@keyframes sfb-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.filter-dropdown-header{padding:.3rem .6rem .4rem;font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.filter-dropdown-item{display:flex;align-items:center;gap:.4rem;width:100%;padding:.45rem .6rem;background:none;border:none;border-radius:6px;color:var(--text-primary);font-size:.83rem;cursor:pointer;transition:background .1s;text-align:left}.filter-dropdown-item:hover{background:color-mix(in srgb,var(--accent) 12%,transparent)}.filter-dropdown-item--active{background:color-mix(in srgb,var(--accent) 8%,transparent)}.filter-dropdown-check{width:1rem;text-align:center;font-size:.75rem;color:var(--accent);flex-shrink:0}.filter-dropdown-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-dropdown-count{margin-left:auto;font-size:.72rem;color:var(--text-secondary)}.search-filter-status{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:1.6rem}.filter-chips{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}.filter-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:12px;font-size:.75rem;color:var(--text-primary);white-space:nowrap}.filter-chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.filter-chip-remove{background:none;border:none;color:var(--text-secondary);font-size:.85rem;cursor:pointer;padding:0 .1rem;line-height:1;margin-left:.1rem}.filter-chip-remove:hover{color:var(--text-primary)}.filter-clear-all{background:none;border:none;color:var(--text-secondary);font-size:.75rem;cursor:pointer;padding:.15rem .3rem;border-radius:4px}.filter-clear-all:hover{color:var(--accent)}.filter-result-count{font-size:.78rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.asset-list{display:flex;flex-direction:column;gap:1.25rem}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}.asset-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:border-color .15s,transform .1s;outline:none}.asset-card:hover{border-color:var(--accent);transform:translateY(-1px)}.asset-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) 44}.asset-card-thumb{width:100%;aspect-ratio:1 / 1;overflow:hidden;background:var(--surface-raised)}.asset-thumb{width:100%;height:100%;object-fit:cover;display:block}.asset-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--border)}.asset-card-body{padding:.625rem .75rem .75rem;display:flex;flex-direction:column;gap:.3rem}.asset-card-top{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.asset-name{font-size:.875rem;font-weight:600;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-type-badge{font-size:.68rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;white-space:nowrap;flex-shrink:0;text-transform:capitalize}.asset-prompt{color:var(--text-secondary);font-size:.78rem;line-height:1.4}.fe-layout{display:grid;grid-template-columns:1fr 320px;height:100%;overflow:hidden}.fe-visual-col{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;overflow-y:auto;border-right:1px solid var(--border);background:var(--bg)}.fe-frame-pair{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:start}.fe-frame-slot{display:flex;flex-direction:column;gap:.4rem}.fe-frame-slot--selectable{background:none;padding:.4rem;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:border-color .15s}.fe-frame-slot--selectable:hover{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.fe-frame-slot--selected{border-color:var(--accent)}.fe-slot-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.fe-frame-slot--selected .fe-slot-label{color:var(--accent)}.fe-slot-preview-wrap{border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--surface)}.fe-slot-img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.fe-slot-empty{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--text-secondary);opacity:.5;border:1px dashed var(--border);border-radius:8px;background:var(--surface-raised)}.fe-frame-swap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding-top:1.4rem}.fe-btn-swap{padding:.35rem .5rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;font-size:1.1rem;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s;line-height:1}.fe-btn-swap:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.fe-btn-swap:disabled{opacity:.3;cursor:not-allowed}.fe-btn-copy{padding:.2rem .5rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:5px;font-size:.72rem;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.fe-btn-copy:hover:not(:disabled){color:var(--accent);border-color:var(--accent)}.fe-btn-copy:disabled{opacity:.35;cursor:not-allowed}.fe-animate-row{display:flex;gap:.5rem}.fe-video-preview{border-radius:8px;overflow:hidden;background:var(--surface);border:1px solid var(--border)}.fe-video-player{width:100%;display:block;max-height:280px}.fe-panel-col{display:flex;flex-direction:column;overflow:hidden;background:var(--surface)}.fe-panel-scroll{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.25rem}.fe-section{display:flex;flex-direction:column;gap:.6rem}.fe-section--revision{margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}.fe-section-label{font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;opacity:.7}.field{display:flex;flex-direction:column;gap:.35rem}.field-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.field-label-hint{font-size:.72rem;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-secondary);opacity:.7}.field-hint{color:var(--text-secondary);font-size:.82rem;font-style:italic}.field-input{width:100%;padding:.5rem .7rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.85rem;outline:none;transition:border-color .15s;resize:vertical}.field-input:focus{border-color:var(--accent)}.field-input::placeholder{color:var(--text-secondary)}.fe-asset-grid{display:flex;flex-direction:column;gap:.25rem;max-height:140px;overflow-y:auto;padding:.4rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px}.fe-asset-check{display:flex;align-items:center;gap:.4rem;cursor:pointer;padding:.25rem .2rem;border-radius:4px;transition:background .1s}.fe-asset-check:hover{background:var(--border)}.fe-asset-check input[type=checkbox]{accent-color:var(--accent);width:13px;height:13px}.fe-asset-name{font-size:.82rem;color:var(--text-primary);flex:1}.fe-asset-type{font-size:.7rem;color:var(--text-secondary);text-transform:capitalize}.fe-btn-create,.fe-btn-revise,.fe-btn-animate{padding:.55rem 1rem;background:var(--surface-raised);color:var(--text-secondary);border:1px dashed var(--border);border-radius:6px;font-size:.82rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s;align-self:stretch;text-align:center}.fe-btn-revise{border-style:solid}.fe-btn-create:not(:disabled):hover,.fe-btn-revise:not(:disabled):hover,.fe-btn-animate:not(:disabled):hover{color:var(--text-primary);border-color:var(--accent)}.fe-btn-create:disabled,.fe-btn-revise:disabled,.fe-btn-animate:disabled{opacity:.5;cursor:not-allowed}@keyframes pulse-border{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.fe-btn-create.generating,.fe-btn-revise.generating,.fe-btn-animate.generating{animation:pulse-border 1.2s ease-in-out infinite;color:var(--accent)}.fe-history{display:flex;flex-direction:column;gap:.35rem;margin-top:.25rem}.fe-history-label{font-size:.72rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;opacity:.7}.fe-history-scroll{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:2px}.fe-history-thumb{flex-shrink:0;width:52px;height:36px;border-radius:4px;overflow:hidden;border:1px solid var(--border);background:var(--surface-raised);padding:0;cursor:pointer;opacity:.65;transition:opacity .15s,border-color .15s}.fe-history-thumb img{width:100%;height:100%;object-fit:cover;display:block}.fe-history-thumb:hover{opacity:1;border-color:var(--accent)}.fe-history-thumb--current{opacity:1;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent);cursor:default}.fe-video-history{margin-top:.5rem}.fe-video-thumb{flex-shrink:0;width:84px;height:48px;border-radius:5px;overflow:hidden;border:1px solid var(--border);background:var(--surface-raised);padding:0;cursor:pointer;opacity:.65;transition:opacity .15s,border-color .15s}.fe-video-thumb video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.fe-video-thumb:hover{opacity:1;border-color:var(--accent)}.fe-video-thumb--current{opacity:1;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent);cursor:default}.editor-error{color:var(--error);font-size:.82rem}@keyframes banner-enter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.editor-mode-banner{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--success, #4caf82);background:color-mix(in srgb,var(--success, #4caf82) 8%,transparent);border:1px solid color-mix(in srgb,var(--success, #4caf82) 25%,transparent);border-radius:8px;padding:.5rem .75rem;animation:banner-enter .25s ease-out}.editor-mode-banner .banner-icon{font-size:1rem;font-weight:700;flex-shrink:0}.editor-mode-banner .banner-text{font-weight:500}.btn-primary{padding:.55rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-secondary{padding:.55rem 1rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.88rem;font-weight:500;cursor:pointer;transition:color .15s}.btn-new-frame{padding:.55rem 1rem;background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:8px;font-size:.88rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.btn-new-frame:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 10%,transparent)}.btn-new-frame:disabled{opacity:.5;cursor:not-allowed}.btn-danger{padding:.45rem .875rem;background:var(--error, #e05252);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer}.btn-danger-outline{padding:.45rem .875rem;background:transparent;color:var(--error, #e05252);border:1px solid var(--error, #e05252);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-danger-outline:hover:not(:disabled){background:color-mix(in srgb,var(--error, #e05252) 12%,transparent)}@media(max-width:768px){.fe-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.fe-visual-col{border-right:none;border-bottom:1px solid var(--border);max-height:45vh}}.frame-timeline{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.tl-controls{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border);background:var(--surface-raised);gap:1rem;flex-wrap:wrap}.tl-controls-left,.tl-controls-right{display:flex;align-items:center;gap:.75rem}.tl-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:border-color .15s,background .15s}.tl-btn:hover:not(:disabled){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.tl-btn:disabled{opacity:.35;cursor:not-allowed}.tl-play-btn{width:2rem;height:2rem;font-size:.8rem;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.tl-time{font-size:.78rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:5rem}.tl-frame-indicator{font-size:.78rem;color:var(--text-secondary);white-space:nowrap}.tl-fps-label{font-size:.78rem;color:var(--text-secondary)}.tl-fps-select{background:var(--surface);border:1px solid var(--border);border-radius:5px;color:var(--text-primary);font-size:.78rem;padding:.2rem .4rem;cursor:pointer}.tl-zoom{display:flex;align-items:center;gap:.35rem}.tl-zoom-btn{width:1.5rem;height:1.5rem;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0}.tl-zoom-value{font-size:.72rem;color:var(--text-secondary);min-width:2.5rem;text-align:center;font-variant-numeric:tabular-nums}.tl-strip-wrapper{overflow:hidden;position:relative}.tl-strip{display:flex;gap:2px;padding:.75rem .5rem;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.tl-strip::-webkit-scrollbar{height:6px}.tl-strip::-webkit-scrollbar-track{background:transparent}.tl-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.tl-frame{flex-shrink:0;position:relative;cursor:pointer;border:2px solid transparent;border-radius:6px;overflow:hidden;transition:border-color .15s,transform .15s,opacity .15s;background:var(--surface-raised);outline:none}.tl-frame:hover{border-color:color-mix(in srgb,var(--accent) 50%,transparent)}.tl-frame--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 2px 8px #0000004d}.tl-frame--selected{border-color:var(--accent)}.tl-frame--dragging{opacity:.4;transform:scale(.92)}.tl-frame--drag-over{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 50%,transparent)}.tl-frame-number{position:absolute;top:.3rem;left:.3rem;background:#000000bf;color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;z-index:2}.tl-frame-thumb{width:100%;aspect-ratio:16 / 9;overflow:hidden;position:relative}.tl-frame-thumb img{width:100%;height:100%;object-fit:cover;display:block}.tl-frame-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface)}.tl-placeholder-icon{font-size:1.5rem;opacity:.15}.tl-video-badge{position:absolute;bottom:.25rem;right:.25rem;background:#000000b3;color:#fff;font-size:.55rem;width:1.1rem;height:1.1rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.tl-frame-timing{font-size:.65rem;color:var(--text-secondary);text-align:center;padding:.2rem 0;background:var(--surface);border-top:1px solid var(--border)}.tl-frame-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);z-index:3;pointer-events:none;box-shadow:0 0 4px var(--accent)}.tl-scrubber{position:relative;height:28px;cursor:pointer;border-top:1px solid var(--border);background:var(--surface-raised);-webkit-user-select:none;user-select:none}.tl-scrubber-track{position:absolute;inset:6px 8px;border-radius:3px;overflow:hidden;background:var(--surface)}.tl-scrubber-segment{position:absolute;top:0;bottom:0;border-right:1px solid var(--border);transition:background .15s}.tl-scrubber-segment--active{background:color-mix(in srgb,var(--accent) 20%,transparent)}.tl-scrubber-head{position:absolute;top:-2px;bottom:-2px;width:3px;background:var(--accent);border-radius:2px;transform:translate(-50%);z-index:1;box-shadow:0 0 6px color-mix(in srgb,var(--accent) 60%,transparent);transition:left .05s linear}@media(max-width:700px){.tl-controls{padding:.4rem .5rem;gap:.5rem}.tl-frame-indicator{display:none}.tl-strip{padding:.5rem .35rem}}.shortcuts-backdrop{position:fixed;inset:0;z-index:2000;background:#0009;display:flex;align-items:center;justify-content:center;animation:shortcuts-fade-in .15s ease-out}@keyframes shortcuts-fade-in{0%{opacity:0}to{opacity:1}}.shortcuts-panel{background:var(--surface-raised);border:1px solid var(--border);border-radius:14px;width:420px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px #00000080;animation:shortcuts-slide-up .15s ease-out}@keyframes shortcuts-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.shortcuts-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.shortcuts-close{background:none;border:none;color:var(--text-secondary);padding:.25rem;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s}.shortcuts-close:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 15%,transparent)}.shortcuts-body{padding:.75rem 1.25rem 1.25rem}.shortcuts-section{margin-bottom:1rem}.shortcuts-section:last-child{margin-bottom:0}.shortcuts-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:.5rem}.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem 0}.shortcut-keys{display:flex;gap:.3rem}.shortcut-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.6rem;padding:.15rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:5px;font-family:inherit;font-size:.75rem;font-weight:600;color:var(--text-primary);line-height:1.4}.shortcut-desc{font-size:.82rem;color:var(--text-secondary)}.undo-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface-raised);border:1px solid var(--accent);border-radius:10px;padding:.6rem .5rem .6rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 8px 32px #0006;z-index:300;animation:undo-toast-in .2s ease-out;overflow:hidden;min-width:240px}@keyframes undo-toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.undo-toast-msg{font-size:.84rem;color:var(--text-primary);white-space:nowrap}.undo-toast-btn{padding:.3rem .65rem;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;flex-shrink:0}.undo-toast-btn:hover{background:var(--accent-hover)}.undo-toast-dismiss{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:0 .2rem;line-height:1;flex-shrink:0}.undo-toast-dismiss:hover{color:var(--text-primary)}.undo-toast-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--accent);transition:width .1s linear;border-radius:0 0 10px 10px}.sbm-backdrop{position:fixed;inset:0;z-index:110;background:#00000080;display:flex;align-items:center;justify-content:center;animation:sbm-fade-in .15s ease-out}@keyframes sbm-fade-in{0%{opacity:0}to{opacity:1}}.sbm-dialog{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:480px;max-width:90vw;box-shadow:0 8px 32px #0000004d;animation:sbm-slide-up .2s ease-out}@keyframes sbm-slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.sbm-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.sbm-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.sbm-close{background:none;border:none;font-size:1.4rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.sbm-close:hover{color:var(--text-primary)}.sbm-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.sbm-hint{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.4}.sbm-input{width:100%;padding:.65rem .875rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;outline:none;resize:vertical;transition:border-color .15s}.sbm-input:focus{border-color:var(--accent)}.sbm-input::placeholder{color:var(--text-secondary)}.sbm-error{color:var(--error);font-size:.85rem;margin:0}.sbm-actions{display:flex;justify-content:flex-end;gap:.5rem}.sbm-btn-cancel{padding:.5rem 1rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.88rem;cursor:pointer;transition:color .15s}.sbm-btn-cancel:hover:not(:disabled){color:var(--text-primary)}.sbm-btn-submit{padding:.5rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s}.sbm-btn-submit:hover:not(:disabled){background:var(--accent-hover)}.sbm-btn-submit:disabled{opacity:.6;cursor:not-allowed}.sbm-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer}.sbm-checkbox input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}.sbm-progress{align-items:center;justify-content:center;padding:2.5rem 1.25rem;text-align:center}@keyframes sbm-spin{to{transform:rotate(360deg)}}.sbm-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sbm-spin .8s linear infinite}.sbm-status{font-size:.88rem;color:var(--text-primary);margin:0;font-weight:500}.sbm-render-progress{font-size:.82rem;color:var(--text-secondary);margin:0}.storyboard{display:flex;flex-direction:column;gap:1.25rem}.storyboard-header{display:flex;align-items:center;justify-content:space-between}.storyboard-count{font-size:.85rem;color:var(--text-secondary)}.storyboard-loading,.storyboard-empty{color:var(--text-secondary);text-align:center;padding:2rem;font-size:.9rem}.storyboard-error{color:var(--error);font-size:.88rem}.frame-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.frame-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative;display:flex;flex-direction:column;outline:none}.frame-card:active{cursor:grabbing}.frame-card--dragging{opacity:.4;transform:scale(.95);border-color:var(--accent)}.frame-card--drag-over{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 50%,transparent);transform:translateY(-3px)}.frame-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.frame-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}.frame-number{position:absolute;top:.6rem;left:.6rem;background:#000000b3;color:#fff;font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;z-index:1}.frame-image{width:100%;height:180px;object-fit:cover;display:block}.frame-image-placeholder{width:100%;height:180px;background:var(--surface-raised);display:flex;align-items:center;justify-content:center}.frame-placeholder-icon{font-size:2.5rem;opacity:.2}.frame-prompt{padding:.75rem .875rem .875rem;font-size:.82rem;color:var(--text-secondary);line-height:1.45;flex:1}.storyboard-header-actions{display:flex;gap:.5rem;align-items:center}.btn-export{padding:.5rem .875rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.85rem;font-weight:500;transition:color .15s,border-color .15s}.btn-export:hover:not(:disabled){color:var(--text-primary);border-color:var(--accent)}.btn-export:disabled{opacity:.5;cursor:not-allowed}.btn-breakdown{padding:.5rem .875rem;background:var(--surface-raised);color:var(--accent);border:1px solid var(--accent);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-breakdown:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.frame-card{position:relative}.frame-image--static{display:block}.frame-card-video{position:absolute;top:0;left:0;width:100%;height:180px;object-fit:cover;opacity:0;transition:opacity .2s}.frame-card:hover .frame-card-video{opacity:1}.frame-card:hover .frame-image--static{opacity:0}.frame-card--selected{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}.frame-context-menu{position:fixed;z-index:1000;background:var(--surface-raised);border:1px solid var(--border);border-radius:10px;padding:.35rem;min-width:180px;box-shadow:0 8px 32px #0006;animation:context-fade-in .1s ease-out}@keyframes context-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.frame-context-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:none;border:none;border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:background .1s}.frame-context-item:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 15%,transparent)}.frame-context-item:disabled{color:var(--text-secondary);opacity:.4;cursor:not-allowed}.frame-context-shortcut{font-size:.75rem;color:var(--text-secondary);margin-left:1.5rem}.frame-context-item--danger{color:var(--error)}.frame-context-item--danger:hover:not(:disabled){background:color-mix(in srgb,var(--error) 12%,transparent)}.frame-context-separator{height:1px;background:var(--border);margin:.25rem .5rem}.clipboard-indicator{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--surface-raised);border:1px solid var(--accent);border-radius:8px;padding:.5rem .75rem;font-size:.82rem;color:var(--text-primary);display:flex;align-items:center;gap:.75rem;box-shadow:0 4px 16px #0000004d;z-index:100;animation:context-fade-in .15s ease-out}.clipboard-clear{background:none;border:none;color:var(--text-secondary);font-size:.78rem;cursor:pointer;padding:.15rem .4rem;border-radius:4px}.clipboard-clear:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 15%,transparent)}.view-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.view-toggle-btn{padding:.4rem .7rem;background:none;border:none;color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.view-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.view-toggle-btn:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.view-toggle-btn--active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);font-weight:600}.frame-card--delete-confirm{border-color:var(--error);box-shadow:0 0 0 2px color-mix(in srgb,var(--error) 40%,transparent);animation:delete-pulse .6s ease-in-out infinite alternate}@keyframes delete-pulse{0%{box-shadow:0 0 0 2px color-mix(in srgb,var(--error) 40%,transparent)}to{box-shadow:0 0 0 3px color-mix(in srgb,var(--error) 60%,transparent)}}.action-flash{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;padding:.5rem 1rem;font-size:.82rem;color:var(--text-primary);box-shadow:0 4px 16px #0000004d;z-index:200;animation:flash-in .15s ease-out,flash-out .3s ease-in .9s forwards;pointer-events:none}@keyframes flash-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes flash-out{0%{opacity:1}to{opacity:0}}.shortcuts-hint-btn{position:fixed;bottom:1.5rem;left:1.5rem;width:28px;height:28px;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.82rem;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:100;transition:color .15s,border-color .15s}.shortcuts-hint-btn:hover{color:var(--text-primary);border-color:var(--accent)}.frame-select-badge{position:absolute;top:.6rem;right:.6rem;width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#0006;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;z-index:1;transition:background .15s,border-color .15s}.frame-select-badge--active{background:var(--accent);border-color:var(--accent)}.selection-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .875rem;background:color-mix(in srgb,var(--accent) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:10px;animation:context-fade-in .12s ease-out}.selection-count{font-size:.85rem;font-weight:600;color:var(--accent)}.selection-actions{display:flex;gap:.4rem}.selection-btn{padding:.35rem .75rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;font-size:.8rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.selection-btn:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface-raised))}.selection-btn--danger{color:var(--error)}.selection-btn--danger:hover{border-color:var(--error);background:color-mix(in srgb,var(--error) 10%,var(--surface-raised))}.selection-btn--confirm{background:var(--error);border-color:var(--error);color:#fff}.selection-btn--confirm:hover{background:color-mix(in srgb,var(--error) 85%,black)}.selection-btn--clear{color:var(--text-secondary);border-color:transparent;background:none}.selection-btn--clear:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.episode-list{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;min-height:400px}.episode-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:.5rem;align-self:start}.episode-sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.episode-sidebar-title{font-size:.82rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.btn-add-episode{background:var(--accent);color:#fff;border:none;border-radius:5px;width:22px;height:22px;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-add-episode:hover{background:var(--accent-hover)}.episode-create-form{display:flex;flex-direction:column;gap:.4rem}.episode-input{width:100%;padding:.45rem .6rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.85rem;outline:none}.episode-input:focus{border-color:var(--accent)}.episode-form-actions{display:flex;gap:.35rem;justify-content:flex-end}.btn-cancel-ep,.btn-save-ep{width:28px;height:28px;border-radius:6px;border:none;font-size:.9rem;display:flex;align-items:center;justify-content:center}.btn-cancel-ep{background:var(--surface-raised);color:var(--text-secondary)}.btn-save-ep{background:var(--accent);color:#fff}.btn-save-ep:hover:not(:disabled){background:var(--accent-hover)}.episode-nav{list-style:none;display:flex;flex-direction:column;gap:.2rem}.episode-nav-li{display:flex;align-items:center;position:relative}.episode-nav-item{flex:1;min-width:0;text-align:left;padding:.5rem .75rem;background:transparent;border:none;border-radius:7px;color:var(--text-secondary);font-size:.88rem;transition:background .12s,color .12s;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.episode-nav-item:hover{background:var(--surface-raised);color:var(--text-primary)}.episode-nav-item.active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);font-weight:500}.episode-item-actions{display:flex;gap:.15rem;opacity:0;transition:opacity .12s;position:absolute;right:.25rem}.episode-nav-li:hover .episode-item-actions{opacity:1}.btn-ep-action{width:22px;height:22px;border-radius:4px;border:none;background:transparent;color:var(--text-secondary);font-size:.78rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,color .12s}.btn-ep-action:hover{background:var(--surface-raised);color:var(--text-primary)}.btn-ep-action-danger:hover{color:var(--error)}.episode-rename-form{display:flex;flex-direction:column;gap:.4rem;padding:.25rem 0;width:100%}.episode-delete-confirm{display:flex;flex-direction:column;gap:.35rem;padding:.4rem .5rem;background:color-mix(in srgb,var(--error) 8%,transparent);border-radius:7px}.episode-delete-label{font-size:.8rem;color:var(--error);font-weight:500}.btn-delete-ep{width:28px;height:28px;border-radius:6px;border:none;font-size:.9rem;display:flex;align-items:center;justify-content:center;background:var(--error);color:#fff;cursor:pointer}.btn-delete-ep:disabled{opacity:.5;cursor:not-allowed}.episode-item-error{color:var(--error);font-size:.75rem;padding:.15rem 0}.episodes-loading,.episodes-empty,.episodes-error{color:var(--text-secondary);font-size:.85rem;padding:.5rem 0}.episodes-error{color:var(--error)}.sidebar-toggle{display:none;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.sidebar-toggle:hover{background:var(--surface-raised)}@media screen and (max-width:768px){.episode-list{grid-template-columns:1fr;min-height:unset}.sidebar-toggle{display:flex}.episode-sidebar{display:none}.episode-list.sidebar-open .episode-sidebar{display:flex}.episode-nav-item{padding:.65rem .85rem;font-size:.95rem}.episode-item-actions{opacity:1}.btn-ep-action{width:32px;height:32px;font-size:.9rem}.btn-add-episode{width:32px;height:32px;font-size:1.1rem}.btn-cancel-ep,.btn-save-ep,.btn-delete-ep{width:36px;height:36px;font-size:1rem}}.episode-content{display:flex;flex-direction:column;gap:1rem}.episode-content-title{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.episode-content-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:2rem}.modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.modal-close{background:transparent;border:none;color:var(--text-secondary);font-size:1rem;line-height:1;padding:.25rem;border-radius:4px;transition:color .15s}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto}.style-editor-form{display:flex;flex-direction:column;gap:1rem}.style-gallery{display:flex;flex-direction:column;gap:.4rem}.gallery-label{font-size:.82rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.style-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.style-gallery-item{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border);aspect-ratio:1 / 1}.style-gallery-img{width:100%;height:100%;object-fit:cover;display:block}.style-img-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:.65rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.style-gallery-item:hover .style-img-remove{opacity:1}.style-upload-section{display:flex;flex-direction:column;gap:.4rem}.style-drop-zone{border:2px dashed var(--border);border-radius:8px;padding:1.25rem 1rem;text-align:center;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s,color .15s;position:relative;-webkit-user-select:none;user-select:none}.style-drop-zone:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,transparent);color:var(--text-primary)}.style-drop-zone.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--text-primary)}.style-drop-zone.uploading{opacity:.6;cursor:wait;pointer-events:none}.hidden-file-input{display:none}.style-gen-section{display:flex;flex-direction:column;gap:.4rem}.style-gen-row{display:flex;gap:.5rem;align-items:stretch}.style-gen-row .field-input{flex:1}.btn-generate{padding:.55rem 1rem;background:var(--surface-raised);color:var(--text-secondary);border:1px dashed var(--border);border-radius:8px;font-size:.88rem;white-space:nowrap;transition:color .15s,border-color .15s}.btn-generate:not(:disabled):hover{color:var(--text-primary);border-color:var(--accent)}.btn-generate:disabled{opacity:.5;cursor:not-allowed}.editor-error{color:var(--error);font-size:.85rem}.editor-actions{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}.editor-actions-left{display:flex;align-items:center;gap:.5rem}.editor-actions-right{display:flex;gap:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.55rem 1rem;background:var(--surface-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.88rem;font-weight:500;transition:color .15s}.btn-secondary:hover:not(:disabled){color:var(--text-primary)}.btn-danger{padding:.45rem .875rem;background:var(--error, #e05252);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-danger-outline{padding:.45rem .875rem;background:transparent;color:var(--error, #e05252);border:1px solid var(--error, #e05252);border-radius:8px;font-size:.85rem;font-weight:500;transition:background .15s}.btn-danger-outline:hover:not(:disabled){background:var(--error, #e05252)18}.btn-link{background:none;border:none;color:var(--text-secondary);font-size:.82rem;padding:0;cursor:pointer;transition:color .15s}.btn-link:hover{color:var(--text-primary)}.style-list{display:flex;flex-direction:column;gap:1.25rem}.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}.style-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:border-color .15s,transform .1s;outline:none}.style-card:hover{border-color:var(--accent);transform:translateY(-1px)}.style-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) 44}.style-card-thumbs{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--surface-raised);overflow:hidden}.style-thumb{position:absolute;top:8px;width:60%;aspect-ratio:1 / 1;object-fit:cover;border-radius:6px;border:2px solid var(--surface);box-shadow:0 2px 6px #0000004d}.style-thumb:first-child{left:0;top:0;width:70%;aspect-ratio:1 / 1;border-radius:0;border:none;box-shadow:none}.style-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--border)}.style-card-body{padding:.625rem .75rem .75rem;display:flex;flex-direction:column;gap:.2rem}.style-name{font-size:.875rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.style-count{font-size:.75rem;color:var(--text-secondary)}.list-header{display:flex;align-items:center;justify-content:space-between}.list-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.list-loading,.list-empty{color:var(--text-secondary);text-align:center;padding:2rem;font-size:.9rem}.list-error{color:var(--error);font-size:.88rem}.btn-primary{padding:.55rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--accent-hover)}.project-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.page-loading,.page-error{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary)}.page-error{color:var(--error)}.project-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-bottom:1px solid var(--border);background:var(--surface);gap:1rem;flex-wrap:wrap}.project-header-left{display:flex;align-items:flex-start;gap:1rem}.back-link{color:var(--text-secondary);font-size:.85rem;white-space:nowrap;padding-top:.2rem;transition:color .15s}.back-link:hover{color:var(--accent)}.project-title-block{display:flex;flex-direction:column;gap:.2rem}.project-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.project-desc{color:var(--text-secondary);font-size:.85rem}.project-meta{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;white-space:nowrap}.meta-dot{opacity:.4}.project-tabs{display:flex;padding:0 2rem;border-bottom:1px solid var(--border);background:var(--surface);gap:.25rem}.tab{padding:.75rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.project-content{flex:1;padding:1.5rem;width:100%}@media screen and (max-width:768px){.project-header{padding:1rem}.project-tabs{padding:0 1rem;overflow-x:auto}.project-content{padding:1rem}.project-title{font-size:1.1rem}}:root{--bg: #0d0d0f;--surface: #1a1a1f;--surface-raised: #242430;--accent: #7c6af7;--accent-hover: #9b8ef9;--text-primary: #e8e8f0;--text-secondary: #8888a0;--border: #2a2a3a;--success: #4caf82;--error: #f05a5a;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text-primary);font-family:var(--font);font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:var(--font)}input,textarea,select{font-family:var(--font)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary);font-size:1rem}
