:root{--ui-bg: #08080c;--ui-surface: rgba(255, 255, 255, .04);--ui-surface-raised: rgba(255, 255, 255, .07);--ui-surface-solid: #111116;--ui-border: rgba(255, 255, 255, .08);--ui-border-subtle: rgba(255, 255, 255, .05);--ui-border-strong: rgba(255, 255, 255, .14);--ui-accent: #7c6cf0;--ui-accent-hover: #6a5bd8;--ui-accent-glow: rgba(124, 108, 240, .25);--ui-accent-subtle: rgba(124, 108, 240, .08);--ui-accent-muted: rgba(124, 108, 240, .15);--ui-danger: #f06068;--ui-danger-glow: rgba(240, 96, 104, .2);--ui-success: #34d399;--ui-text: #e8e6f0;--ui-text-muted: #8a879c;--ui-text-subtle: #56536a;--ui-radius-sm: 6px;--ui-radius: 10px;--ui-radius-lg: 14px;--ui-font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ui-font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--ui-glass-blur: 16px;--ui-glass-blur-heavy: 24px;--ui-shadow: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .5);--ui-shadow-lg: 0 8px 32px rgba(0, 0, 0, .5), 0 0 1px rgba(255, 255, 255, .05);--ui-shadow-float: 0 12px 40px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .06);--ui-ease: cubic-bezier(.4, 0, .2, 1);--ui-ease-spring: cubic-bezier(.34, 1.56, .64, 1)}html{font-size:16px;-webkit-text-size-adjust:100%}body{background-color:var(--ui-bg);color:var(--ui-text);font-family:var(--ui-font-sans);line-height:1.6;min-height:100dvh}a{color:var(--ui-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}img{max-width:100%;display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:var(--ui-radius);border:1px solid var(--ui-border);font-size:.85rem;font-weight:500;transition:all .2s var(--ui-ease);white-space:nowrap;-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));background:var(--ui-surface)}.ui-btn-primary{background:var(--ui-accent);border-color:transparent;color:#fff;box-shadow:0 0 16px var(--ui-accent-glow)}.ui-btn-primary:hover{background:var(--ui-accent-hover);box-shadow:0 0 24px var(--ui-accent-glow);transform:translateY(-1px)}.ui-btn-ghost{background:var(--ui-surface);color:var(--ui-text-muted);border:1px solid var(--ui-border)}.ui-btn-ghost:hover{color:var(--ui-text);border-color:var(--ui-border-strong);background:var(--ui-surface-raised)}.ui-btn-danger{background:var(--ui-danger);border-color:transparent;color:#fff}.ui-btn-danger:hover{background:color-mix(in srgb,var(--ui-danger) 85%,#000);box-shadow:0 0 16px var(--ui-danger-glow)}.ui-btn-danger-ghost{background:transparent;color:var(--ui-danger);border-color:var(--ui-danger)}.ui-btn-danger-ghost:hover{color:var(--ui-danger);border-color:var(--ui-danger);box-shadow:0 0 12px var(--ui-danger-glow);background:color-mix(in srgb,var(--ui-danger) 10%,transparent)}.ui-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.ui-btn-sm{padding:.25rem .6rem;font-size:.78rem}.ui-card{background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-border);border-radius:var(--ui-radius-lg);padding:1.5rem}.ui-input{background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-border);border-radius:var(--ui-radius);color:var(--ui-text);padding:.5rem .75rem;font-size:.85rem;outline:none;transition:border-color .2s var(--ui-ease),box-shadow .2s var(--ui-ease);width:100%}.ui-input:focus{border-color:var(--ui-accent);box-shadow:0 0 0 3px var(--ui-accent-subtle)}.ui-input::placeholder{color:var(--ui-text-subtle)}.ui-page{min-height:100dvh;display:flex;flex-direction:column}.ui-aurora{position:relative}.ui-aurora:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 15% 10%,rgba(124,108,240,.084),transparent),radial-gradient(ellipse 60% 50% at 85% 20%,rgba(56,189,248,.056),transparent),radial-gradient(ellipse 50% 60% at 40% 90%,rgba(168,85,247,.07),transparent),radial-gradient(ellipse 70% 40% at 75% 75%,rgba(34,211,153,.042),transparent),radial-gradient(ellipse 40% 30% at 50% 50%,rgba(244,114,182,.028),transparent);pointer-events:none;z-index:0}.ui-aurora:after{content:"";position:fixed;inset:0;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;pointer-events:none;z-index:0}.ui-aurora>*{position:relative;z-index:1}.ui-ctx-menu{position:fixed;z-index:1000;min-width:170px;background:#121218d1;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong);border-radius:var(--ui-radius);padding:4px;box-shadow:var(--ui-shadow-float);animation:ui-ctx-in .12s var(--ui-ease)}@keyframes ui-ctx-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.ui-ctx-menu-item{display:block;width:100%;padding:7px 12px;background:none;border:none;color:var(--ui-text);font-size:.82rem;text-align:left;border-radius:var(--ui-radius-sm);cursor:pointer;transition:background .12s,color .12s}.ui-ctx-menu-item:hover{background:var(--ui-accent-muted);color:#fff}.ui-ctx-menu-item--danger:hover{background:var(--ui-danger-glow);color:var(--ui-danger)}.ui-ctx-menu-sep{height:1px;background:var(--ui-border);margin:4px 8px}.ui-lightbox-backdrop{position:fixed;inset:0;z-index:200;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;animation:ui-lightbox-fade-in .2s var(--ui-ease)}@keyframes ui-lightbox-fade-in{0%{opacity:0}to{opacity:1}}.ui-lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:90vw;max-height:90vh;cursor:default;animation:ui-lightbox-img-in .3s var(--ui-ease-spring)}@keyframes ui-lightbox-img-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.ui-lightbox-img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:var(--ui-radius-lg);box-shadow:0 20px 80px #0009,0 0 1px #ffffff1a}.ui-lightbox-caption{font-size:.85rem;color:var(--ui-text-muted)}.ui-lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:#12121899;-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-border);color:var(--ui-text);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s var(--ui-ease)}.ui-lightbox-nav:hover{background:#121218d9;border-color:var(--ui-border-strong);box-shadow:0 0 20px #0006}.ui-lightbox-nav svg{width:20px;height:20px}.ui-lightbox-prev{left:1.5rem}.ui-lightbox-next{right:1.5rem}.ui-dp-panel{position:absolute;z-index:30;background:#121218cc;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong);border-radius:var(--ui-radius);box-shadow:var(--ui-shadow-float);display:flex;flex-direction:column;min-width:120px;-webkit-user-select:none;user-select:none}.ui-dp-titlebar{display:flex;align-items:center;justify-content:space-between;padding:.4rem .65rem;cursor:grab;border-bottom:1px solid var(--ui-border);flex-shrink:0}.ui-dp-titlebar:active{cursor:grabbing}.ui-dp-title{font-size:.7rem;font-weight:600;color:var(--ui-text-muted);text-transform:uppercase;letter-spacing:.06em}.ui-dp-close{background:none;border:none;color:var(--ui-text-subtle);font-size:.9rem;cursor:pointer;line-height:1;padding:.1rem .2rem;border-radius:var(--ui-radius-sm);transition:color .15s,background .15s}.ui-dp-close:hover{color:var(--ui-text);background:var(--ui-surface-raised)}.ui-dp-body{flex:1;min-height:0}.ui-dp-resize-handle{height:6px;cursor:ns-resize;background:transparent;border-top:1px solid var(--ui-border);flex-shrink:0;transition:background .15s}.ui-dp-resize-handle:hover{background:var(--ui-accent-muted)}.ui-ev-display{cursor:pointer;font-size:.8rem;color:var(--ui-text-muted);font-variant-numeric:tabular-nums;border-radius:var(--ui-radius-sm);padding:.15rem .35rem;transition:all .15s var(--ui-ease)}.ui-ev-display:hover{background:var(--ui-surface-raised);color:var(--ui-text);box-shadow:0 0 0 1px var(--ui-border)}.ui-ev-input{font:inherit;font-size:.8rem;font-variant-numeric:tabular-nums;background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-accent);box-shadow:0 0 0 3px var(--ui-accent-subtle);border-radius:var(--ui-radius-sm);color:var(--ui-text);padding:.15rem .35rem;outline:none;width:4.5rem}.ui-inline-editable{cursor:text;border-radius:var(--ui-radius-sm);padding:.1rem .25rem;margin:-.1rem -.25rem;transition:all .15s var(--ui-ease)}.ui-inline-editable:hover{background:var(--ui-surface-raised);box-shadow:0 0 0 1px var(--ui-border)}.ui-inline-edit-input{font:inherit;font-weight:600;background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-accent);box-shadow:0 0 0 3px var(--ui-accent-subtle);border-radius:var(--ui-radius-sm);color:var(--ui-text);padding:.1rem .25rem;margin:-.1rem -.25rem;outline:none;width:100%;min-width:60px}.ui-modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:ui-modal-bg-in .2s var(--ui-ease)}@keyframes ui-modal-bg-in{0%{opacity:0}to{opacity:1}}.ui-modal{background:#121218d9;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong);border-radius:var(--ui-radius-lg);width:320px;box-shadow:var(--ui-shadow-float);animation:ui-modal-in .25s var(--ui-ease-spring)}@keyframes ui-modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.ui-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--ui-border)}.ui-modal-title{font-size:.9rem;font-weight:600;color:var(--ui-text)}.ui-modal-close{background:none;border:none;color:var(--ui-text-subtle);font-size:1.2rem;cursor:pointer;padding:.2rem;line-height:1;transition:color .15s;border-radius:var(--ui-radius-sm)}.ui-modal-close:hover{color:var(--ui-text);background:var(--ui-surface-raised)}.ui-modal-body{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem}.ui-zoom-controls{display:flex;align-items:center;gap:.15rem;background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-border);border-radius:var(--ui-radius);padding:.2rem .35rem;box-shadow:var(--ui-shadow)}.ui-zoom-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--ui-radius-sm);color:var(--ui-text-muted);font-size:.85rem;cursor:pointer;transition:all .15s var(--ui-ease)}.ui-zoom-btn:hover{background:var(--ui-surface-raised);color:var(--ui-text)}.ui-zoom-btn:active{transform:scale(.92)}.ui-zoom-fit{font-size:.72rem;width:auto;padding:0 .45rem}.ui-zoom-val{font-size:.7rem;color:var(--ui-text-muted);min-width:2.4rem;text-align:center;font-variant-numeric:tabular-nums}.ui-page-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--ui-border);background:#08080cbf;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));box-shadow:0 1px #ffffff08;position:sticky;top:0;z-index:10}.ui-page-header-left{display:flex;align-items:center;gap:.5rem;min-width:0}.ui-page-header-actions{display:flex;align-items:center;gap:.5rem}.ui-breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.ui-breadcrumb-segment{display:flex;align-items:center;gap:.4rem}.ui-breadcrumb-sep{color:var(--ui-text-subtle);font-size:.8rem}.ui-breadcrumb-link{color:var(--ui-text-muted);font-size:.85rem;cursor:pointer;transition:color .2s var(--ui-ease)}.ui-breadcrumb-link:hover{color:var(--ui-text)}.ui-breadcrumb-current{font-size:.9rem;font-weight:600;color:var(--ui-text)}.ui-selection-count{font-size:.82rem;color:var(--ui-accent);padding:.15rem .5rem;background:var(--ui-accent-subtle);border-radius:var(--ui-radius-sm);font-variant-numeric:tabular-nums}.ui-item-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--ui-grid-min, 160px),1fr));gap:.75rem}.ui-item-grid--drop-active{background:var(--ui-accent-subtle);border-radius:var(--ui-radius)}.ui-item-card-wrap{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.ui-item-card-wrap[draggable=true]{cursor:grab}.ui-item-card-wrap[draggable=true]:active{cursor:grabbing}.ui-item-card-wrap.dragging{opacity:.4}.ui-item-card--selected .ui-item-card{border-color:var(--ui-accent);box-shadow:0 0 0 1px var(--ui-accent),0 0 24px var(--ui-accent-glow),inset 0 0 20px #7c6cf00f}.ui-item-card--selected .ui-item-card-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(124,108,240,.12),transparent);pointer-events:none}.ui-item-card{display:flex;flex-direction:column;transition:border-color .2s var(--ui-ease),transform .2s var(--ui-ease-spring),box-shadow .2s var(--ui-ease);padding:0;overflow:hidden;border-radius:var(--ui-radius);background:var(--ui-surface);-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong)}.ui-item-card:hover{border-color:var(--ui-border-strong);transform:translateY(-2px) scale(1.01);box-shadow:0 8px 24px #0000004d}.ui-item-card-thumb{position:relative;aspect-ratio:1;background:var(--ui-surface-solid);overflow:hidden;border-bottom:1px solid var(--ui-border-subtle)}.ui-item-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s var(--ui-ease)}.ui-item-card:hover .ui-item-card-thumb img{transform:scale(1.04)}.ui-item-card-thumb-empty{width:100%;height:100%;background:radial-gradient(circle at 50% 40%,var(--ui-accent-subtle),transparent 70%),var(--ui-surface-solid)}.ui-item-card-info{display:flex;align-items:baseline;gap:.4rem;padding:.5rem .6rem}.ui-item-card-name{font-size:.8rem;font-weight:600;color:var(--ui-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.ui-item-card-meta{font-size:.65rem;color:var(--ui-text-subtle);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.ui-folder-wrap{position:relative;border-radius:var(--ui-radius);transition:box-shadow .2s var(--ui-ease)}.ui-folder-wrap.ui-folder-drop-active{box-shadow:inset 0 0 0 2px var(--ui-accent),0 0 20px var(--ui-accent-glow);border-radius:var(--ui-radius)}.ui-folder{display:flex;flex-direction:column;width:100%;background:none;border:1px solid var(--ui-border);border-radius:var(--ui-radius);padding:0;cursor:pointer;overflow:hidden;transition:border-color .2s var(--ui-ease),transform .2s var(--ui-ease-spring),box-shadow .2s var(--ui-ease);color:var(--ui-text)}.ui-folder:hover{border-color:var(--ui-border-strong);transform:translateY(-2px) scale(1.01);box-shadow:0 8px 24px #0000004d}.ui-folder-icon{aspect-ratio:1;background:linear-gradient(135deg,var(--ui-accent-subtle) 0%,transparent 60%),var(--ui-surface-solid);border-bottom:1px solid var(--ui-border-subtle);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.ui-folder-icon:before{content:"";position:absolute;top:0;left:0;width:40%;height:6px;background:linear-gradient(90deg,var(--ui-accent),transparent);border-radius:0 0 6px;opacity:.6}.ui-folder-info{display:flex;flex-direction:column;gap:.1rem;padding:.45rem .6rem;-webkit-backdrop-filter:blur(var(--ui-glass-blur));backdrop-filter:blur(var(--ui-glass-blur));background:var(--ui-surface)}.ui-folder-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.ui-folder-count{font-size:.62rem;color:var(--ui-text-subtle);text-align:left}.ui-folder-preview-grid{width:80%;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--ui-border-subtle)}.ui-folder-preview-grid img{width:100%;height:100%;object-fit:cover}.ui-folder-preview-grid--1{display:flex}.ui-folder-preview-grid--2{display:grid;grid-template-columns:1fr 1fr}.ui-folder-preview-grid--3{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ui-folder-preview-grid--3 img:first-child{grid-row:1 / -1}.ui-folder-preview-grid--4{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.ui-folder-preview-empty{display:flex;align-items:center;justify-content:center;width:60%;aspect-ratio:1}.ui-folder-preview-svg{width:48px;height:48px;color:var(--ui-text-subtle);opacity:.3}.ui-slide-panel{position:fixed;top:0;height:100dvh;background:#0c0c12d9;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border-right:1px solid var(--ui-border);transition:transform .3s var(--ui-ease);z-index:50;display:flex;flex-direction:column;box-shadow:var(--ui-shadow-float)}.ui-slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid var(--ui-border);flex-shrink:0}.ui-slide-panel-title{font-size:.82rem;font-weight:600;color:var(--ui-text)}.ui-slide-panel-close{background:none;border:none;color:var(--ui-text-muted);font-size:1.1rem;cursor:pointer;line-height:1;border-radius:var(--ui-radius-sm);padding:.1rem .2rem;transition:color .15s,background .15s}.ui-slide-panel-close:hover{color:var(--ui-text);background:var(--ui-surface-raised)}.ui-slide-panel-tabs{display:flex;border-bottom:1px solid var(--ui-border);flex-shrink:0}.ui-slide-panel-body{flex:1;overflow-y:auto;padding:.75rem}.ui-tab{flex:1;padding:.5rem;font-size:.72rem;font-weight:500;color:var(--ui-text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .2s var(--ui-ease),border-color .2s var(--ui-ease)}.ui-tab:hover{color:var(--ui-text)}.ui-tab--active{color:var(--ui-accent);border-bottom-color:var(--ui-accent)}.ui-login-card{position:relative;display:flex;flex-direction:column;gap:1rem;width:100%;max-width:400px;padding:2rem;background:#121218b3;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong);border-radius:var(--ui-radius-lg);box-shadow:var(--ui-shadow-float)}.ui-login-dev-badge{position:absolute;top:-1px;right:-1px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#000;font-size:.65rem;font-weight:700;letter-spacing:.08em;padding:.2rem .65rem;border-radius:0 var(--ui-radius-lg) 0 var(--ui-radius);box-shadow:0 0 12px #f59e0b4d;text-transform:uppercase}.ui-login-title{font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;background:linear-gradient(135deg,#fff 0%,var(--ui-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ui-login-subtitle{color:var(--ui-text-muted);font-size:.88rem;margin-top:-.5rem}.ui-login-tabs{display:flex;border:1px solid var(--ui-border);border-radius:var(--ui-radius);overflow:hidden}.ui-login-tab{flex:1;background:transparent;border:none;color:var(--ui-text-muted);padding:.55rem .5rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s var(--ui-ease);font-family:inherit}.ui-login-tab:hover{color:var(--ui-text)}.ui-login-tab--active{background:var(--ui-surface-raised);color:var(--ui-text)}.ui-login-body{display:flex;flex-direction:column;gap:.75rem}.ui-login-error{color:var(--ui-danger);font-size:.82rem;padding:.5rem .75rem;background:#f0606814;border:1px solid rgba(240,96,104,.2);border-radius:var(--ui-radius)}.ui-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ui-bg);padding:1rem}.ui-login-section{display:flex;flex-direction:column;gap:.75rem}.ui-login-hint{color:var(--ui-text-muted);font-size:.88rem;text-align:center}.ui-login-label{font-size:.88rem;color:var(--ui-text-muted);font-weight:500}.ui-login-btn-full{width:100%}.ui-login-footer{color:var(--ui-text-subtle);font-size:.78rem;text-align:center;line-height:1.5}.ui-login-dev-section{display:flex;flex-direction:column;gap:.75rem}.ui-login-dev-divider{display:flex;align-items:center;gap:.75rem;color:var(--ui-text-subtle);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.ui-login-dev-divider:before,.ui-login-dev-divider:after{content:"";flex:1;height:1px;background:var(--ui-border)}.ui-user-menu{position:relative;z-index:100}.ui-user-menu-trigger{width:34px;height:34px;border-radius:50%;border:1px solid var(--ui-border);background:var(--ui-accent-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:border-color .15s,box-shadow .15s;overflow:hidden}.ui-user-menu-trigger:hover{border-color:var(--ui-accent);box-shadow:0 0 0 2px var(--ui-accent-glow)}.ui-user-menu-avatar{width:100%;height:100%;object-fit:cover;border-radius:50%}.ui-user-menu-initials{font-size:.82rem;font-weight:600;color:var(--ui-accent);line-height:1;-webkit-user-select:none;user-select:none}.ui-user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:#121218d1;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));border:1px solid var(--ui-border);border-top-color:var(--ui-border-strong);border-radius:var(--ui-radius);padding:4px;box-shadow:var(--ui-shadow-float);animation:ui-user-menu-in .12s var(--ui-ease);z-index:1000}@keyframes ui-user-menu-in{0%{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.ui-user-menu-name{padding:7px 12px;font-size:.78rem;font-weight:500;color:var(--ui-text-muted);-webkit-user-select:none;user-select:none}.ui-user-menu-item{display:block;width:100%;padding:7px 12px;background:none;border:none;color:var(--ui-text);font-size:.82rem;text-align:left;border-radius:var(--ui-radius-sm);cursor:pointer;transition:background .12s,color .12s}.ui-user-menu-item:hover{background:var(--ui-accent-muted);color:#fff}.ui-user-menu-item--danger:hover{background:var(--ui-danger-glow);color:var(--ui-danger)}.ui-user-menu-sep{height:1px;background:var(--ui-border);margin:4px 8px}.ui-statusbar{display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:28px;border-top:1px solid var(--ui-border);background:#08080cbf;-webkit-backdrop-filter:blur(var(--ui-glass-blur-heavy));backdrop-filter:blur(var(--ui-glass-blur-heavy));box-shadow:0 -1px #ffffff08;position:fixed;bottom:0;left:0;right:0;z-index:10;font-size:.72rem;color:var(--ui-text-muted);gap:.5rem}.ui-statusbar-left,.ui-statusbar-right,.ui-statusbar-center{display:flex;align-items:center;gap:.6rem;min-width:0}.ui-statusbar-left{justify-content:flex-start}.ui-statusbar-center{justify-content:center;flex:1}.ui-statusbar-right{justify-content:flex-end}.ui-sb-label{color:var(--ui-text-subtle);margin-right:.3rem}.ui-sb-text{white-space:nowrap;font-variant-numeric:tabular-nums}.ui-sb-text--muted{color:var(--ui-text-subtle)}.ui-sb-spinner{display:inline-flex;align-items:center;gap:.35rem}.ui-sb-spinner-icon{animation:ui-sb-spin .8s linear infinite;color:var(--ui-accent)}@keyframes ui-sb-spin{to{transform:rotate(360deg)}}.ui-sb-progress{display:inline-flex;align-items:center;gap:.4rem}.ui-sb-progress-track{height:4px;background:var(--ui-surface-raised);border-radius:2px;overflow:hidden;display:inline-block}.ui-sb-progress-fill{display:block;height:100%;background:var(--ui-accent);border-radius:2px;transition:width .3s var(--ui-ease)}.ui-sb-badge{display:inline-flex;align-items:center;gap:.3rem;white-space:nowrap}.ui-sb-badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ui-sb-sep{width:1px;height:14px;background:var(--ui-border);flex-shrink:0}.dashboard-main{flex:1;padding:1.5rem;width:100%}.dashboard-empty{text-align:center;color:var(--text-secondary);padding:3rem}.dashboard-error{color:var(--error);margin-bottom:1rem;font-size:.88rem}.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}.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-type-badge{font-size:.68rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;white-space:nowrap;flex-shrink:0;text-transform:capitalize}.episode-list{display:flex;flex-direction:column;gap:1rem}.episode-create-form{display:flex;flex-direction:column;gap:.75rem;max-width:480px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.episodes-loading,.episodes-error{color:var(--text-secondary);font-size:.85rem;padding:.5rem 0}.episodes-error{color:var(--error)}.style-list{display:flex;flex-direction:column;gap:1.25rem}.project-sub-bar{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;border-bottom:1px solid var(--border);background:#12121880;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);gap:1rem}.project-tabs{display:flex;gap:.25rem}.project-sub-bar-right{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end;max-width:360px}.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-sub-bar{padding:0 1rem;flex-wrap:wrap}.project-sub-bar-right{max-width:100%}.project-content{padding:1rem}}.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-sub-bar{display:flex;align-items:center;padding:.4rem 1.5rem;border-bottom:1px solid var(--border);background:#12121880;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-height:40px}.episode-sub-bar-content{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;width:100%}.episode-sub-bar-content .view-toggle{justify-self:center}.episode-sub-bar-content .search-filter-bar{justify-self:end}.episode-page-content{flex:1;padding:1.5rem;width:100%}@media screen and (max-width:768px){.episode-sub-bar{padding:.4rem 1rem}.episode-page-content{padding:1rem}}.fe-layout{display:grid;grid-template-columns:1fr 320px;flex:1;min-height:0}.fe-visual-col{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;overflow-y:auto}.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;padding:.75rem;overflow:hidden}.fe-panel{flex:1;min-height:0}.fe-panel>.ui-panel-body{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-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}.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}.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}.kft-root{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:10px}.kft-header{display:flex;align-items:center;justify-content:space-between}.kft-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.kft-duration-label{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--text-secondary)}.kft-duration-select{padding:.2rem .4rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-size:.78rem;cursor:pointer}.kft-track-wrap{display:flex;flex-direction:column;gap:.25rem}.kft-track{position:relative;height:36px;cursor:crosshair;-webkit-user-select:none;user-select:none}.kft-track-bar{position:absolute;top:50%;left:0;right:0;height:3px;background:var(--border);border-radius:2px;transform:translateY(-50%)}.kft-marker{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;padding:0;cursor:pointer;z-index:1}.kft-marker--dragging{cursor:grabbing;z-index:2}.kft-marker-dot{width:12px;height:12px;border-radius:50%;background:var(--surface-raised);border:2px solid var(--text-secondary);transition:border-color .15s,background .15s,transform .15s}.kft-marker:hover .kft-marker-dot{border-color:var(--accent);transform:scale(1.15)}.kft-marker--active .kft-marker-dot{background:var(--accent);border-color:var(--accent)}.kft-marker--endpoint .kft-marker-dot{width:14px;height:14px;border-width:2.5px;border-color:var(--text-primary)}.kft-marker--endpoint.kft-marker--active .kft-marker-dot{background:var(--accent);border-color:var(--accent)}.kft-marker-time{font-size:.62rem;color:var(--text-secondary);white-space:nowrap;position:absolute;top:calc(100% + 2px);opacity:0;transition:opacity .15s;pointer-events:none}.kft-marker:hover .kft-marker-time,.kft-marker--active .kft-marker-time,.kft-marker--dragging .kft-marker-time{opacity:1}.kft-ticks{display:flex;justify-content:space-between;padding:0 2px}.kft-tick{font-size:.6rem;color:var(--text-secondary);opacity:.5}.kft-descriptions{display:flex;flex-direction:column;gap:.3rem;max-height:180px;overflow-y:auto}.kft-desc-row{display:grid;grid-template-columns:48px 1fr auto;gap:.4rem;align-items:start;padding:.35rem .4rem;border-radius:6px;cursor:pointer;transition:background .1s}.kft-desc-row:hover{background:var(--surface-raised)}.kft-desc-row--active{background:color-mix(in srgb,var(--accent) 8%,transparent)}.kft-desc-time{font-size:.72rem;font-weight:600;color:var(--accent);padding-top:.3rem;font-variant-numeric:tabular-nums}.kft-desc-input{width:100%;padding:.3rem .5rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:5px;color:var(--text-primary);font-size:.78rem;outline:none;resize:none;transition:border-color .15s;min-height:28px}.kft-desc-input:focus{border-color:var(--accent)}.kft-desc-input::placeholder{color:var(--text-secondary);opacity:.6}.kft-desc-remove{background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:.2rem .3rem;border-radius:4px;line-height:1;transition:color .15s,background .15s}.kft-desc-remove:hover:not(:disabled){color:var(--error, #e05252);background:color-mix(in srgb,var(--error, #e05252) 10%,transparent)}.kft-desc-remove:disabled{opacity:.3;cursor:not-allowed}.kft-hint{font-size:.68rem;color:var(--text-secondary);opacity:.5;text-align:center;margin:0}.editor-error{color:var(--error);font-size:.82rem}.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}@media(max-width:768px){.fe-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.fe-visual-col{border-bottom:1px solid var(--border);max-height:45vh}}.ae-layout{display:grid;grid-template-columns:1fr 340px;flex:1;min-height:0}.ae-preview-col{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;overflow-y:auto}.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;padding:.75rem;overflow:hidden}.ae-panel{flex:1;min-height:0}.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{display:flex;flex-direction:column;gap:.35rem}.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}.field-input:focus{border-color:var(--accent)}.field-input::placeholder{color:var(--text-secondary)}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}@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}.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}@keyframes pulse-border{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.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}.editor-error{color:var(--error);font-size:.85rem}.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)}@media(max-width:768px){.ae-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.ae-preview-col{border-bottom:1px solid var(--border);max-height:40vh}}.se-layout{display:grid;grid-template-columns:1fr 340px;flex:1;min-height:0}.se-gallery-col{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;overflow-y:auto}.se-gallery-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}.se-panel-col{display:flex;flex-direction:column;padding:.75rem;overflow:hidden}.se-panel{flex:1;min-height:0}.se-panel>.ui-panel-body{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(140px,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}@media(max-width:768px){.se-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.se-gallery-col{border-bottom:1px solid var(--border);max-height:40vh}}: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;--ui-bg: var(--bg);--ui-surface: var(--surface);--ui-surface-raised: var(--surface-raised);--ui-border: var(--border);--ui-accent: var(--accent);--ui-accent-hover: var(--accent-hover);--ui-text: var(--text-primary);--ui-text-muted: var(--text-secondary);--ui-text-subtle: #555;--ui-danger: var(--error);--ui-success: var(--success)}*,*: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}.breadcrumb-editable{font-weight:600;color:var(--text-primary);cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .15s}.breadcrumb-editable:hover{border-color:var(--text-secondary)}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.list-title{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.list-empty{text-align:center;color:var(--text-secondary);padding:2rem;font-size:.9rem}.list-loading,.list-error{color:var(--text-secondary);font-size:.88rem;padding:1rem}.list-error{color:var(--error)}.page-loading,.page-error{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary)}.page-error{color:var(--error)}.ui-login-title{font-family:Teko,sans-serif;font-weight:600;font-size:4rem;letter-spacing:.08em}
