:root{--bg-canvas: #0f1117;--bg-panel: rgba(20, 23, 30, .8);--bg-elevated: rgba(26, 30, 40, .9);--bg-surface: rgba(32, 36, 48, .95);--text-primary: #ffffff;--text-secondary: #a0a8b8;--text-tertiary: #6b7280;--text-muted: #4b5563;--accent-primary: #3b82f6;--accent-primary-hover: #2563eb;--accent-primary-transparent: rgba(59, 130, 246, .1);--accent-secondary: #6366f1;--accent-secondary-hover: #4f46e5;--accent-secondary-transparent: rgba(99, 102, 241, .1);--accent-gradient: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--accent-success: #10b981;--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-info: #3b82f6;--border-color: rgba(255, 255, 255, .08);--border-color-light: rgba(255, 255, 255, .12);--border-color-hover: rgba(59, 130, 246, .2);--glass-border: rgba(255, 255, 255, .1);--divider-color: rgba(255, 255, 255, .06);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .7);--shadow-glow: 0 0 0 1px rgba(59, 130, 246, .2);--shadow-glow-sm: 0 0 0 1px rgba(59, 130, 246, .1);--shadow-glow-strong: 0 0 0 2px rgba(59, 130, 246, .3);--glass-blur: blur(16px) saturate(150%);--glass-bg-light: rgba(255, 255, 255, .04);--glass-bg-dark: rgba(0, 0, 0, .2);--gradient-primary: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--gradient-accent: linear-gradient(90deg, #3b82f6 0%, #6366f1 100%);--gradient-card: linear-gradient(145deg, rgba(26, 30, 40, .9), rgba(20, 23, 30, .9));--gradient-surface: linear-gradient(135deg, rgba(15, 17, 23, .95), rgba(20, 23, 30, .95));--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--toolbar-height: 72px;--canvas-min-height: 60vh;--font-family-base: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Code", "Fira Mono", "Droid Sans Mono", "Source Code Pro", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: .9375rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-canvas);background-image:radial-gradient(circle at 20% 30%,rgba(59,130,246,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(99,102,241,.03) 0%,transparent 50%);background-attachment:fixed;color:var(--text-primary);line-height:1.6;overflow-x:hidden;font-size:var(--font-size-base)}#root{width:100%;min-height:100vh;background-color:var(--bg-canvas)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-panel);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:var(--radius-sm);border:1px solid var(--bg-panel);transition:all .3s ease}::-webkit-scrollbar-thumb:hover{background:#3b82f680}::selection{background-color:var(--accent-primary);color:#fff}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary);letter-spacing:-.01em}h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--text-primary)}h2{font-size:var(--font-size-3xl);font-weight:600}h3{font-size:var(--font-size-2xl);font-weight:600}h4{font-size:var(--font-size-xl);font-weight:600}p{color:var(--text-secondary);line-height:1.7}.btn{padding:.625rem 1.25rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);position:relative;letter-spacing:0;font-family:var(--font-family-base);color:#fff}.btn-primary{background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-primary:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-ghost{background-color:transparent;color:#fff;border:1px solid transparent}.btn-ghost:hover{background:#ffffff0d;color:#fff;border-color:#ffffff1a}.input{width:100%;padding:10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;font-family:var(--font-family-base)}.input:focus{outline:none;border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.input::placeholder{color:#ffffff4d;font-style:italic;opacity:1}textarea.input{min-height:100px;resize:vertical}select,select.input,.select{width:100%;padding:10px 36px 10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;font-family:var(--font-family-base);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a78bfa' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}select:focus,select.input:focus,.select:focus{outline:none;border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}select option,select.input option,.select option{background:#14171ef2;color:#fff;padding:8px}.card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative;overflow:hidden}.card:hover{box-shadow:var(--shadow-lg);border-color:#3b82f633;transform:translateY(-1px)}@keyframes scaleIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .3s ease-out}.slide-up{animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.scale-in{animation:scaleIn .2s cubic-bezier(.4,0,.2,1)}.spin{animation:spin 1s linear infinite}button,a,input,select,textarea{transition:all var(--transition-base)}.card,.project-card,.character-card,.location-card,.workspace-card{transition:all var(--transition-base);will-change:transform}button:hover,.btn:hover,button:active,.btn:active{transition:all var(--transition-fast)}.interactive-card{cursor:pointer;position:relative;overflow:hidden}.interactive-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.loading-spinner{width:18px;height:18px;border:2px solid rgba(59,130,246,.2);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.page-enter{opacity:0;transform:translateY(8px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--transition-base),transform var(--transition-base)}.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-8px);transition:opacity var(--transition-base),transform var(--transition-base)}*{animation-timing-function:cubic-bezier(.16,1,.3,1)}@keyframes page-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.content-area>*{animation:page-enter .6s cubic-bezier(.16,1,.3,1)}.script-chatbot-fab{position:fixed;bottom:24px;right:24px;z-index:999;display:inline-flex;align-items:center;gap:8px;padding:12px 18px;background:var(--gradient-primary);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-xl);font-size:.9375rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-lg);transition:transform var(--transition-base),box-shadow var(--transition-base)}.script-chatbot-fab:hover{transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.script-chatbot-fab:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.script-chatbot-fab-icon{font-size:1.25rem;line-height:1}.script-chatbot-fab-label{letter-spacing:.02em}.script-chatbot-overlay{position:fixed;inset:0;background:#0006;z-index:1000;animation:script-chatbot-fadeIn .2s ease-out}@keyframes script-chatbot-fadeIn{0%{opacity:0}to{opacity:1}}.script-chatbot-panel{position:fixed;top:0;right:0;width:100%;max-width:420px;height:100vh;z-index:1001;background:var(--bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-left:1px solid var(--border-color);box-shadow:-8px 0 32px #0000004d;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}.script-chatbot-panel--open{transform:translate(0)}.script-chatbot-header{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-xl);border-bottom:1px solid var(--border-color);background:var(--bg-elevated)}.script-chatbot-header-text{min-width:0}.script-chatbot-title{margin:0 0 var(--spacing-xs) 0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.script-chatbot-subtitle{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.script-chatbot-subtitle strong{color:var(--text-primary);font-weight:600}.script-chatbot-close{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.script-chatbot-close:hover{background:var(--bg-panel);border-color:var(--accent-primary);color:var(--accent-primary)}.script-chatbot-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);min-height:0}.script-chatbot-messages::-webkit-scrollbar{width:8px}.script-chatbot-messages::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:var(--radius-sm)}.script-chatbot-messages::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:var(--radius-sm)}.script-chatbot-loading{color:var(--text-tertiary);font-size:.875rem;padding:var(--spacing-lg)}.script-chatbot-message{display:flex;flex-direction:column;gap:var(--spacing-xs);align-items:flex-start;max-width:90%;animation:script-chatbot-messageIn .2s ease-out}@keyframes script-chatbot-messageIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.script-chatbot-message--user{align-self:flex-end;align-items:flex-end}.script-chatbot-message-content{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);word-wrap:break-word}.script-chatbot-message-content p{margin:0;line-height:1.6;font-size:.9375rem}.script-chatbot-message--user .script-chatbot-message-content{background:var(--accent-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.script-chatbot-message--assistant .script-chatbot-message-content{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary);border-bottom-left-radius:var(--radius-sm)}.script-chatbot-message-pre{margin:0;padding:0;background:transparent;color:inherit;font-family:inherit;font-size:.875rem;white-space:pre-wrap;word-wrap:break-word;line-height:1.5}.script-chatbot-message-time{font-size:.75rem;color:var(--text-tertiary);padding:0 var(--spacing-sm)}.script-chatbot-footer{flex-shrink:0;padding:var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-elevated);display:flex;flex-direction:column;gap:var(--spacing-md)}.script-chatbot-share{width:100%;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}.script-chatbot-form{display:flex;gap:var(--spacing-sm);align-items:center}.script-chatbot-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.script-chatbot-input::placeholder{color:var(--text-tertiary)}.script-chatbot-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f626}.script-chatbot-send{padding:var(--spacing-md) var(--spacing-lg);min-width:80px}@media(max-width:480px){.script-chatbot-panel{max-width:100%}.script-chatbot-fab-label{display:none}.script-chatbot-fab{padding:12px 14px;border-radius:50%}}.main-layout{display:flex;flex-direction:column;height:100vh;overflow-x:hidden;overflow-y:auto;background:var(--bg-canvas)}.top-navbar{background:#0f1117f2;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 1px 3px #0000004d;z-index:1000;position:sticky;top:0;overflow:visible}.navbar-content{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);gap:var(--spacing-lg);width:100%;min-height:72px;overflow:visible;position:relative}.navbar-left{display:flex;align-items:center;gap:var(--spacing-lg);flex-shrink:0;min-width:0}.navbar-logo-link{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-base);position:relative;overflow:hidden}.navbar-logo-link:before{content:"";position:absolute;inset:0;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base);border-radius:var(--radius-md)}.navbar-logo-link:hover:before{opacity:.1}.navbar-logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary);border-radius:var(--radius-md);position:relative;z-index:1;transition:all var(--transition-base)}.navbar-logo-icon svg{width:20px;height:20px;color:#fff}.navbar-logo-link:hover .navbar-logo-icon{background:var(--accent-primary-hover)}.navbar-logo-icon:after{content:"";position:absolute;inset:-4px;background:radial-gradient(circle,rgba(108,74,182,.2) 0%,transparent 70%);border-radius:50%;opacity:0;transition:opacity var(--transition-base);z-index:-1}.navbar-logo-link:hover .navbar-logo-icon:after{opacity:1}.navbar-logo-link:hover .navbar-logo-icon{transform:rotate(5deg) scale(1.05)}.navbar-logo-text{font-size:1.25rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em;position:relative;z-index:1;white-space:nowrap}.navbar-nav{display:flex;align-items:center;gap:var(--spacing-sm);list-style:none;padding:0;margin:0;flex-wrap:nowrap}.navbar-nav .nav-link{font-size:.9375rem}.navbar-center{display:flex;align-items:center;gap:var(--spacing-lg);flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.navbar-center::-webkit-scrollbar{display:none}.project-badge{font-size:.875rem;color:var(--text-primary);font-weight:500;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color);white-space:nowrap;flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);letter-spacing:0}.project-nav{gap:var(--spacing-xs);flex-wrap:nowrap}.project-nav .nav-link{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}.extra-menu-wrapper{position:relative;display:inline-block}.extra-menu-trigger{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;border:none;background:transparent;font-family:inherit;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-md);white-space:nowrap;font-size:.875rem;font-weight:500;letter-spacing:-.015em;position:relative;overflow:visible}.extra-menu-trigger:before{content:"";position:absolute;inset:0;background:#3b82f614;border-radius:var(--radius-md);opacity:0;transition:opacity .2s ease}.extra-menu-trigger:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:var(--accent-primary);transition:width .2s cubic-bezier(.4,0,.2,1);border-radius:1px}.extra-menu-trigger:hover{color:var(--text-primary)}.extra-menu-trigger:hover:before{opacity:1}.extra-menu-trigger.active{color:var(--accent-primary);font-weight:600}.extra-menu-trigger.active:before{opacity:1;background:#3b82f61f}.extra-menu-trigger.active:after{width:calc(100% - 24px)}.extra-menu-arrow{font-size:.7rem;transition:transform var(--transition-base);display:inline-block}.extra-menu-wrapper:hover .extra-menu-arrow{transform:rotate(180deg)}.extra-menu-dropdown{position:absolute;top:calc(100% + var(--spacing-xs));right:0;background:#14171ef2;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xs);min-width:160px;z-index:10000;animation:fadeInDown .2s cubic-bezier(.4,0,.2,1)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.extra-menu-item{display:block;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-base);font-size:.875rem;white-space:nowrap}.extra-menu-item:hover{background:#3b82f61a;color:var(--text-primary)}.extra-menu-item.active{background:#3b82f626;color:var(--accent-primary);font-weight:600}.navbar-right{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0;position:relative;z-index:1001;overflow:visible}.nav-link{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);color:var(--text-secondary);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-md);white-space:nowrap;font-size:.9375rem;font-weight:500;letter-spacing:-.015em;position:relative;overflow:visible;background:transparent}.nav-link:before{content:"";position:absolute;inset:0;background:#6c4ab60f;border-radius:var(--radius-md);opacity:0;transition:opacity .2s ease}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:var(--accent-primary);transition:width .2s cubic-bezier(.4,0,.2,1);border-radius:1px}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:before{opacity:1}.nav-link.active{color:var(--accent-primary);font-weight:600}.nav-link.active:before{opacity:1;background:#3b82f61f}.nav-link.active:after{width:calc(100% - 24px)}.user-menu{position:relative;display:inline-flex;align-items:center;z-index:1001}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-base);border:2px solid var(--bg-elevated);flex-shrink:0;box-shadow:0 2px 12px #6c4ab666,0 0 0 2px #6c4ab61a;border:2px solid rgba(255,255,255,.15)}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 16px #6c4ab666;border-color:#6c4ab680}.user-dropdown{position:absolute;top:calc(100% + var(--spacing-md));right:0;background:#14171ef2!important;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border:1px solid var(--border-color)!important;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)!important;padding:var(--spacing-md);min-width:220px;opacity:0;visibility:hidden;transform:translateY(-8px) scale(.95);transition:opacity .2s cubic-bezier(.4,0,.2,1),visibility .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);z-index:99999!important;pointer-events:none;white-space:nowrap;display:block!important}.user-menu:hover .user-dropdown,.user-dropdown:hover{opacity:1!important;visibility:visible!important;transform:translateY(0) scale(1)!important;pointer-events:auto!important;display:block!important}.user-info{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1)}.user-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);letter-spacing:-.01em}.user-email{font-size:.8125rem;color:var(--text-tertiary)}.logout-btn{width:100%;justify-content:flex-start;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-base);color:var(--text-secondary)}.logout-btn:hover{background:#e74c3c1a;color:var(--accent-danger);border-color:#e74c3c33}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-canvas)}.content-area{flex:1;overflow-y:auto;padding:var(--spacing-xl)}@media(max-width:1024px){.navbar-content{padding:var(--spacing-md);gap:var(--spacing-md)}.navbar-center{gap:var(--spacing-sm)}.navbar-left{gap:var(--spacing-md)}.nav-label{display:none}.nav-link{padding:var(--spacing-sm)}.project-badge{display:none}}@media(max-width:768px){.navbar-left{gap:var(--spacing-md)}.navbar-logo-text{font-size:1.125rem}.navbar-logo-icon{width:32px;height:32px}.navbar-nav{gap:2px}.navbar-nav .nav-link{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}.project-nav .nav-link{font-size:.8125rem;padding:var(--spacing-xs) var(--spacing-sm)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-canvas);padding:var(--spacing-lg);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(74,158,255,.1) 0%,transparent 70%);animation:rotate-gradient 20s linear infinite}.login-card{width:100%;max-width:420px;background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-2xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-xl),0 0 50px #4a9eff33;position:relative;z-index:1;animation:slide-in-fade .6s cubic-bezier(.16,1,.3,1)}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-logo{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.login-submit{width:100%;margin-top:var(--spacing-sm)}.demo-login{width:100%;background:var(--bg-elevated);color:var(--text-secondary)}.demo-login:hover{background:var(--bg-panel);color:var(--text-primary)}.error-message{padding:var(--spacing-md);background:#e74c3c1a;border:1px solid var(--accent-danger);border-radius:var(--radius-md);color:var(--accent-danger);font-size:.9rem}.login-footer{margin-top:var(--spacing-xl);text-align:center}.link-button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:.9rem;text-decoration:underline;padding:0}.link-button:hover{color:var(--accent-primary-hover)}.workflow-builder{width:100%;padding:var(--spacing-xl);background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.workflow-header{margin-bottom:var(--spacing-xl);text-align:center}.workflow-header h2{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:1.5rem}.workflow-header p{margin:0;color:var(--text-secondary);font-size:.95rem}.workflow-canvas{position:relative;width:100%;min-height:500px;max-height:600px;background:var(--bg-canvas);background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-md);border:2px solid var(--border-color);overflow:auto;cursor:grab;box-shadow:inset 0 0 50px #0000004d}.workflow-canvas>div{position:relative;width:100%;height:100%}.workflow-canvas:active{cursor:grabbing}.workflow-item{position:absolute;width:180px;min-height:100px;background:var(--bg-panel);border:3px solid;border-radius:var(--radius-lg);cursor:grab;transition:all var(--transition-base);z-index:10;box-shadow:var(--shadow-md);-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.workflow-item:hover{transform:scale(1.08) translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #4a9eff33;z-index:20}.workflow-item.dragging{cursor:grabbing;z-index:100;transform:scale(1.15) rotate(2deg);box-shadow:var(--shadow-glow),0 10px 30px #00000080;opacity:.95;border-width:4px}.workflow-item-handle{width:100%;height:4px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:grab}.workflow-item-content{padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);height:100%;justify-content:center}.workflow-item-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.workflow-item-label{font-size:1rem;font-weight:600;color:var(--text-primary);text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.3)}.workflow-item-order{position:absolute;top:-12px;right:-12px;width:24px;height:24px;background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--text-primary)}.workflow-connections{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.workflow-info{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);text-align:center}.workflow-info p{margin:0;color:var(--text-secondary);font-size:.9rem}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:var(--spacing-2xl)}.dashboard-header h1{font-size:2.5rem;margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.subtitle{font-size:1.1rem;color:var(--text-secondary);margin:0}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:2rem}.stages-overview h2,.projects-section h2,.quick-actions h2{font-size:1.5rem;margin:0 0 var(--spacing-lg) 0;color:var(--text-primary)}.stages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.stage-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border-left:4px solid;box-shadow:var(--shadow-md);transition:all .4s cubic-bezier(.16,1,.3,1);border:1px solid var(--glass-border);position:relative;overflow:hidden}.stage-card:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(74,158,255,.05) 0%,transparent 100%);opacity:0;transition:opacity .4s ease}.stage-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl);border-color:#4a9eff66}.stage-card:hover:after{opacity:1}.stage-card h3{margin:0 0 var(--spacing-sm) 0;font-size:1.25rem;color:var(--text-primary)}.stage-card p{margin:0 0 var(--spacing-lg) 0;color:var(--text-secondary);line-height:1.5}.stage-roles{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.stage-roles strong{display:block;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:.9rem}.stage-roles ul{list-style:none;padding:0;margin:0}.stage-roles li{padding:var(--spacing-xs) 0;color:var(--text-secondary);font-size:.9rem}.projects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.project-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.16,1,.3,1);border:1px solid var(--glass-border);cursor:pointer;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.project-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl);border-color:#4a9eff66}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.project-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.project-desc{color:var(--text-secondary);font-size:.9rem;margin:0 0 var(--spacing-md) 0;line-height:1.5}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;text-transform:capitalize;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color)}.status-badge.active{background:var(--accent-primary);color:var(--text-primary);border-color:var(--accent-primary)}.project-meta{display:flex;gap:var(--spacing-lg);color:var(--text-tertiary);font-size:.85rem}.empty-projects{padding:var(--spacing-xl);text-align:center;color:var(--text-secondary);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.empty-projects:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg)}.action-btn{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-base);font-size:.9rem;color:var(--text-primary)}.action-btn:hover{border-color:var(--accent-primary);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-icon{font-size:2rem}.workflow-section{margin-top:var(--spacing-2xl);grid-column:1 / -1}.workflow-header-section{margin-bottom:var(--spacing-lg);text-align:center}.workflow-header-section h2{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:1.75rem}.workflow-header-section p{margin:0;color:var(--text-secondary);font-size:1rem}.projects-page{max-width:1400px;margin:0 auto}.projects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.projects-header h1{margin:0}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.project-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:var(--spacing-md);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.project-card:hover{box-shadow:var(--shadow-xl);border-color:#4a9eff66;transform:translateY(-6px) scale(1.02)}.project-card:hover:before{opacity:1}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start}.project-card-header h3{margin:0;font-size:1.25rem;color:var(--text-primary);flex:1}.project-actions{display:flex;gap:var(--spacing-xs)}.btn-icon-small{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-base)}.btn-icon-small:hover{background:var(--bg-elevated);color:var(--accent-danger)}.project-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.project-meta{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-tertiary)}.project-stage{text-transform:capitalize;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.project-date{color:var(--text-tertiary)}.project-open-btn{width:100%;margin-top:auto}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden;animation:slide-in-fade .6s cubic-bezier(.16,1,.3,1)}.empty-state:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(74,158,255,.3))}.empty-state h2{margin-bottom:var(--spacing-md);color:var(--text-primary)}.empty-state p{margin-bottom:var(--spacing-xl);color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn .3s ease-out}.modal-content{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:500px;width:100%;border:1px solid var(--glass-border);box-shadow:var(--shadow-xl),0 0 50px #4a9eff33;animation:slide-in-fade .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.modal-content h2{margin:0 0 var(--spacing-lg) 0}.modal-content .form-group{margin-bottom:var(--spacing-lg)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl)}.delete-modal{max-width:500px}.delete-modal p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.impact-analysis{background:#e74c3c1a;border:1px solid var(--accent-danger);border-radius:var(--radius-md);padding:var(--spacing-md);margin:var(--spacing-lg) 0}.impact-analysis strong{color:var(--accent-danger);display:block;margin-bottom:var(--spacing-sm)}.impact-analysis ul{margin:0;padding-left:var(--spacing-lg);color:var(--text-secondary)}.impact-analysis li{margin-bottom:var(--spacing-xs)}.btn-danger{background-color:var(--accent-danger);color:var(--text-primary)}.btn-danger:hover{background-color:#c83c2d}textarea.input{resize:vertical;font-family:inherit}.project-workspace{max-width:1200px;margin:0 auto}.workspace-loading{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}.workspace-header{margin-bottom:var(--spacing-2xl)}.workspace-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.workspace-description{color:var(--text-secondary);font-size:1rem;margin:0}.workspace-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.workspace-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);transition:all .4s cubic-bezier(.16,1,.3,1);cursor:pointer;position:relative;display:flex;flex-direction:column;gap:var(--spacing-md);overflow:hidden}.workspace-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(74,158,255,.1) 0%,transparent 70%);opacity:0;transition:opacity .4s ease}.workspace-card:hover:not(.disabled){transform:translateY(-8px) scale(1.03);box-shadow:var(--shadow-xl),0 0 30px #4a9eff33;border-color:#4a9eff80}.workspace-card:hover:not(.disabled):before{opacity:1}.workspace-card .card-icon{transition:all .3s ease}.workspace-card:hover:not(.disabled) .card-icon{transform:scale(1.2) rotate(5deg);filter:drop-shadow(0 0 10px rgba(74,158,255,.5))}.workspace-card.disabled{opacity:.5;cursor:not-allowed}.card-icon{font-size:3rem;margin-bottom:var(--spacing-sm)}.workspace-card h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.workspace-card p{margin:0;color:var(--text-secondary);font-size:.9rem}.card-status{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem}.card-status.complete{background:var(--accent-success);color:var(--text-primary)}.card-status.pending{background:var(--bg-elevated);border:2px solid var(--border-color);color:var(--text-tertiary)}.script-upload-page{max-width:900px;margin:0 auto}.script-upload-header{margin-bottom:var(--spacing-2xl);text-align:center}.script-upload-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.script-upload-header p{color:var(--text-secondary);font-size:1rem;margin:0}.upload-zone{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:2px dashed var(--glass-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.upload-zone:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(74,158,255,.05) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.upload-zone:hover:not(.uploading){border-color:var(--accent-primary);background:var(--gradient-card);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.upload-zone:hover:not(.uploading):before{opacity:1}.upload-zone.dragging{border-color:var(--accent-primary);background:#4a9eff26;border-style:solid;box-shadow:var(--shadow-glow);animation:pulse-glow 1s ease-in-out infinite}.upload-zone.uploading{cursor:not-allowed;opacity:.7}.upload-icon{font-size:4rem;margin-bottom:var(--spacing-md);animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(74,158,255,.4));transition:all .3s ease}.upload-zone:hover:not(.uploading) .upload-icon{transform:scale(1.1);filter:drop-shadow(0 0 30px rgba(74,158,255,.6))}.upload-zone h3{margin:0;color:var(--text-primary);font-size:1.5rem}.upload-zone p{margin:0;color:var(--text-secondary)}.upload-hint{font-size:.85rem;color:var(--text-tertiary);margin-top:var(--spacing-xs)}.upload-progress{width:100%;max-width:400px}.progress-bar{width:100%;height:8px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--spacing-md)}.progress-fill{height:100%;background:var(--accent-primary);transition:width var(--transition-base);border-radius:var(--radius-sm)}.script-info-card{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.script-info{margin-bottom:var(--spacing-lg)}.script-info h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.script-info p{margin:var(--spacing-xs) 0;color:var(--text-secondary);font-size:.9rem}.script-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.script-analysis-section{margin-top:var(--spacing-2xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.script-analysis-header{text-align:center;margin-bottom:var(--spacing-lg)}.script-analysis-header h2{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.script-analysis-header p{margin:0;color:var(--text-secondary)}.script-analysis-table-wrapper{overflow-x:auto}.script-analysis-table{width:100%;border-collapse:collapse;background:var(--bg-elevated);border-radius:var(--radius-md);overflow:hidden}.script-analysis-table thead th{text-align:left;padding:var(--spacing-md);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:#ffffff0a;border-bottom:1px solid var(--glass-border)}.script-analysis-table td{padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.06);color:var(--text-primary);vertical-align:top}.script-analysis-table tbody tr:hover{background:#ffffff08}.script-analysis-empty{text-align:center;color:var(--text-tertiary);padding:var(--spacing-lg)}.script-analysis-type{font-weight:600;color:var(--accent-primary);white-space:nowrap}.script-analysis-name{font-weight:600;color:var(--text-primary);min-width:180px}.script-analysis-details{color:var(--text-secondary)}.upload-options{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.upload-options .form-group{margin-bottom:0}.upload-options label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-weight:500;font-size:.9375rem}.select-wrapper{position:relative;display:inline-block;width:100%}.select-input{width:100%;padding-right:40px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--bg-elevated);cursor:pointer}.select-arrow{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary);font-size:.75rem}.language-detected{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:#6c4ab61a;border:1px solid rgba(108,74,182,.3);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;animation:fadeIn .3s ease-out}.language-detected strong{color:var(--accent-primary)}.entity-detail-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.entity-detail-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);overflow:hidden}.entity-detail-modal-header{padding:var(--spacing-xl);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:flex-start;background:var(--bg-secondary)}.entity-detail-modal-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.modal-subtitle{margin:0;color:var(--text-secondary);font-size:.9rem}.entity-detail-modal-content{padding:var(--spacing-xl);overflow-y:auto;flex:1}.detail-section-divider{margin:var(--spacing-xl) 0 var(--spacing-lg) 0;padding-top:var(--spacing-lg);border-top:2px solid var(--border-color)}.detail-section-divider:first-child{margin-top:0;padding-top:0;border-top:none}.detail-section-divider h3{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.1rem}.section-hint{margin:0;color:var(--text-tertiary);font-size:.85rem;font-style:italic}.detail-field-group{margin-bottom:var(--spacing-lg)}.detail-label{display:block;margin-bottom:var(--spacing-xs);color:var(--text-primary);font-weight:500;font-size:.95rem}.detail-input,.detail-select,.detail-textarea{width:100%;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition-base)}.detail-input:focus,.detail-select:focus,.detail-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab626}.detail-input-large{font-size:1.1rem;font-weight:500}.detail-textarea{resize:vertical;min-height:100px;line-height:1.6}.detail-textarea-large{min-height:300px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.7}.detail-fields-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.prompt-stats{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xs);font-size:.85rem;color:var(--text-tertiary)}.entity-detail-modal-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-md);background:var(--bg-secondary)}.relationships-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.relationship-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color)}.relationship-type{font-weight:600;color:var(--text-secondary);min-width:80px}.relationship-to{flex:1;color:var(--text-primary)}.detail-remove-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px 6px;font-size:1.2rem;line-height:1;border-radius:var(--radius-sm)}.detail-remove-btn:hover{color:var(--accent-danger, #dc3545);background:#dc35451a}.relationship-add{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;align-items:center;margin-top:var(--spacing-sm)}.relationship-add .detail-input-sm{flex:1;min-width:100px}.detail-input-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem}.suggested-shots-list{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:320px;overflow-y:auto}.suggested-shot-item{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md)}.suggested-shot-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.suggested-shot-num{font-weight:600;color:var(--accent-primary);font-size:.9rem}.suggested-shot-meta{font-size:.85rem;color:var(--text-secondary)}.suggested-shot-purpose{margin:0 0 var(--spacing-xs) 0;font-size:.9rem;color:var(--text-primary)}.suggested-shot-description{margin:0 0 var(--spacing-xs) 0;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.suggested-shot-details{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);font-size:.85rem;color:var(--text-tertiary)}.suggested-shot-details span{white-space:nowrap}.suggested-shot-purpose.content-rtl,.suggested-shot-description.content-rtl{direction:rtl;text-align:right;unicode-bidi:embed}.prompt-editor-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10001;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.prompt-editor-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);overflow:hidden}.prompt-editor-modal-header{padding:var(--spacing-xl);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:flex-start;background:var(--bg-secondary)}.prompt-editor-modal-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.modal-subtitle{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary);font-size:.9rem}.system-prompt-section{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-tertiary);border-left:3px solid var(--accent-primary);border-radius:var(--radius-md)}.system-prompt-label{margin-bottom:var(--spacing-xs);color:var(--text-primary);font-size:.85rem}.system-prompt-content{color:var(--text-secondary);font-size:.85rem;line-height:1.6;font-style:italic;white-space:pre-wrap;word-wrap:break-word}.close-btn{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-base)}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.prompt-editor-modal-content{padding:var(--spacing-xl);overflow-y:auto;flex:1}.prompt-editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.prompt-editor-info{background:var(--bg-tertiary);border-left:4px solid var(--accent-primary);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);border-radius:var(--radius-md)}.prompt-editor-info p{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:.9rem;line-height:1.5}.prompt-stats{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm);font-size:.85rem;flex-wrap:wrap}.prompt-stats span{color:var(--text-secondary)}.prompt-stats span.warning{color:#ff6b6b;font-weight:500}.prompt-stats span.success{color:#2ed573;font-weight:500}.prompt-editor-field{margin-bottom:var(--spacing-lg)}.prompt-editor-label{display:block;margin-bottom:var(--spacing-xs);color:var(--text-primary);font-weight:500;font-size:.95rem}.prompt-editor-textarea{width:100%;padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:Courier New,monospace;line-height:1.7;resize:vertical;min-height:300px;transition:all var(--transition-base)}.prompt-editor-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab626}.prompt-preview-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.prompt-preview-section h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1rem}.prompt-preview-content{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);font-family:Courier New,monospace;font-size:.9rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto}.prompt-editor-modal-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-md);background:var(--bg-secondary)}.global-context-card{background:linear-gradient(135deg,#1e293bf2,#0f172afa);border-radius:16px;border:1px solid rgba(148,163,184,.1);overflow:hidden;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #94a3b80d,inset 0 1px #ffffff0d;transition:all .3s ease}.global-context-card:hover{box-shadow:0 10px 15px -3px #00000026,0 4px 6px -2px #0000001a,0 0 0 1px #94a3b81a,inset 0 1px #ffffff0d}.global-context-card.rtl{direction:rtl;text-align:right}.gc-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;background:linear-gradient(90deg,#3b82f61a,#8b5cf61a);border-bottom:1px solid rgba(148,163,184,.1);transition:background .3s ease}.gc-header:hover{background:linear-gradient(90deg,#3b82f626,#8b5cf626)}.gc-header-left{display:flex;align-items:center;gap:12px}.gc-icon{font-size:1.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.gc-title{font-size:1.25rem;font-weight:700;color:#f1f5f9;margin:0;letter-spacing:-.025em}.gc-subtitle{font-size:.875rem;color:#94a3b8;margin-left:12px;padding-left:12px;border-left:1px solid rgba(148,163,184,.2)}.rtl .gc-subtitle{margin-left:0;margin-right:12px;padding-left:0;padding-right:12px;border-left:none;border-right:1px solid rgba(148,163,184,.2)}.gc-expand-icon{color:#94a3b8;font-size:.875rem;transition:transform .3s ease}.gc-expand-icon.expanded{transform:rotate(180deg)}.gc-content{padding:0;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.gc-tabs{display:flex;gap:4px;padding:12px 24px;background:#0f172a80;border-bottom:1px solid rgba(148,163,184,.1)}.gc-tab{padding:10px 20px;font-size:.875rem;font-weight:500;color:#94a3b8;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.gc-tab:hover{color:#e2e8f0;background:#94a3b81a}.gc-tab.active{color:#fff;background:linear-gradient(135deg,#3b82f64d,#8b5cf64d);box-shadow:0 2px 8px #3b82f633}.gc-tab-content{padding:24px}.gc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}@media(max-width:768px){.gc-grid{grid-template-columns:1fr}}.gc-info-card{display:flex;gap:16px;padding:20px;background:#1e293b99;border-radius:12px;border:1px solid rgba(148,163,184,.08);transition:all .2s ease}.gc-info-card:hover{border-color:#94a3b826;background:#1e293bcc;transform:translateY(-2px)}.gc-card-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f626,#8b5cf626);border-radius:12px;flex-shrink:0}.gc-time-period .gc-card-icon{background:linear-gradient(135deg,#fbbf2426,#f59e0b26)}.gc-setting .gc-card-icon{background:linear-gradient(135deg,#22c55e26,#10b98126)}.gc-genre .gc-card-icon{background:linear-gradient(135deg,#ec489926,#db277726)}.gc-tone .gc-card-icon{background:linear-gradient(135deg,#8b5cf626,#7c3aed26)}.gc-card-content{flex:1;min-width:0}.gc-card-content h3{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}.gc-card-value{font-size:1.125rem;font-weight:600;color:#f1f5f9;margin-bottom:4px}.gc-year{font-size:.875rem;color:#94a3b8;margin-left:8px}.gc-card-sub{font-size:.875rem;color:#94a3b8;margin-bottom:8px}.confidence-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:500;border-radius:20px;margin-top:8px}.evidence-list{margin-top:12px;padding-top:12px;border-top:1px solid rgba(148,163,184,.1);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.evidence-label{font-size:.75rem;color:#64748b;font-weight:500}.evidence-item{font-size:.75rem;color:#94a3b8;background:#94a3b81a;padding:4px 10px;border-radius:6px;font-style:italic}.evidence-more{font-size:.75rem;color:#64748b}.gc-quick-stats{display:flex;justify-content:center;gap:32px;padding:20px;background:#0f172a66;border-radius:12px;margin-bottom:24px}.gc-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.gc-stat-icon{font-size:1.25rem;opacity:.8}.gc-stat-value{font-size:1.5rem;font-weight:700;color:#f1f5f9;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gc-stat-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.gc-entity-list{margin-bottom:16px}.gc-entity-list h4{font-size:.875rem;font-weight:600;color:#e2e8f0;margin:0 0 12px}.gc-entity-tags{display:flex;flex-wrap:wrap;gap:8px}.gc-entity-tag{padding:6px 14px;font-size:.875rem;font-weight:500;border-radius:20px;transition:all .2s ease}.gc-entity-tag:hover{transform:translateY(-1px)}.gc-entity-character{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.2)}.gc-entity-character:hover{background:#3b82f640}.gc-entity-location{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.2)}.gc-entity-location:hover{background:#22c55e40}.gc-visual-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}@media(max-width:768px){.gc-visual-grid{grid-template-columns:1fr}}.gc-visual-card{padding:20px;background:#1e293b99;border-radius:12px;border:1px solid rgba(148,163,184,.08)}.gc-visual-card-wide{grid-column:span 2}@media(max-width:768px){.gc-visual-card-wide{grid-column:span 1}}.gc-visual-icon{font-size:1.5rem;margin-bottom:12px}.gc-visual-card h3{font-size:.875rem;font-weight:600;color:#e2e8f0;margin:0 0 8px}.gc-visual-card p{font-size:.875rem;color:#94a3b8;margin:0;line-height:1.6}.gc-props-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.gc-prop-tag{padding:4px 12px;font-size:.8125rem;background:#94a3b81a;color:#94a3b8;border-radius:6px}.gc-visual-note{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#3b82f61a;border-radius:10px;border:1px solid rgba(59,130,246,.2)}.gc-visual-note-icon{font-size:1.25rem;flex-shrink:0}.gc-visual-note p{font-size:.875rem;color:#94a3b8;margin:0;line-height:1.5}.gc-narrative-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:768px){.gc-narrative-grid{grid-template-columns:1fr}}.gc-narrative-card{padding:20px;background:#1e293b99;border-radius:12px;border:1px solid rgba(148,163,184,.08)}.gc-narrative-card-wide{grid-column:span 2}.gc-narrative-card-full{grid-column:1 / -1}@media(max-width:768px){.gc-narrative-card-wide,.gc-narrative-card-full{grid-column:span 1}}.gc-narrative-card h3{font-size:.875rem;font-weight:600;color:#94a3b8;margin:0 0 12px}.gc-narrative-value{font-size:1.125rem;font-weight:600;color:#f1f5f9}.gc-themes-list{display:flex;flex-wrap:wrap;gap:8px}.gc-theme-tag{padding:6px 14px;font-size:.875rem;font-weight:500;background:#8b5cf626;color:#a78bfa;border-radius:20px;border:1px solid rgba(139,92,246,.2)}.gc-synopsis{font-size:.9375rem;color:#cbd5e1;line-height:1.7;white-space:pre-wrap}.global-context-card.collapsed .gc-content{display:none}.gc-info-card,.gc-visual-card,.gc-narrative-card{animation:fadeInUp .3s ease forwards;opacity:0}.gc-info-card:nth-child(1){animation-delay:.05s}.gc-info-card:nth-child(2){animation-delay:.1s}.gc-info-card:nth-child(3){animation-delay:.15s}.gc-info-card:nth-child(4){animation-delay:.2s}.gc-visual-card:nth-child(1){animation-delay:.05s}.gc-visual-card:nth-child(2){animation-delay:.1s}.gc-visual-card:nth-child(3){animation-delay:.15s}.gc-visual-card:nth-child(4){animation-delay:.2s}.gc-visual-card:nth-child(5){animation-delay:.25s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.shot-breakdown-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.shot-breakdown-overlay.rtl{direction:rtl}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shot-breakdown-modal{background:linear-gradient(180deg,#1a1a2e,#16213e);border-radius:20px;width:95%;max-width:1400px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0009,0 0 60px #6366f11a,inset 0 1px #ffffff0d;border:1px solid rgba(255,255,255,.08);animation:slideUp .3s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.shot-breakdown-header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;background:linear-gradient(90deg,#6366f126,#8b5cf61a);border-bottom:1px solid rgba(255,255,255,.08)}.header-title-section{display:flex;align-items:center;gap:16px}.header-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;font-size:24px;box-shadow:0 8px 20px #6366f166}.header-text h2{color:#fff;font-size:1.4rem;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}.shot-count-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;background:#6366f133;border-radius:20px;font-size:.8rem;color:#a5b4fc;font-weight:500}.close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#94a3b8;font-size:18px;cursor:pointer;transition:all .2s ease}.close-btn:hover{background:#ef444433;border-color:#ef444466;color:#ef4444}.scene-navigation{display:flex;align-items:center;justify-content:center;gap:20px;padding:14px 28px;background:#0003;border-bottom:1px solid rgba(255,255,255,.05)}.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:8px;color:#a5b4fc;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.nav-btn:hover:not(:disabled){background:#6366f133;border-color:#6366f180;color:#c7d2fe}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.scene-indicator{color:#94a3b8;font-size:.9rem;font-weight:500}.view-mode-controls{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:#00000026;border-bottom:1px solid rgba(255,255,255,.05)}.view-mode-tabs{display:flex;gap:4px;background:#0000004d;padding:4px;border-radius:10px}.view-mode-tab{padding:10px 18px;background:transparent;border:none;border-radius:8px;color:#94a3b8;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.view-mode-tab:hover{background:#ffffff0d;color:#e2e8f0}.view-mode-tab.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f166}.view-mode-actions{display:flex;gap:12px}.btn{padding:10px 18px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;box-shadow:0 4px 15px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#e2e8f0}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-lg{padding:14px 28px;font-size:1rem}.shot-error-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#ef444426;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.9rem}.shot-error-banner button{background:transparent;border:none;color:#fca5a5;cursor:pointer;font-size:14px;padding:4px 8px}.shot-breakdown-content{flex:1;overflow-y:auto;padding:24px;background:#0000001a}.shot-breakdown-content::-webkit-scrollbar{width:8px}.shot-breakdown-content::-webkit-scrollbar-track{background:#0003}.shot-breakdown-content::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}.shot-breakdown-content::-webkit-scrollbar-thumb:hover{background:#6366f180}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-state p,.empty-state p{color:#94a3b8;font-size:1rem;margin:8px 0}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.7}.empty-state h3{color:#e2e8f0;font-size:1.4rem;margin:0 0 12px}.storyboard-view{display:flex;flex-direction:column;gap:20px}.shot-card.storyboard-card{background:linear-gradient(145deg,#1e293bcc,#0f172ae6);border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;transition:all .3s ease}.shot-card.storyboard-card:hover{border-color:#6366f14d;box-shadow:0 8px 30px #0000004d}.shot-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#0003;border-bottom:1px solid rgba(255,255,255,.05)}.shot-number{display:flex;align-items:center;gap:10px}.number-badge{padding:6px 14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;letter-spacing:.05em}.confidence-badge{padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase}.confidence-badge.high{background:#22c55e33;color:#4ade80}.confidence-badge.medium{background:#fbbf2433;color:#fbbf24}.confidence-badge.low{background:#ef444433;color:#f87171}.shot-actions{display:flex;gap:8px}.action-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s ease}.action-btn.edit:hover{background:#6366f133;border-color:#6366f166}.action-btn.delete:hover{background:#ef444433;border-color:#ef444466}.shot-card-body{display:grid;grid-template-columns:280px 1fr;gap:24px;padding:20px}.shot-visual-section{display:flex;flex-direction:column;gap:12px}.shot-thumbnail{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.shot-placeholder{width:100%;aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(145deg,#1e293b99,#0f172acc);border:2px dashed rgba(99,102,241,.3);border-radius:12px;color:#64748b}.placeholder-icon{font-size:32px;margin-bottom:8px;opacity:.6}.placeholder-text{font-size:.85rem;font-weight:500}.generate-image-btn{padding:10px 16px;background:linear-gradient(135deg,#6366f133,#8b5cf633);border:1px solid rgba(99,102,241,.3);border-radius:8px;color:#a5b4fc;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.generate-image-btn:hover:not(:disabled){background:linear-gradient(135deg,#6366f14d,#8b5cf64d);border-color:#6366f180}.generate-image-btn:disabled{opacity:.6;cursor:not-allowed}.shot-details-section{display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;flex-wrap:wrap;gap:16px}.detail-row.primary{padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.06)}.detail-row.secondary{padding-bottom:10px}.detail-item{display:flex;flex-direction:column;gap:4px;min-width:140px}.detail-item.wide{flex:1;min-width:200px}.detail-icon{font-size:14px;opacity:.8}.detail-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-weight:600}.detail-value{font-size:.95rem;color:#e2e8f0;font-weight:500}.shot-description{padding:14px 16px;background:#00000026;border-radius:10px;margin-top:8px}.shot-description p{color:#cbd5e1;font-size:.9rem;line-height:1.6;margin:0}.image-prompt-section,.director-notes{padding:14px 16px;background:#6366f10d;border:1px solid rgba(99,102,241,.15);border-radius:10px;margin-top:8px}.prompt-header,.notes-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.prompt-text,.notes-text{color:#a5b4fc;font-size:.85rem;line-height:1.6;font-family:Monaco,Menlo,monospace}.transition-indicator{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 0}.transition-line{flex:1;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.4),transparent)}.transition-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:20px}.transition-icon{font-size:14px}.transition-type{color:#a5b4fc;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.transition-desc{color:#64748b;font-size:.75rem;font-style:italic}.timeline-view{display:flex;flex-direction:column;gap:16px}.timeline-header{padding:0 120px 0 160px;position:relative;height:30px}.timeline-scale{position:relative;width:100%;height:100%}.scale-mark{position:absolute;transform:translate(-50%);color:#64748b;font-size:.75rem;font-weight:500}.timeline-tracks{display:flex;flex-direction:column;gap:8px}.timeline-row{display:flex;align-items:center;gap:16px}.timeline-shot-label{width:140px;display:flex;align-items:center;gap:10px;padding:8px 12px;background:#1e293b80;border-radius:8px;flex-shrink:0}.shot-num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:6px;color:#fff;font-size:.8rem;font-weight:700}.shot-type-icon{font-size:16px}.shot-type-abbr{color:#94a3b8;font-size:.8rem;font-weight:600}.timeline-bar-container{flex:1;display:flex;align-items:center;position:relative}.timeline-bar{height:44px;border-radius:8px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;cursor:pointer;transition:all .2s ease;min-width:60px}.timeline-bar:hover{transform:scaleY(1.05);box-shadow:0 4px 15px #0000004d}.timeline-bar.establishing,.timeline-bar.wide{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.timeline-bar.medium,.timeline-bar.medium-wide,.timeline-bar.medium-close-up{background:linear-gradient(135deg,#6366f1,#4f46e5)}.timeline-bar.close-up,.timeline-bar.extreme-close-up{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.timeline-bar.insert,.timeline-bar.pov{background:linear-gradient(135deg,#ec4899,#db2777)}.timeline-bar.over-shoulder,.timeline-bar.two-shot{background:linear-gradient(135deg,#14b8a6,#0d9488)}.timeline-bar.default{background:linear-gradient(135deg,#64748b,#475569)}.bar-label{color:#fff;font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.bar-duration{color:#ffffffb3;font-size:.75rem;font-weight:500}.timeline-transition{position:absolute;right:-20px;display:flex;align-items:center;justify-content:center}.transition-marker{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#1e293bcc;border:1px solid rgba(99,102,241,.3);border-radius:50%;font-size:12px}.timeline-legend{display:flex;flex-wrap:wrap;gap:16px;padding:16px 20px;background:#0003;border-radius:10px;margin-top:16px}.legend-item{display:flex;align-items:center;gap:8px;color:#94a3b8;font-size:.8rem}.legend-color{width:16px;height:16px;border-radius:4px}.legend-color.establishing,.legend-color.wide{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.legend-color.medium{background:linear-gradient(135deg,#6366f1,#4f46e5)}.legend-color.close-up{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.legend-color.insert{background:linear-gradient(135deg,#ec4899,#db2777)}.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.shot-card.grid-card{background:linear-gradient(145deg,#1e293bcc,#0f172ae6);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease}.shot-card.grid-card:hover{transform:translateY(-4px);border-color:#6366f166;box-shadow:0 12px 30px #0006}.grid-card-visual{position:relative;aspect-ratio:16/9}.grid-thumbnail{width:100%;height:100%;object-fit:cover}.grid-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#1e293b99,#0f172acc);font-size:32px;opacity:.5}.grid-overlay{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:linear-gradient(transparent,#000c)}.grid-shot-num{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:6px;color:#fff;font-size:.75rem;font-weight:700}.grid-shot-type{padding:4px 8px;background:#0009;border-radius:4px;color:#e2e8f0;font-size:.7rem;font-weight:600}.grid-card-info{display:flex;align-items:center;justify-content:space-between;padding:10px 12px}.grid-duration{color:#94a3b8;font-size:.8rem;font-weight:500}.grid-actions{display:flex;gap:6px}.mini-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease}.mini-btn:hover:not(:disabled){background:#6366f133;border-color:#6366f166}.mini-btn.delete:hover{background:#ef444433;border-color:#ef444466}.mini-btn:disabled{opacity:.5;cursor:not-allowed}.shot-breakdown-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:#00000040;border-top:1px solid rgba(255,255,255,.06)}.footer-info{display:flex;gap:16px}.info-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#6366f11a;border-radius:8px;color:#a5b4fc;font-size:.85rem;font-weight:500}.footer-actions{display:flex;gap:12px}.shot-edit-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2100}.shot-edit-form{background:linear-gradient(180deg,#1a1a2e,#16213e);border-radius:16px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0009,0 0 60px #6366f126;border:1px solid rgba(255,255,255,.1);overflow:hidden}.shot-edit-form.rtl{direction:rtl}.edit-form-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background:#6366f11a;border-bottom:1px solid rgba(255,255,255,.08)}.edit-form-header h3{color:#fff;font-size:1.2rem;font-weight:600;margin:0}.edit-form-body{flex:1;overflow-y:auto;padding:24px}.form-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.06)}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section h4{color:#e2e8f0;font-size:1rem;font-weight:600;margin:0 0 16px;display:flex;align-items:center;gap:8px}.form-row{display:flex;gap:16px;margin-bottom:14px}.form-row:last-child{margin-bottom:0}.form-group{flex:1;display:flex;flex-direction:column;gap:6px}.form-group.wide{flex:1 1 100%}.form-group label{color:#94a3b8;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e2e8f0;font-size:.9rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f180;box-shadow:0 0 0 3px #6366f11a}.form-group input::placeholder,.form-group textarea::placeholder{color:#64748b}.form-group select{cursor:pointer}.form-group select option{background:#1e293b;color:#e2e8f0}.form-group textarea{resize:vertical;min-height:60px;font-family:inherit}.edit-form-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;background:#0003;border-top:1px solid rgba(255,255,255,.06)}@media(max-width:1200px){.shot-card-body{grid-template-columns:220px 1fr;gap:20px}}@media(max-width:900px){.shot-card-body{grid-template-columns:1fr}.shot-visual-section{max-width:400px}.view-mode-controls{flex-direction:column;gap:14px}.detail-row{flex-direction:column;gap:12px}.detail-item{min-width:auto}.timeline-header{padding-left:100px}.timeline-shot-label{width:90px}.form-row{flex-direction:column}}@media(max-width:640px){.shot-breakdown-modal{width:100%;max-width:100%;max-height:100%;border-radius:0}.shot-breakdown-header{padding:16px 20px}.header-icon{width:40px;height:40px;font-size:20px}.header-text h2{font-size:1.1rem}.scene-navigation{flex-direction:column;gap:10px;padding:12px 20px}.nav-btn,.view-mode-tabs{width:100%;justify-content:center}.view-mode-tab{flex:1;text-align:center;padding:10px 12px;font-size:.8rem}.view-mode-actions{width:100%;flex-direction:column}.view-mode-actions .btn{width:100%;justify-content:center}.grid-view{grid-template-columns:repeat(2,1fr);gap:12px}.shot-breakdown-content{padding:16px}.footer-info{flex-direction:column;gap:8px}.shot-edit-form{width:100%;max-width:100%;max-height:100%;border-radius:0}}.shot-breakdown-overlay.rtl .shot-breakdown-modal{direction:rtl}.shot-breakdown-overlay.rtl .header-title-section,.shot-breakdown-overlay.rtl .shot-card-header,.shot-breakdown-overlay.rtl .scene-navigation,.shot-breakdown-overlay.rtl .nav-btn:first-child{flex-direction:row-reverse}.shot-breakdown-overlay.rtl .nav-btn:last-child{flex-direction:row-reverse}.shot-breakdown-overlay.rtl .detail-row,.shot-breakdown-overlay.rtl .timeline-row{flex-direction:row-reverse}.shot-breakdown-overlay.rtl .bar-label{text-align:right}.shot-breakdown-overlay.rtl .transition-indicator{flex-direction:row-reverse}.analysis-page{max-width:100%;margin:0 auto;position:relative;display:flex;gap:var(--spacing-xl);align-items:flex-start}.analysis-page.with-chat{max-width:100%}.analysis-content{flex:1;min-width:0}.analysis-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.analysis-status{text-align:center;padding:var(--spacing-2xl);max-width:600px;margin:0 auto}.analysis-spinner{font-size:4rem;margin-bottom:var(--spacing-lg);animation:float 3s ease-in-out infinite,pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(74,158,255,.5))}.analysis-status h2{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.analysis-status p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.progress-bar{width:100%;height:8px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden;margin:var(--spacing-lg) 0}.progress-fill{height:100%;background:var(--gradient-accent);transition:width .3s cubic-bezier(.16,1,.3,1);border-radius:var(--radius-sm);box-shadow:0 0 10px #4a9eff80;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer-effect 2s infinite}.progress-text{color:var(--text-tertiary);font-size:.9rem}.analysis-header{margin-bottom:var(--spacing-2xl);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.analysis-header>div{flex:1;text-align:center}.analysis-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.analysis-header p{color:var(--text-secondary);margin:0}.language-badge{margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:#6c4ab61a;border:1px solid rgba(108,74,182,.3);border-radius:var(--radius-md);display:inline-block;font-size:.9rem;color:var(--text-primary)}.language-badge strong{color:var(--accent-primary)}.analysis-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);text-align:center;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.stat-card-link{cursor:pointer;font:inherit;color:inherit;width:100%}.stat-card-link:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.stat-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;margin:0 auto var(--spacing-md) auto;color:var(--accent-primary);opacity:.9}.stat-card-icon svg{width:100%;height:100%}.stat-card-link:hover .stat-card-icon{opacity:1;color:var(--accent-primary-hover)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.stat-card:hover{transform:translateY(-4px) scale(1.05);box-shadow:var(--shadow-lg);border-color:#4a9eff66}.stat-card:hover:before{opacity:1}.stat-value{font-size:2.5rem;font-weight:700;color:var(--accent-primary);margin-bottom:var(--spacing-xs)}.stat-label{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.analysis-options-bar{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--glass-border)}.analysis-options-label{color:var(--text-secondary);font-size:.9rem;margin-right:var(--spacing-xs)}.analysis-option-radio{display:inline-flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:.95rem;color:var(--text-primary)}.analysis-option-radio input{cursor:pointer}.analysis-sections{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.analysis-table-wrapper{overflow-x:auto}.analysis-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);overflow:hidden}.analysis-table thead th{text-align:left;padding:var(--spacing-md);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:#ffffff0a;border-bottom:1px solid var(--glass-border)}.analysis-table td{padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.06);color:var(--text-primary);vertical-align:top}.analysis-table tbody tr:hover{background:#ffffff08}.analysis-table-empty{text-align:center;color:var(--text-tertiary);padding:var(--spacing-lg)}.analysis-table-type{font-weight:600;color:var(--accent-primary);white-space:nowrap}.analysis-table-name{font-weight:600;color:var(--text-primary);min-width:180px}.analysis-preview{background:var(--gradient-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.analysis-preview .section-header{align-items:center}.analysis-preview-controls{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.analysis-preview-toggle{display:inline-flex;gap:var(--spacing-sm);align-items:center;color:var(--text-secondary);font-size:.9rem}.analysis-preview-toggle input{accent-color:var(--accent-primary)}.analysis-preview-text{margin-top:var(--spacing-md);background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:var(--spacing-lg);white-space:pre-wrap;word-break:break-word;max-height:520px;overflow:auto;color:var(--text-primary);font-family:SFMono-Regular,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;line-height:1.5}.analysis-page.rtl .analysis-content,.analysis-page.rtl .script-chat-sidebar{direction:rtl;text-align:right}.analysis-page.rtl .analysis-preview-text,.analysis-page.rtl .extracted-text-content,.analysis-page.rtl .script-excerpt-text,.analysis-page.rtl .shared-data,.analysis-page.rtl .message-content p{direction:rtl;text-align:right;unicode-bidi:plaintext}.script-excerpt-text.content-rtl,.extracted-text-content.content-rtl{direction:rtl;text-align:right;unicode-bidi:isolate}.script-excerpt-text-rtl,.extracted-text-content-rtl{direction:rtl;text-align:right;unicode-bidi:plaintext}.script-excerpt-note{font-size:.9rem;color:var(--text-secondary, #666);margin:0 0 var(--spacing-sm, 8px) 0}.content-rtl-wrap,.script-excerpt-rtl .script-excerpt-content,.script-excerpt-rtl.content-rtl-wrap{direction:rtl;unicode-bidi:isolate;text-align:right}.analysis-preview-text.content-rtl,.shared-data.content-rtl,.message-content p.content-rtl,.entity-description p.content-rtl,.scene-summary.content-rtl,h3.content-rtl{direction:rtl;text-align:right;unicode-bidi:embed}.analysis-page.rtl .analysis-meta-label,.analysis-page.rtl .analysis-meta-sub,.analysis-page.rtl .stat-label{text-align:right}.analysis-table-details{color:var(--text-secondary)}.analysis-section{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);transition:all .3s ease;position:relative;scroll-margin-top:80px;overflow:hidden}.analysis-section:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.analysis-section:hover:before{opacity:1}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-header h2{margin:0;color:var(--text-primary)}.entity-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-md)}.entity-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:var(--spacing-md);transition:all .3s cubic-bezier(.16,1,.3,1)}.entity-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.entity-card:hover{border-color:#4a9eff66;transform:translateY(-4px);box-shadow:var(--shadow-lg)}.entity-card:hover:before{opacity:1}.entity-card-character{border-left:3px solid rgba(99,102,241,.5)}.entity-card-location{border-left:3px solid rgba(46,213,115,.5)}.entity-card-scene{border-left:3px solid rgba(245,158,11,.5)}.entity-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);flex-wrap:wrap}.entity-card-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary);flex:1;min-width:0}.entity-status-badge{flex-shrink:0;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;white-space:nowrap}.entity-status-badge.created{background:#10b98126;border:1px solid var(--accent-success);color:var(--accent-success)}.entity-card-body{flex:1;min-height:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.entity-description{font-size:.9rem;color:var(--text-secondary);line-height:1.4}.entity-description p{margin:0 0 var(--spacing-xs) 0}.entity-description p:last-child{margin-bottom:0}.entity-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.entity-meta .meta-badge{padding:2px var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary)}.entity-prompt-preview{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8rem}.prompt-preview-header{margin-bottom:var(--spacing-xs);color:var(--text-tertiary)}.prompt-preview-header strong{color:var(--text-secondary)}.prompt-preview-text{color:var(--text-primary);line-height:1.35;word-break:break-word;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.entity-card-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.entity-card-actions .btn{flex:1;min-width:fit-content}.scene-entities-info{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);font-size:.85rem}.scene-entity-item{color:var(--text-secondary)}.scene-entity-item strong{color:var(--text-primary);margin-right:var(--spacing-xs)}.scene-characters-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.character-tag-small{padding:2px var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;background:#6366f126;border:1px solid rgba(99,102,241,.3);color:var(--accent-secondary)}.entity-card .type-badge{margin-left:auto}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.entity-card.slide-up{animation:slide-up .4s ease-out forwards}.global-context-card{margin-bottom:var(--spacing-xl)}.global-context-card:before{opacity:.5}.global-context-card:hover:before{opacity:1}.global-context-card .section-header h2{font-size:1.25rem;font-weight:600;letter-spacing:-.01em}.global-context-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-lg)}.global-context-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.global-context-item.visual-style-block{grid-column:1 / -1}.global-context-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.global-context-value{color:var(--text-primary);font-size:.95rem;line-height:1.5}.global-context-value p{margin:0 0 var(--spacing-xs) 0}.global-context-value p:last-child{margin-bottom:0}.global-context-card .entity-card{border:1px solid var(--glass-border)}.global-context-card .entity-card:before{height:2px}.context-theme-body{display:flex;flex-direction:column;gap:var(--spacing-lg)}.context-theme-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.context-theme-field .global-context-label,.context-theme-field .global-context-label:first-child{margin-top:0}.global-context-card .entity-card .entity-description .global-context-value p,.global-context-card .entity-card .entity-prompt-preview .global-context-value,.global-context-card .entity-card .entity-prompt-preview .prompt-preview-text{font-size:.95rem;line-height:1.5;color:var(--text-primary)}.global-context-card .entity-card .prompt-preview-text{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color)}.characters-context-block{background:linear-gradient(135deg,#1e293bf2,#0f172afa);border-radius:16px;border:1px solid rgba(148,163,184,.1);overflow:hidden;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #94a3b80d,inset 0 1px #ffffff0d;transition:all .3s ease}.characters-context-block:hover{box-shadow:0 10px 15px -3px #00000026,0 4px 6px -2px #0000001a,0 0 0 1px #94a3b81a,inset 0 1px #ffffff0d}.characters-context-block.collapsed .gc-content{display:none}.characters-context-actions{margin-bottom:20px}.characters-context-block .characters-group{margin-bottom:24px}.characters-context-block .characters-group:last-child{margin-bottom:0}.characters-context-block .characters-group h4{font-size:.875rem;font-weight:600;color:#e2e8f0;margin:0 0 12px}.characters-context-block .characters-context-card{background:#1e293b99;border:1px solid rgba(148,163,184,.08);box-shadow:0 2px 4px -1px #0000000f}.characters-context-block .characters-context-card:hover{border-color:#94a3b826;background:#1e293bcc}.characters-context-block .characters-context-card:before{background:linear-gradient(90deg,#3b82f666,#8b5cf666);opacity:0;height:2px}.characters-context-block .characters-context-card:hover:before{opacity:1}.characters-context-block .characters-context-card.entity-card-character{border-left-color:#3b82f659}.locations-context-block{background:linear-gradient(135deg,#1e293bf2,#0f172afa);border-radius:16px;border:1px solid rgba(148,163,184,.1);overflow:hidden;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #94a3b80d,inset 0 1px #ffffff0d;transition:all .3s ease}.locations-context-block:hover{box-shadow:0 10px 15px -3px #00000026,0 4px 6px -2px #0000001a,0 0 0 1px #94a3b81a,inset 0 1px #ffffff0d}.locations-context-block.collapsed .gc-content{display:none}.locations-context-block .locations-context-card{background:#1e293b99;border:1px solid rgba(148,163,184,.08);box-shadow:0 2px 4px -1px #0000000f}.locations-context-block .locations-context-card:hover{border-color:#94a3b826;background:#1e293bcc}.locations-context-block .locations-context-card:before{background:linear-gradient(90deg,#22c55e66,#10b98166);opacity:0;height:2px}.locations-context-block .locations-context-card:hover:before{opacity:1}.locations-context-block .locations-context-card.entity-card-location{border-left-color:#22c55e59}.scenes-context-block{background:linear-gradient(135deg,#1e293bf2,#0f172afa);border-radius:16px;border:1px solid rgba(148,163,184,.1);overflow:hidden;margin-bottom:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #94a3b80d,inset 0 1px #ffffff0d;transition:all .3s ease}.scenes-context-block:hover{box-shadow:0 10px 15px -3px #00000026,0 4px 6px -2px #0000001a,0 0 0 1px #94a3b81a,inset 0 1px #ffffff0d}.scenes-context-block.collapsed .gc-content{display:none}.scenes-context-block .scenes-context-card{background:#1e293b99;border:1px solid rgba(148,163,184,.08);box-shadow:0 2px 4px -1px #0000000f}.scenes-context-block .scenes-context-card:hover{border-color:#94a3b826;background:#1e293bcc}.scenes-context-block .scenes-context-card:before{background:linear-gradient(90deg,#f59e0b66,#fbbf2466);opacity:0;height:2px}.scenes-context-block .scenes-context-card:hover:before{opacity:1}.scenes-context-block .scenes-context-card.entity-card-scene{border-left-color:#f59e0b59}.script-excerpt-card{margin-bottom:var(--spacing-xl)}.script-excerpt-content{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--glass-border)}.script-excerpt-text{margin:0;white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.6;color:var(--text-secondary);max-height:min(60vh,600px);overflow-y:auto}.script-excerpt-meta{margin:var(--spacing-md) 0 0 0;font-size:.85rem;color:var(--text-tertiary)}.characters-grid,.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.character-card,.location-card{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:var(--spacing-lg);border:1px solid var(--glass-border);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-md);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:var(--spacing-md)}.character-card-content{flex:1;cursor:pointer;display:flex;flex-direction:column;gap:var(--spacing-md)}.character-card:before,.location-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:0;transition:opacity .3s ease}.character-card:hover,.location-card:hover{border-color:#4a9eff80;transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl)}.character-card:hover:before,.location-card:hover:before{opacity:1}.character-card-body,.location-card-body{display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;min-width:0}.character-card-header,.location-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);flex-wrap:wrap}.character-card h3,.location-card h3{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600;flex:1;min-width:0}.character-type-badge,.location-type-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:var(--radius-sm);font-weight:600;flex-shrink:0}.character-type-badge.type-human,.location-type-badge.interior{background:#4a9eff33;color:var(--accent-primary)}.character-type-badge.type-animal{background:#4caf5033;color:#81c784}.character-type-badge.type-group{background:#9c27b033;color:#ce93d8}.character-type-badge.type-creature{background:#ff980033;color:#ffb74d}.location-type-badge.exterior{background:#4caf5033;color:#81c784}.character-role,.location-meta{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.character-description,.location-description{margin:0;font-size:.85rem;color:var(--text-tertiary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.character-meta-tag{font-size:.75rem;color:var(--text-tertiary)}.character-hierarchy-item,.character-relationships-block{display:flex;flex-direction:column;gap:var(--spacing-xs)}.character-hierarchy-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.character-hierarchy-value{font-size:.85rem;color:var(--text-secondary)}.character-relationships{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.relationship-tag{font-size:.75rem;padding:2px 6px;background:#ffffff0f;border-radius:var(--radius-sm);color:var(--text-secondary)}.location-key-props{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.location-prop-tag{font-size:.75rem;padding:2px 6px;background:#ffffff0f;border-radius:var(--radius-sm);color:var(--text-tertiary)}.character-preview,.location-preview{position:relative;width:100%;height:200px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.character-preview img,.location-preview img{width:100%;height:100%;object-fit:cover}.character-preview.placeholder,.location-preview.placeholder{background:var(--bg-elevated);border:2px dashed var(--border-color)}.character-preview .placeholder-icon,.location-preview .placeholder-icon{font-size:3rem;color:var(--text-tertiary);opacity:.5}.card-meta{font-size:.85rem;color:var(--text-tertiary)}.character-remove-btn{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:var(--radius-md);color:var(--accent-danger);cursor:pointer;font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0;opacity:0}.character-card:hover .character-remove-btn{opacity:1}.character-remove-btn:hover{background:#e74c3c33;border-color:var(--accent-danger);transform:scale(1.1)}.scenes-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-md);max-height:calc(2 * (180px + var(--spacing-md)));overflow-x:auto;overflow-y:hidden;padding-bottom:var(--spacing-sm);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--accent-primary) var(--bg-elevated);align-content:flex-start}.scenes-list::-webkit-scrollbar{height:8px}.scenes-list::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:var(--radius-sm)}.scenes-list::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-sm)}.scenes-list::-webkit-scrollbar-thumb:hover{background:var(--accent-primary-hover)}.scene-item{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color);transition:all var(--transition-base);width:280px;flex-shrink:0;height:fit-content;min-height:160px;max-height:180px;overflow:hidden;display:flex;flex-direction:column}.scene-item.clickable-scene{cursor:pointer}.scene-item:hover{border-color:var(--accent-primary);transform:translate(4px);box-shadow:var(--shadow-sm)}.scene-item.clickable-scene:hover{background:var(--bg-panel);border-color:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff1a}.scene-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-xs)}.scene-number-badge{background:var(--accent-primary);color:var(--text-primary);padding:2px var(--spacing-xs);border-radius:var(--radius-sm);font-weight:600;font-size:.75rem;white-space:nowrap}.scene-type-badges{display:flex;gap:3px;flex-wrap:wrap;align-items:center}.type-badge{padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;border:1px solid;white-space:nowrap}.type-badge.interior{background:#4a9eff26;border-color:var(--accent-primary);color:var(--accent-primary)}.type-badge.exterior{background:#2ed57326;border-color:#2ed573;color:#2ed573}.time-badge{padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;background:var(--bg-panel);border:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap}.jump-badge{padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;background:#4a9eff33;border:1px solid var(--accent-primary);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-base);animation:pulse-glow 2s ease-in-out infinite;white-space:nowrap}.jump-badge:hover{background:var(--accent-primary);color:var(--text-primary);transform:scale(1.1)}@keyframes pulse-glow{0%,to{box-shadow:0 0 #4a9eff66}50%{box-shadow:0 0 0 4px #4a9eff00}}.scene-item-body h3{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.scene-summary{margin:0 0 var(--spacing-sm) 0;color:var(--text-secondary);font-size:.8rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.scene-details{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.scene-detail-item{display:flex;align-items:flex-start;gap:var(--spacing-xs);font-size:.75rem;line-height:1.3}.scene-detail-item strong{color:var(--text-primary);min-width:70px;flex-shrink:0;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.scene-detail-item span{color:var(--text-secondary);font-size:.75rem;word-break:break-word}.scene-characters-list{display:flex;flex-wrap:wrap;gap:3px}.character-tag{background:var(--bg-panel);border:1px solid var(--border-color);padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.interior-scene{border-left:3px solid var(--accent-primary)}.exterior-scene{border-left:3px solid #2ed573}.script-chat-sidebar{width:400px;flex-shrink:0;height:calc(100vh - 150px);max-height:900px;display:flex;flex-direction:column;background:var(--bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);position:sticky;top:var(--spacing-xl);overflow:hidden;isolation:isolate}.script-chat-sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--gradient-primary);opacity:.6}.chat-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-color);background:var(--bg-elevated);flex-shrink:0;z-index:10}.chat-close-btn{display:none}.chat-sidebar-title h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600;letter-spacing:-.01em}.chat-close-btn{background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);font-size:1.125rem}.chat-close-btn:hover{background:var(--bg-panel);border-color:var(--accent-primary);color:var(--accent-primary);transform:scale(1.05)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-canvas);min-height:0}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:var(--radius-sm)}.chat-messages::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-sm)}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--accent-primary-hover)}.chat-message{display:flex;flex-direction:column;gap:var(--spacing-xs);animation:fadeIn .3s ease-out;width:100%}.chat-message.user{align-items:flex-end}.chat-message.assistant{align-items:flex-start}.message-content{max-width:85%;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);word-wrap:break-word;position:relative}.chat-message.user .message-content{background:var(--accent-primary);color:var(--text-primary);border-bottom-right-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.chat-message.assistant .message-content{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:var(--radius-sm);box-shadow:var(--shadow-xs)}.message-content p{margin:0;line-height:1.6}.message-content pre.shared-data{margin:0;padding:0;background:transparent;color:inherit;font-family:inherit;font-size:.9rem;white-space:pre-wrap;word-wrap:break-word}.message-time{font-size:.75rem;color:var(--text-tertiary);padding:0 var(--spacing-sm)}.chat-sidebar-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color);background:var(--bg-elevated);flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.share-details-btn{width:100%;justify-content:center}.chat-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;transition:all var(--transition-base)}.chat-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab626}.chat-send-btn{padding:var(--spacing-md) var(--spacing-lg);white-space:nowrap;min-width:80px}.chat-toggle-btn{white-space:nowrap}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media(max-width:1200px){.script-chat-sidebar{width:380px}}@media(max-width:1024px){.analysis-page{flex-direction:column}.script-chat-sidebar{width:100%;height:500px;position:relative;top:0;max-height:none}.analysis-content{width:100%}}.extracted-text-preview{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.extracted-text-preview .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.extracted-text-info{background:var(--bg-tertiary);border-left:4px solid var(--accent-primary);padding:var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:var(--radius-md)}.extracted-text-info .text-info{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-weight:500}.extracted-text-info .text-info-list{margin:var(--spacing-sm) 0 0 0;padding-left:var(--spacing-lg);color:var(--text-secondary)}.extracted-text-info .text-info-list li{margin-bottom:var(--spacing-xs)}.extracted-text-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;max-height:600px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word;color:var(--text-primary)}.analysis-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;margin-top:12px}.analysis-meta-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px}.analysis-meta-label{font-size:12px;letter-spacing:.02em;opacity:.8;margin-bottom:6px}.analysis-meta-value{font-size:14px;font-weight:600;line-height:1.3}.analysis-meta-sub{margin-top:6px;font-size:12px;opacity:.8}.meta-badge-type{text-transform:uppercase;letter-spacing:.04em}.meta-badge-human{background:#38bdf826;border-color:#38bdf840}.meta-badge-animal{background:#22c55e26;border-color:#22c55e40}.meta-badge-group{background:#a855f726;border-color:#a855f740}.meta-badge-creature{background:#fb923c26;border-color:#fb923c40}.meta-badge-object{background:#94a3b826;border-color:#94a3b840}.shot-breakdown-btn{background:linear-gradient(135deg,#6366f133,#8b5cf633)!important;border:1px solid rgba(99,102,241,.4)!important;color:#a5b4fc!important;transition:all .2s ease!important}.shot-breakdown-btn:hover{background:linear-gradient(135deg,#6366f14d,#8b5cf64d)!important;border-color:#6366f199!important;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-info{background:linear-gradient(135deg,#0ea5e9,#06b6d4);border:none;color:#fff}.btn-info:hover{background:linear-gradient(135deg,#0284c7,#0891b2)}.scene-shots-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:12px;font-size:.75rem;color:#a5b4fc;margin-top:8px}.scene-shots-indicator .shots-icon{font-size:12px}.scene-shots-indicator .shots-count{font-weight:600}.scene-emotional-arc{color:#c084fc;font-style:italic;margin-top:8px;padding:8px 12px;background:#c084fc1a;border-left:3px solid rgba(192,132,252,.4);border-radius:4px}.scene-shots-preview{margin-top:12px;padding:12px;background:linear-gradient(135deg,#6366f114,#8b5cf614);border:1px solid rgba(99,102,241,.2);border-radius:8px}.shots-preview-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(99,102,241,.2);color:#a5b4fc;font-size:.85rem}.shots-preview-list{display:flex;flex-direction:column;gap:6px}.shot-preview-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;padding:8px 10px;background:#0003;border-radius:6px;transition:background .2s ease}.shot-preview-item:hover{background:#0000004d}.shot-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.shot-preview-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.shot-type-badge{display:inline-block;padding:2px 8px;background:#3b82f633;border:1px solid rgba(59,130,246,.3);border-radius:10px;font-size:.7rem;font-weight:600;color:#60a5fa;text-transform:uppercase;letter-spacing:.5px;width:fit-content}.shot-purpose{font-size:.8rem;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shot-preview-description{width:100%;margin:2px 0 0;padding-left:34px;font-size:.78rem;color:#ffffffbf;line-height:1.35;white-space:normal;word-break:break-word}.shot-preview-prompt{width:100%;margin:2px 0 0;padding-left:34px;font-size:.72rem;color:#94a3b8e6;line-height:1.3;white-space:normal;word-break:break-word}.rtl .shot-preview-description,.rtl .shot-preview-prompt{padding-left:0;padding-right:34px}.shot-emotion{font-size:.75rem;color:#fbbf24;white-space:nowrap;flex-shrink:0}.shot-preview-more{text-align:center;padding:6px;font-size:.75rem;color:#ffffff80;font-style:italic}.rtl .scene-shots-preview{direction:rtl}.rtl .shot-preview-item{flex-direction:row-reverse}.rtl .shot-preview-info{text-align:right;align-items:flex-end}.rtl .scene-emotional-arc{border-left:none;border-right:3px solid rgba(192,132,252,.4)}.generation-canvas{width:100%;min-height:60vh;max-height:65vh;background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);transition:all .3s ease}.generation-canvas:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(74,158,255,.05) 0%,transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.generation-canvas:hover:before{opacity:1}.canvas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-2xl)}.loading-spinner{font-size:4rem;animation:pulse 2s ease-in-out infinite}.canvas-loading h3{margin:0;color:var(--text-primary)}.canvas-loading p{margin:0;color:var(--text-secondary);font-size:.9rem}.canvas-image-container{width:100%;height:100%;display:flex;flex-direction:column;position:relative}.canvas-image{width:100%;height:auto;max-height:calc(65vh - 80px);object-fit:contain;transition:opacity var(--transition-base),transform var(--transition-base);animation:fadeIn var(--transition-base)}.canvas-image:hover{transform:scale(1.02)}.image-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-secondary)}.canvas-actions{padding:var(--spacing-md);display:flex;gap:var(--spacing-md);justify-content:center;background:var(--bg-panel);border-top:1px solid var(--border-color)}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-2xl);color:var(--text-secondary)}.empty-icon{font-size:4rem;opacity:.5}.empty-hint{font-size:.85rem;color:var(--text-tertiary)}.generation-modal{max-width:700px;width:90%;max-height:90vh;overflow-y:auto}.generation-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.generation-modal-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.generation-modal-body{display:flex;flex-direction:column;gap:var(--spacing-xl)}.input-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.section-header{display:flex;justify-content:space-between;align-items:center}.section-header label{font-size:.9rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.btn-add-input{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.85rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-base)}.btn-add-input:hover{background:var(--bg-panel);border-color:var(--accent-primary);color:var(--accent-primary)}.description-inputs{display:flex;flex-direction:column;gap:var(--spacing-md)}.description-input-group{display:flex;align-items:flex-start;gap:var(--spacing-sm);position:relative}.input-number{width:28px;height:28px;background:var(--accent-primary);color:var(--text-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;margin-top:2px}.description-textarea{flex:1;padding:10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;font-family:inherit;resize:vertical;min-height:80px;transition:all .3s cubic-bezier(.4,0,.2,1);line-height:1.5;outline:none}.description-textarea:focus{outline:none;border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.description-textarea::placeholder{color:#ffffff4d;font-style:italic}.btn-remove-input{background:transparent;border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0;margin-top:2px}.btn-remove-input:hover{background:var(--accent-danger);border-color:var(--accent-danger);color:var(--text-primary)}.input-hint{margin:0;color:var(--text-tertiary);font-size:.85rem;font-style:italic}.settings-section{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.setting-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-item label{font-size:.85rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.setting-select{padding:10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;outline:none}.setting-select:focus{outline:none;border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.summary-section{background:#4a9eff1a;border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--accent-primary)}.summary-card{display:flex;flex-direction:column;gap:var(--spacing-sm)}.summary-card strong{color:var(--text-primary);font-size:.9rem}.summary-details{color:var(--text-secondary);font-size:.95rem}.total-count{color:var(--accent-primary);font-weight:600;font-size:1.1rem}.generation-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.generate-btn-modal{min-width:200px;display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600}.generate-btn-modal:disabled{opacity:.6;cursor:not-allowed}.asset-library{margin-top:var(--spacing-xl)}.asset-library-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.empty-hint{font-size:.85rem;color:var(--text-tertiary);margin-top:var(--spacing-xs)}.asset-library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.asset-library-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.asset-count{font-size:.85rem;color:var(--text-tertiary)}.asset-library-scroll{display:flex;gap:var(--spacing-md);overflow-x:auto;padding:var(--spacing-sm) 0;scrollbar-width:thin}.asset-thumbnail{flex-shrink:0;width:120px;height:120px;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--glass-border);cursor:pointer;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-sm)}.asset-thumbnail:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(74,158,255,.3) 0%,transparent 70%);opacity:0;transition:opacity .3s ease;z-index:1}.asset-thumbnail:hover{border-color:var(--accent-primary);transform:scale(1.1) translateY(-4px);box-shadow:var(--shadow-md),0 0 20px #4a9eff66}.asset-thumbnail:hover:before{opacity:1}.asset-thumbnail.selected{border-color:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff4d,var(--shadow-md);transform:scale(1.05);animation:pulse-glow 2s ease-in-out infinite}.asset-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:var(--spacing-sm);opacity:0;transition:opacity var(--transition-base)}.asset-thumbnail:hover .asset-overlay{opacity:1}.asset-name{color:var(--text-primary);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-create-modal{max-width:800px;max-height:90vh;overflow-y:auto}.character-create-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.character-edit-modal{max-width:800px;max-height:90vh;overflow-y:auto}.character-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.character-preview{position:relative;width:100%;max-height:300px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--accent-primary);background:var(--bg-elevated)}.character-preview img{width:100%;height:100%;object-fit:contain}.filter-icon-dropdown{position:relative;display:inline-block}.filter-icon-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;padding:0;color:#fff}.filter-icon-btn:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.filter-icon-btn.has-value{background:#3b82f626;border-color:#3b82f680}.filter-icon-btn.open{background:#3b82f633;border-color:#3b82f699}.filter-icon{font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;color:#fff}.filter-icon-svg{width:18px;height:18px}.filter-icon-svg svg{width:100%;height:100%;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.filter-badge{position:absolute;top:-3px;right:-3px;width:10px;height:10px;background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:50%;border:2px solid rgba(20,20,30,.95);box-shadow:0 0 8px #8b5cf699;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.filter-dropdown-menu{position:absolute;bottom:calc(100% + 10px);left:0;min-width:220px;max-width:280px;background:linear-gradient(135deg,#0a0a14fa,#0f0f1efa);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(139,92,246,.3);border-radius:12px;box-shadow:0 8px 32px #0009,0 0 0 1px #8b5cf61a;z-index:1001;animation:slideUp .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.filter-icon-dropdown:last-child .filter-dropdown-menu,.filter-icon-dropdown:nth-last-child(2) .filter-dropdown-menu,.filter-icon-dropdown:nth-last-child(3) .filter-dropdown-menu{left:auto;right:0}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.filter-dropdown-header{padding:10px 14px;font-size:.75rem;font-weight:700;color:#8b5cf6e6;border-bottom:1px solid rgba(139,92,246,.2);text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#8b5cf61a,#8b5cf60d)}.filter-dropdown-options{max-height:200px;overflow-y:auto}.filter-dropdown-option{padding:12px 14px;font-size:.85rem;color:#ffffffb3;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:space-between;gap:8px;font-weight:500}.filter-dropdown-option:hover{background:linear-gradient(135deg,#8b5cf626,#8b5cf614);color:#fff;padding-left:18px}.filter-dropdown-option.selected{background:linear-gradient(135deg,#8b5cf640,#8b5cf626);color:#c4b5fd;border-left:3px solid rgba(139,92,246,.6)}.check-icon{color:#a78bfa;font-weight:700;font-size:1rem;filter:drop-shadow(0 0 4px rgba(139,92,246,.6))}.filter-dropdown-options::-webkit-scrollbar{width:6px}.filter-dropdown-options::-webkit-scrollbar-track{background:#ffffff0d}.filter-dropdown-options::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.filter-dropdown-options::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.compact-character-controller{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:900px;background:linear-gradient(135deg,#0a0a14bf,#0f0f1ebf);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:10px 16px;display:flex;flex-direction:column;gap:8px;z-index:1000;box-shadow:0 -8px 32px #0009,0 0 0 1px #8b5cf61a,inset 0 1px #ffffff0d;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideUpFade .4s ease-out}.controller-reference-image{display:flex;align-items:center;margin-right:8px}.upload-image-label{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf633,#8b5cf61a);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.upload-image-label:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf64d,#8b5cf633);border-color:#8b5cf680;transform:translateY(-1px)}.upload-image-label svg{width:20px;height:20px;stroke:#c4b5fd;stroke-width:2}.upload-image-label:disabled{opacity:.5;cursor:not-allowed}.reference-image-preview{position:relative;width:40px;height:40px;border-radius:10px;overflow:hidden;border:1.5px solid rgba(139,92,246,.3);flex-shrink:0}.reference-image-preview img{width:100%;height:100%;object-fit:cover}.remove-image-btn{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#ef4444e6;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.remove-image-btn:hover:not(:disabled){background:#ef4444;transform:scale(1.1)}.remove-image-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.compact-character-controller{padding:8px 12px;width:95%}.controller-main-wrapper{gap:8px}.controller-name-input{max-width:150px}.controller-name-input,.controller-prompt-input{font-size:.85rem;padding:8px 12px}.controller-generate-btn{width:40px;height:40px}}.prompt-editor-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin-top:16px}.prompt-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.prompt-editor-title{margin:0;font-size:.95rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:8px}.btn-edit-prompt{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit-prompt:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-edit-prompt svg{width:14px;height:14px}.prompt-comparison{display:flex;flex-direction:column;gap:16px}.prompt-section{display:flex;flex-direction:column;gap:8px}.prompt-label{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.prompt-label-icon{font-size:.9rem}.prompt-badge{margin-left:auto;padding:2px 8px;background:linear-gradient(135deg,#8b5cf633,#3b82f633);border:1px solid rgba(139,92,246,.4);border-radius:4px;font-size:.7rem;color:#c4b5fd;font-weight:600}.prompt-display{padding:12px;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto}.prompt-display.original-prompt{border-left:3px solid rgba(59,130,246,.5)}.prompt-display.enriched-prompt{border-left:3px solid rgba(139,92,246,.5);background:#8b5cf60d}.prompt-display.single-prompt{border-left:3px solid rgba(255,255,255,.2)}.prompt-editor-edit-mode{display:flex;flex-direction:column;gap:12px}.prompt-editor-textarea{width:100%;padding:12px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:8px;color:#fff;font-size:.9rem;font-family:inherit;resize:vertical;min-height:150px;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;line-height:1.6}.prompt-editor-textarea:focus{border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.prompt-editor-textarea::placeholder{color:#ffffff4d;font-style:italic}.prompt-editor-actions{display:flex;gap:8px;justify-content:flex-end}.btn-save-prompt{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#8b5cf6,#6366f1,#3b82f6);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-save-prompt:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.btn-save-prompt:disabled{opacity:.6;cursor:not-allowed}.btn-save-prompt .spinner{animation:spin 1s linear infinite}.btn-cancel-prompt{padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel-prompt:hover:not(:disabled){background:#ffffff14;border-color:#fff3}.btn-cancel-prompt:disabled{opacity:.6;cursor:not-allowed}.prompt-display::-webkit-scrollbar{width:6px}.prompt-display::-webkit-scrollbar-track{background:#ffffff0d}.prompt-display::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.prompt-display::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.character-detail-page{max-width:1600px;margin:0 auto}.character-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.character-header .header-actions{display:flex;gap:var(--spacing-md);align-items:center}.character-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.character-info h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.character-description{color:var(--text-secondary);font-size:1rem;margin:0 0 var(--spacing-md) 0;line-height:1.6}.character-meta{font-size:.9rem;color:var(--text-tertiary);display:flex;gap:var(--spacing-md);align-items:center}.characters-list-view{width:100%}.characters-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.characters-list-header h1{margin:0;color:var(--text-primary)}.characters-list-view .empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden;animation:slide-in-fade .6s cubic-bezier(.16,1,.3,1)}.characters-list-view .empty-state:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.characters-list-view .empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(74,158,255,.3))}.characters-list-view .empty-state h2{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.characters-list-view .empty-state p{margin:0 0 var(--spacing-xl) 0;color:var(--text-secondary)}.characters-list-view{max-width:1400px;margin:0 auto}.characters-list-view h1{margin-bottom:var(--spacing-xl);color:var(--text-primary)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.character-card{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-base);display:flex;flex-direction:column}.character-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.character-card h3{margin:var(--spacing-md) 0 0 0;color:var(--text-primary);text-align:center;font-size:1.1rem;font-weight:600}.character-preview{position:relative;width:100%;height:250px;border-radius:var(--radius-md);overflow:hidden;margin:0;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.character-preview img{width:100%;height:100%;object-fit:cover}.character-preview.placeholder{background:var(--bg-elevated);border:2px dashed var(--border-color)}.character-preview .placeholder-icon{font-size:4rem;color:var(--text-tertiary);opacity:.5}.character-details-section{margin-top:var(--spacing-2xl);padding:var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.character-details-heading{margin:0 0 var(--spacing-lg) 0;font-size:1.25rem;color:var(--text-primary);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.character-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.character-detail-block{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color)}.character-detail-block-full{grid-column:1 / -1}.character-detail-block label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.02em}.character-spec-list{list-style:none;margin:0;padding:0}.character-spec-list li{padding:var(--spacing-xs) 0;font-size:.95rem;color:var(--text-primary)}.character-spec-list li.muted{color:var(--text-tertiary);font-style:italic}.character-detail-block p{margin:0;font-size:.95rem;color:var(--text-primary);line-height:1.5}.character-enriched-prompt{white-space:pre-wrap;word-break:break-word;font-size:.9rem;max-height:200px;overflow-y:auto}.location-create-modal{max-width:800px;max-height:90vh;overflow-y:auto}.location-create-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-group-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.select{cursor:pointer}.location-edit-modal{max-width:800px;max-height:90vh;overflow-y:auto}.location-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.location-preview{position:relative;width:100%;max-height:300px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--accent-primary);background:var(--bg-elevated)}.location-preview img{width:100%;height:100%;object-fit:contain}.description-textarea{min-height:150px;resize:vertical;font-family:inherit}.description-hint{margin-top:var(--spacing-xs);color:var(--text-tertiary);font-size:.85rem;font-style:italic}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.compact-location-controller{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:900px;background:linear-gradient(135deg,#0a0a14bf,#0f0f1ebf);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:10px 16px;display:flex;flex-direction:column;gap:8px;z-index:1000;box-shadow:0 -8px 32px #0009,0 0 0 1px #8b5cf61a,inset 0 1px #ffffff0d;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideUpFade .4s ease-out}.controller-name-input,.controller-prompt-input{flex:1;padding:10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;min-width:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.controller-name-input{max-width:200px}.controller-name-input::placeholder,.controller-prompt-input::placeholder{color:#ffffff4d;font-style:italic}.controller-name-input:focus,.controller-prompt-input:focus{border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.controller-name-input:disabled,.controller-prompt-input:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.compact-location-controller{padding:8px 12px;width:95%}.controller-main-wrapper{gap:8px}.controller-name-input{max-width:150px}.controller-name-input,.controller-prompt-input{font-size:.85rem;padding:8px 12px}.controller-generate-btn{width:40px;height:40px}}.location-detail-page{max-width:1600px;margin:0 auto}.location-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.location-header .header-actions{display:flex;gap:var(--spacing-md);align-items:center}.location-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.location-info h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.location-description{color:var(--text-secondary);font-size:1rem;margin:0 0 var(--spacing-md) 0;line-height:1.6}.location-meta{font-size:.9rem;color:var(--text-tertiary);display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.location-type-badge,.location-time-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;background:var(--bg-elevated);border:1px solid var(--border-color)}.locations-list-view{width:100%}.locations-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.locations-list-header h1{margin:0;color:var(--text-primary)}.locations-list-view .empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden;animation:slide-in-fade .6s cubic-bezier(.16,1,.3,1)}.locations-list-view .empty-state:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.locations-list-view .empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(74,158,255,.3))}.locations-list-view .empty-state h2{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.locations-list-view .empty-state p{margin:0 0 var(--spacing-xl) 0;color:var(--text-secondary)}.generation-interface{display:flex;flex-direction:column;gap:var(--spacing-xl)}.locations-list-view{max-width:1400px;margin:0 auto}.locations-list-view h1{margin-bottom:var(--spacing-xl);color:var(--text-primary)}.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.location-card{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-base);display:flex;flex-direction:column}.location-card h3{margin:var(--spacing-md) 0 0 0;color:var(--text-primary);text-align:center;font-size:1.1rem;font-weight:600}.location-preview{position:relative;width:100%;height:250px;border-radius:var(--radius-md);overflow:hidden;margin:0;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.location-preview img{width:100%;height:100%;object-fit:cover}.location-preview.placeholder{background:var(--bg-elevated);border:2px dashed var(--border-color)}.location-preview .placeholder-icon{font-size:4rem;color:var(--text-tertiary);opacity:.5}.published-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--accent-success);color:var(--text-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.loading-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.clip-generation-modal{max-width:900px;width:90%;max-height:90vh;overflow-y:auto}.clip-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.clip-modal-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.clip-subtitle{margin:0;color:var(--text-secondary);font-size:.9rem}.clip-modal-body{min-height:400px;display:flex;align-items:center;justify-content:center}.generation-state{width:100%;text-align:center;padding:var(--spacing-xl)}.generation-animation{margin-bottom:var(--spacing-xl);display:flex;justify-content:center}.film-reel{display:flex;gap:var(--spacing-md);animation:rotate 2s linear infinite}.reel-frame{font-size:3rem;opacity:.8}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generation-state h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.generation-description{color:var(--text-secondary);margin-bottom:var(--spacing-xl);max-width:500px;margin-left:auto;margin-right:auto}.progress-container{margin-bottom:var(--spacing-xl);max-width:500px;margin-left:auto;margin-right:auto}.progress-bar{width:100%;height:8px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm);border:1px solid var(--border-color)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-hover));border-radius:var(--radius-full);transition:width .3s ease;box-shadow:0 0 10px #4a9eff80}.progress-text{display:block;text-align:center;color:var(--text-secondary);font-size:.9rem;font-weight:600}.generation-steps{display:flex;flex-direction:column;gap:var(--spacing-md);max-width:500px;margin:var(--spacing-xl) auto 0;text-align:left}.step{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-color);transition:all var(--transition-base);opacity:.5}.step.completed{opacity:1;border-color:var(--accent-primary);background:#4a9eff1a}.step-icon{width:24px;height:24px;border-radius:50%;background:var(--bg-panel);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.step.completed .step-icon{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--text-primary)}.video-player-container{width:100%}.video-wrapper{position:relative;width:100%;background:#000;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-lg)}.generated-clip-video{width:100%;height:auto;display:block;max-height:60vh}.video-info{background:var(--bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--border-color)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-row strong{color:var(--text-primary);font-weight:600}.info-row span{color:var(--text-secondary)}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600}.status-badge.success{background:#2ed57333;color:#2ed573;border:1px solid rgba(46,213,115,.3)}.video-actions{display:flex;gap:var(--spacing-md);justify-content:center}.ready-to-generate{text-align:center;padding:var(--spacing-xl)}.ready-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:pulse 2s ease-in-out infinite}.ready-to-generate h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.ready-to-generate p{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.generate-clip-btn{min-width:250px;font-size:1.1rem;font-weight:600;padding:var(--spacing-md) var(--spacing-xl)}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.scene-builder{width:100%;padding:var(--spacing-xl);background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.scene-builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.scene-builder-header .header-actions{display:flex;gap:var(--spacing-md);align-items:center}.scene-builder-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.scene-builder-header p{margin:0;color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-xs)}.scenes-count-badge{color:var(--accent-primary);font-weight:600;padding:2px 8px;background:#6c4ab61a;border-radius:var(--radius-sm);border:1px solid rgba(108,74,182,.3);font-size:.85rem}.scene-builder-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.scenes-panel{width:280px;flex-shrink:0;background:var(--bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);padding:var(--spacing-lg);position:sticky;top:var(--spacing-xl);height:calc(100vh - 200px);max-height:800px;overflow-y:auto;transition:all var(--transition-base)}.scenes-panel-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.scenes-panel-header h3{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.2rem}.scenes-panel-header p{margin:0;color:var(--text-secondary);font-size:.85rem}.scenes-panel-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.available-scene-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:grab;transition:all var(--transition-base);-webkit-user-select:none;user-select:none}.available-scene-item:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.available-scene-item:active{cursor:grabbing;opacity:.7}.scene-item-icon{font-size:1.5rem;flex-shrink:0}.scene-item-info{flex:1;min-width:0}.scene-item-title{font-weight:600;color:var(--text-primary);font-size:.9rem;margin-bottom:var(--spacing-xs);word-wrap:break-word}.scene-item-description{color:var(--text-secondary);font-size:.75rem;line-height:1.3;word-wrap:break-word}.scenes-empty{padding:var(--spacing-xl);text-align:center;color:var(--text-tertiary);font-size:.9rem;font-style:italic}.scene-canvas{position:relative;flex:1;min-height:600px;max-height:800px;background:var(--bg-canvas);background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-md);border:2px solid var(--border-color);overflow:auto;cursor:grab;box-shadow:inset 0 0 50px #0000004d;transition:all var(--transition-base)}.scene-canvas.drag-over{border-color:var(--accent-primary);box-shadow:inset 0 0 50px #0000004d,0 0 20px #6c4ab64d;background-color:#6c4ab60d}.scene-canvas:active{cursor:grabbing}.scene-canvas-content{position:relative;min-width:2000px;min-height:1000px;width:100%;height:100%}.scene-card{position:absolute;width:160px;min-height:130px;max-height:300px;background:var(--bg-panel);border:2px solid var(--accent-primary);border-radius:var(--radius-md);cursor:grab;transition:all var(--transition-base);z-index:10;box-shadow:var(--shadow-md);-webkit-user-select:none;user-select:none;overflow:hidden;display:flex;flex-direction:column}.scene-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);z-index:20;border-color:var(--accent-primary-hover)}.scene-card.dragging{cursor:grabbing;z-index:100;transform:scale(1.05) rotate(1deg);box-shadow:var(--shadow-glow),0 10px 30px #00000080;opacity:.95;border-width:3px}.scene-card.editing{border-color:var(--accent-warning);box-shadow:0 0 20px #f39c124d}.scene-card-header{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;background:var(--bg-elevated);border-bottom:1px solid var(--border-color);border-radius:var(--radius-md) var(--radius-md) 0 0;flex-shrink:0}.scene-number{font-weight:700;color:var(--accent-primary);font-size:.75rem}.scene-actions{display:flex;gap:var(--spacing-xs)}.scene-action-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.75rem;padding:2px 3px;border-radius:var(--radius-sm);transition:all var(--transition-base);line-height:1}.scene-action-btn:hover{background:var(--bg-panel);color:var(--text-primary);transform:scale(1.1)}.scene-action-btn.watch-btn:hover{background:#4a9eff33;color:var(--accent-primary)}.scene-card-body{padding:6px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:5px;min-height:0}.scene-title{margin:0 0 3px;color:var(--text-primary);font-size:.8rem;font-weight:600;line-height:1.2;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.scene-description{margin:0 0 3px;color:var(--text-secondary);font-size:.7rem;line-height:1.25;word-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.scene-section{margin-bottom:4px}.scene-section:last-child{margin-bottom:0}.scene-section strong{display:block;margin-bottom:3px;color:var(--text-primary);font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.scene-tags{display:flex;flex-wrap:wrap;gap:3px}.scene-tag{padding:2px 5px;border-radius:3px;font-size:.65rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:inline-block}.character-tag{background:#f39c1233;color:var(--accent-warning);border:1px solid var(--accent-warning)}.location-tag{background:#9b59b633;color:#9b59b6;border:1px solid #9b59b6}.scene-script-preview{background:var(--bg-elevated);padding:3px 5px;border-radius:3px;border:1px solid var(--border-color);color:var(--text-secondary);font-size:.65rem;font-style:italic;line-height:1.2;max-height:35px;overflow:hidden;word-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.scene-connections{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.scene-modal{max-width:700px;max-height:90vh;overflow-y:auto}.scene-editor-modal{max-width:98vw;width:98vw;max-height:95vh;overflow:hidden;display:flex;flex-direction:column}.scene-editor-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color);flex-shrink:0}.scene-editor-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.75rem}.scene-editor-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.close-btn{background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);font-size:1.125rem;flex-shrink:0}.close-btn:hover{background:var(--bg-panel);border-color:var(--accent-primary);color:var(--accent-primary);transform:scale(1.05)}.scene-editor-form{display:flex;flex-direction:column;height:100%;overflow:hidden}.scene-editor-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-2xl);padding-right:var(--spacing-sm)}.scene-editor-content::-webkit-scrollbar{width:8px}.scene-editor-content::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:var(--radius-sm)}.scene-editor-content::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-sm)}.editor-section{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-color)}.editor-section h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary);font-size:1.25rem;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.shots-section{min-height:600px}.shots-editor-container{margin-top:var(--spacing-lg)}.shots-editor-container .shot-builder{padding:0;background:transparent;border:none;box-shadow:none}.shots-editor-container .shot-builder:before{display:none}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);flex-shrink:0}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.selection-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.selection-item:hover{border-color:var(--accent-primary);background:var(--bg-panel);transform:translateY(-2px)}.selection-item.selected{border-color:var(--accent-primary);background:#4a9eff1a;box-shadow:0 0 10px #4a9eff33}.selection-icon{font-size:1.2rem}.selection-label{font-size:.9rem;color:var(--text-primary);font-weight:500}.scene-view-modal{max-width:1000px;max-height:90vh;overflow-y:auto}.view-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.view-modal-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.75rem}.view-subtitle{margin:0;color:var(--accent-primary);font-size:.9rem;font-weight:500}.view-modal-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.view-section{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.view-section h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1.25rem;display:flex;align-items:center;gap:var(--spacing-sm)}.section-description{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.view-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item.full-width{grid-column:1 / -1}.info-item strong{color:var(--text-primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.info-item span{color:var(--text-secondary);font-size:.95rem}.character-grid,.location-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.character-view-card,.location-view-card{background:var(--bg-panel);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color)}.character-view-header,.location-view-header{margin-bottom:var(--spacing-sm)}.character-view-header h4,.location-view-header h4{margin:0;color:var(--text-primary);font-size:1.1rem}.character-description-text,.location-description-text{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary);font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto}.character-description-text p,.location-description-text p{margin:0;padding:0;white-space:pre-wrap;word-wrap:break-word}.no-description{color:var(--text-tertiary);font-style:italic}.character-image,.location-image{position:relative;width:100%;height:200px;border-radius:var(--radius-md);overflow:hidden;margin-top:var(--spacing-md)}.character-image img,.location-image img{width:100%;height:100%;object-fit:cover}.ai-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--accent-primary);color:var(--text-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.scene-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.scene-image-card{position:relative;width:100%;height:250px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);background:var(--bg-elevated)}.scene-image-card img{width:100%;height:100%;object-fit:cover}.image-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 30%,transparent 70%,rgba(0,0,0,.7) 100%);opacity:0;transition:opacity var(--transition-base);display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-sm)}.scene-image-card:hover .image-overlay{opacity:1}.image-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.btn-icon-small{background:#0009;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:var(--spacing-xs);transition:all var(--transition-base)}.btn-icon-small:hover{background:#000c;transform:scale(1.1)}.script-content-view{background:var(--bg-canvas);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--border-color);max-height:400px;overflow-y:auto}.script-content-view pre{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,monospace}.ai-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.summary-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-panel);border-radius:var(--radius-md);border:1px solid var(--border-color)}.summary-item strong{color:var(--text-primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.summary-item span{color:var(--text-secondary);font-size:.95rem}.image-gallery-section{margin-top:var(--spacing-xl)}.generated-images-container{display:flex;flex-direction:column;gap:var(--spacing-xl)}.image-group{background:var(--bg-panel);border-radius:var(--radius-md);padding:var(--spacing-lg);border:1px solid var(--border-color)}.image-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.image-group-header h4{margin:0;color:var(--text-primary);font-size:1.1rem;display:flex;align-items:center;gap:var(--spacing-sm)}.image-count{color:var(--text-secondary);font-size:.85rem}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md)}.gallery-image-card{position:relative;width:100%;height:200px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-base);background:var(--bg-elevated)}.gallery-image-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.gallery-image-card.selected{border-color:var(--accent-primary);border-width:3px;box-shadow:0 0 0 3px #4a9eff33}.gallery-image-card img{width:100%;height:100%;object-fit:cover}.gallery-image-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.8) 100%);opacity:0;transition:opacity var(--transition-base);display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-sm)}.gallery-image-card:hover .gallery-image-overlay,.gallery-image-card.selected .gallery-image-overlay{opacity:1}.selection-checkbox{width:24px;height:24px;border-radius:50%;background:var(--accent-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;align-self:flex-end}.gallery-image-card:not(.selected) .selection-checkbox{background:#ffffff4d;border:2px solid rgba(255,255,255,.5)}.image-name{color:var(--text-primary);font-size:.8rem;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.8)}.selected-indicator{position:absolute;top:var(--spacing-xs);left:var(--spacing-xs);background:var(--accent-primary);color:var(--text-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.scene-editor-modal{max-width:900px;width:90%;max-height:90vh;overflow-y:auto}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.editor-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base)}.scene-editor-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{font-size:.9rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.form-hint{margin:0;color:var(--text-tertiary);font-size:.85rem;font-style:italic}.form-input,.form-textarea{padding:var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition-base);width:100%}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff1a}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.empty-state{padding:var(--spacing-lg);text-align:center;color:var(--text-tertiary);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px dashed var(--border-color)}.location-selection,.characters-selection{display:flex;flex-direction:column;gap:var(--spacing-md)}.location-grid,.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.location-card-selectable,.character-card-selectable{background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-base)}.location-card-selectable:hover,.character-card-selectable:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.location-card-selectable.selected,.character-card-selectable.selected{border-color:var(--accent-primary);background:#4a9eff1a;box-shadow:0 0 0 3px #4a9eff1a}.location-card-header,.character-card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.location-icon,.character-icon{font-size:1.2rem}.location-name,.character-name{flex:1;font-weight:600;color:var(--text-primary);font-size:.95rem}.selected-check{color:var(--accent-primary);font-weight:700;font-size:1.2rem}.location-description,.character-description{margin:var(--spacing-xs) 0 0 0;color:var(--text-secondary);font-size:.85rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.selected-count{padding:var(--spacing-sm);background:#4a9eff1a;border-radius:var(--radius-sm);color:var(--accent-primary);font-size:.9rem;font-weight:600;text-align:center}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.storyboard-page{max-width:1600px;margin:0 auto}.storyboard-header{margin-bottom:var(--spacing-xl);display:flex;justify-content:space-between;align-items:flex-start}.storyboard-header>div:first-child h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.storyboard-header>div:first-child p{color:var(--text-secondary);margin:0}.storyboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.view-mode-toggle{display:flex;gap:var(--spacing-sm)}.generate-movie-header-btn{font-weight:600;padding:var(--spacing-md) var(--spacing-xl);box-shadow:0 4px 12px #4a9eff4d;animation:pulse-glow 2s ease-in-out infinite}.generate-movie-header-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4a9eff66}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #4a9eff4d}50%{box-shadow:0 4px 20px #4a9eff80}}.generation-view,.storyboard-interface{display:flex;flex-direction:column;gap:var(--spacing-xl)}.scene-selector{display:flex;flex-direction:column;gap:var(--spacing-sm)}.selector-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.scene-select{padding:var(--spacing-md);background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition-base)}.scene-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff1a}.scene-info{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color)}.scene-info-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.scene-info-header>div:first-child{flex:1}.scene-info h3{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.scene-info p{margin:0;color:var(--text-secondary)}.scene-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.scene-detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.scene-detail-item strong{color:var(--text-primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.scene-detail-item span{color:var(--text-secondary);font-size:.9rem}.scene-characters-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.scene-characters-tags .character-tag{background:var(--bg-elevated);border:1px solid var(--border-color);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-secondary)}.type-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600}.type-badge.interior{background:#4a9eff26;color:var(--accent-primary)}.type-badge.exterior{background:#2ed57326;color:#2ed573}.generation-controls{margin-top:var(--spacing-md);display:flex;justify-content:center}.open-generation-modal-btn{min-width:200px;font-size:1rem;font-weight:600;padding:var(--spacing-md) var(--spacing-xl)}.published-storyboards{margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-color)}.published-storyboards h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary)}.storyboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg)}.storyboard-frame{background:var(--bg-panel);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);transition:all var(--transition-base)}.storyboard-frame:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.storyboard-frame img{width:100%;height:150px;object-fit:cover}.frame-info{padding:var(--spacing-sm);font-size:.85rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.easy-storyboard-page{width:100%;height:calc(100vh - var(--toolbar-height, 90px));min-height:0;display:flex;flex-direction:column;background:var(--bg-canvas);overflow:hidden}.easy-storyboard-banner{padding:10px 16px;background:linear-gradient(90deg,#6c4ab640,#3b82f626);border-bottom:2px solid rgba(108,74,182,.5);color:var(--text-primary);font-size:.95rem;flex-shrink:0}.easy-storyboard-banner .last-refresh{color:var(--text-secondary, #94a3b8);font-size:.85rem;margin-left:12px}.empty-state-hint{margin:8px 0 16px;font-size:.9rem;color:var(--text-secondary, #94a3b8)}.storyboard-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-color);background:var(--bg-canvas);flex-shrink:0}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:100%}.storyboard-header h2{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.btn-add-scene-top{padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:var(--spacing-xs)}.btn-add-scene-top:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.storyboard-header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-refresh-scenes{padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;color:var(--text-secondary, #94a3b8);border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-refresh-scenes:hover:not(:disabled){background:#ffffff14;color:var(--text-primary, #fff)}.btn-refresh-scenes:disabled{opacity:.6;cursor:not-allowed}.storyboard-scenes-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-2xl);scrollbar-width:thin;scrollbar-color:var(--accent-primary) var(--bg-elevated)}.storyboard-scenes-container::-webkit-scrollbar{width:8px}.storyboard-scenes-container::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:var(--radius-sm)}.storyboard-scenes-container::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-sm)}.storyboard-scenes-container::-webkit-scrollbar-thumb:hover{background:var(--accent-primary-hover)}.empty-scenes-state{text-align:center;padding:var(--spacing-3xl);color:var(--text-tertiary)}.btn-add-scene-small{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-add-scene-small:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.scene-row-container{display:flex;flex-direction:row;gap:var(--spacing-lg);border:2px solid var(--accent-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:#1a1a1a;box-shadow:0 4px 20px #6c4ab640;position:relative;overflow:visible;margin-bottom:var(--spacing-xl);align-items:flex-start}.scene-row-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary) 0%,transparent 50%,var(--accent-primary) 100%);opacity:.3}.scene-title-header-compact{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#6c4ab633,#6c4ab61a);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);border:1px solid rgba(108,74,182,.3);box-shadow:0 1px 4px #6c4ab626}.scene-title-dot{width:8px;height:8px;background:var(--accent-primary);border-radius:50%;flex-shrink:0;box-shadow:0 0 6px #6c4ab699}.scene-title-text{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.01em;text-shadow:0 1px 3px rgba(0,0,0,.5)}.scene-content-wrapper{display:flex;gap:var(--spacing-xl);align-items:flex-start;min-height:400px;width:100%;flex:1}.scene-left-panel{width:280px;flex-shrink:0}.scene-left-content{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.scene-description-header{font-size:.9rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) 0}.scene-option-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;min-height:50px;color:#fff}.scene-option-button:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.option-icon-small{font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.option-icon-small svg{width:100%;height:100%;stroke:currentColor}.option-label-text{flex:1;font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px;text-align:left}.option-info-icon{font-size:.75rem;color:var(--text-tertiary);font-style:italic}.option-circle{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);opacity:.5}.option-arrow{font-size:.875rem;color:var(--text-tertiary)}.option-badge{background:var(--accent-primary);color:#fff;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;min-width:20px;text-align:center}.scene-characters-display{margin-top:var(--spacing-md);padding:var(--spacing-md);background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px}.scene-characters-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-sm);font-weight:600}.scene-characters-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.scene-character-tag{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:.8rem}.scene-character-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover}.scene-character-name{color:var(--text-secondary);font-weight:500}.scene-location-type{color:var(--text-tertiary);font-size:.75rem;font-style:italic}.scene-right-panel{flex:1;min-width:0;position:relative;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0}.shots-horizontal-container{display:flex;gap:var(--spacing-md);overflow-x:auto;overflow-y:hidden;padding:var(--spacing-sm) 0;scrollbar-width:none;-ms-overflow-style:none;flex:1;scroll-behavior:smooth;position:relative}.shots-horizontal-container::-webkit-scrollbar{display:none}.scroll-indicator{width:36px;height:36px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;font-weight:700;cursor:pointer;transition:all .2s;flex-shrink:0;opacity:.5;z-index:5}.scroll-indicator:hover{background:#ffffff14;border-color:#3b82f666;opacity:1;transform:translateY(-1px)}.scroll-indicator-left{margin-right:var(--spacing-sm)}.scroll-indicator-right{margin-left:var(--spacing-sm)}.scene-right-panel:hover .scroll-indicator{opacity:.8}.scene-right-panel:not(:hover) .scroll-indicator{opacity:.4}.shot-item-card{width:380px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-md);position:relative;background:transparent;min-height:600px}.shot-number-badge{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);width:28px;height:28px;background:#6c4ab6e6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:700;z-index:2;box-shadow:0 2px 8px #6c4ab680}.shot-image-container,.shot-video-container{width:100%;min-height:400px;max-height:500px;background:#1a1a1a;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--accent-primary);box-shadow:0 4px 16px #6c4ab64d;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition-base)}.shot-image-container:hover{border-color:var(--accent-primary-hover);box-shadow:0 6px 20px #6c4ab666;transform:translateY(-2px)}.shot-image-container img,.shot-image-container .shot-image{width:100%;height:100%;min-height:400px;object-fit:cover;display:block;transition:opacity .3s ease-in-out}.shot-image-container img[src=""]{display:none}.shot-video-container{position:relative}.shot-video{width:100%;height:100%;min-height:400px;object-fit:cover;display:block;background:#000}.shot-media-toggle{position:absolute;top:8px;right:8px;z-index:10}.btn-toggle-media{background:#6c4ab6f2;border:2px solid rgba(255,255,255,.9);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.4rem;transition:all var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #00000080,0 0 0 2px #6c4ab64d;color:#fff;position:relative}.btn-toggle-media:before{content:"";position:absolute;inset:-2px;background:radial-gradient(circle,rgba(108,74,182,.4) 0%,transparent 70%);border-radius:50%;opacity:0;transition:opacity var(--transition-base);z-index:-1}.btn-toggle-media:hover{background:#6c4ab6;transform:scale(1.15);box-shadow:0 6px 20px #6c4ab6b3,0 0 0 3px #6c4ab666;border-color:#fff}.btn-toggle-media:hover:before{opacity:1}.shot-loading-container{background:#1a1a1a;border-color:var(--accent-primary);border-style:dashed}.shot-loading-overlay{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl)}.shot-loading-spinner{width:48px;height:48px;border:4px solid rgba(108,74,182,.2);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.shot-loading-text{color:#fff;font-size:1rem;font-weight:600;text-align:center}.shot-loading-progress{width:100%;max-width:300px;height:6px;background:#6c4ab633;border-radius:3px;overflow:hidden;position:relative}.shot-loading-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),rgba(108,74,182,.8));border-radius:3px;animation:progress 2s ease-in-out infinite;width:60%;position:absolute;left:-60%}@keyframes progress{0%{left:-60%}50%{left:100%}to{left:100%}}.shot-placeholder-box{width:100%;min-height:400px;max-height:500px;background:#2a2a2a;border:2px dashed #4a4a4a;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.shot-placeholder-box:before{content:"📷";font-size:3rem;opacity:.3}.btn-create-image-shot{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.btn-create-image-shot:hover:not(:disabled){background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-create-image-shot:disabled{background:#ffffff05;color:#fff6;cursor:not-allowed;opacity:.6}.sparkle-icon{font-size:.875rem}.shot-action-buttons{display:flex;gap:var(--spacing-sm);width:100%;margin-top:var(--spacing-sm)}.btn-edit-shot{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit-shot:hover:not(:disabled){background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-edit-shot:disabled{background:#ffffff05;color:#fff6;cursor:not-allowed;opacity:.6}.btn-generate-video-shot{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;min-width:140px}.btn-generate-video-shot:hover:not(:disabled){background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-generate-video-shot:disabled{opacity:.6;cursor:not-allowed;background:#ffffff05}.btn-view-video-shot{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;min-width:140px;position:relative}.btn-view-video-shot:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-view-video-shot:active{transform:translateY(0)}.btn-view-video-shot span{position:relative;z-index:1;font-size:1.1rem}.loading-spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.shot-title-header{width:100%;margin-bottom:var(--spacing-xs)}.shot-title-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#252525;border:1px solid #3a3a3a;border-radius:var(--radius-sm);color:#fff;font-size:1rem;font-weight:600;font-family:inherit;transition:all var(--transition-base)}.shot-title-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab633;background:#2a2a2a}.shot-title-input::placeholder{color:#888}.scene-shots-count-display{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding:var(--spacing-xs) 0}.scene-shots-count-label{font-size:.75rem;font-weight:600;color:var(--text-tertiary, #64748b);letter-spacing:.05em}.scene-shots-count-badge{min-width:1.5rem;padding:2px 8px;background:#6c4ab640;border-radius:10px;font-size:.8rem;font-weight:700;color:var(--accent-primary)}.shot-description-block{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#0003;border-radius:var(--radius-sm);border-left:3px solid var(--accent-primary)}.shot-description-text{margin:0 0 var(--spacing-xs) 0;font-size:.85rem;color:var(--text-secondary, #94a3b8);line-height:1.4}.shot-prompt-text{margin:0;font-size:.8rem;color:var(--text-tertiary, #64748b);line-height:1.35;white-space:pre-wrap;word-break:break-word}.shot-prompt-field{width:100%;padding:var(--spacing-md);background:#252525;border:1px solid #3a3a3a;border-radius:var(--radius-sm);color:#fff;font-size:.9rem;font-family:inherit;transition:all var(--transition-base);margin-top:auto}.shot-prompt-field:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab633;background:#2a2a2a}.shot-prompt-field::placeholder{color:#888}.add-shot-card{width:380px;min-height:600px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#252525;border:2px dashed #4a4a4a;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.add-shot-card:hover{border-color:var(--accent-primary);background:#2d2d2d;border-style:solid;transform:scale(1.02)}.add-shot-icon-large{font-size:3rem;color:var(--text-tertiary);font-weight:300;transition:all var(--transition-base)}.add-shot-card:hover .add-shot-icon-large{color:var(--accent-primary);transform:scale(1.1)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-xl)}.modal-content{background:var(--bg-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;color:var(--text-primary);font-size:1.25rem}.modal-close{width:32px;height:32px;background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base)}.modal-close:hover{background:var(--bg-panel);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.location-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.location-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-base)}.location-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.location-card.selected{border-color:var(--accent-primary);border-width:2px;box-shadow:0 0 0 2px #6c4ab64d;background:#6c4ab61a}.selected-indicator{position:absolute;top:8px;right:8px;width:24px;height:24px;background:var(--accent-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:700;box-shadow:0 2px 4px #0003}.location-card{position:relative}.location-card img{width:100%;height:120px;object-fit:cover}.location-info{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.location-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.location-description{font-size:.8125rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.style-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md)}.style-option-card{padding:var(--spacing-lg);background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-base)}.style-option-card:hover{border-color:var(--accent-primary);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:var(--shadow-md)}.style-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.loading-state{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:1.1rem}.reference-assets-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-xl)}.reference-assets-modal{background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);width:90%;max-width:900px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.reference-assets-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--glass-border)}.reference-assets-modal-header h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.close-modal-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-base)}.close-modal-btn:hover{background:#6c4ab61a;color:var(--accent-primary)}.reference-assets-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.reference-assets-hint{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#6c4ab61a;border-radius:var(--radius-md);border-left:3px solid var(--accent-primary)}.reference-assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md)}.reference-asset-card{position:relative;background:var(--bg-elevated);border:2px solid var(--glass-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-base);aspect-ratio:1}.reference-asset-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #6c4ab64d}.reference-asset-card.selected{border-color:var(--accent-primary);border-width:3px;box-shadow:0 0 0 2px #6c4ab64d}.reference-asset-preview{width:100%;height:100%;object-fit:cover;display:block}.reference-asset-name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);color:#fff;padding:var(--spacing-sm);font-size:.75rem;font-weight:600;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.reference-asset-check{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);background:var(--accent-primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;box-shadow:0 2px 8px #6c4ab680}.reference-assets-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--glass-border)}.btn-cancel-reference{padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-cancel-reference:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}.btn-generate-with-references{padding:var(--spacing-md) var(--spacing-lg);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-generate-with-references:hover{background:#ffffff14;border-color:#3b82f666;transform:translateY(-1px)}@media(max-width:768px){.scene-row-container{flex-direction:column}.scene-left-panel{width:100%}.shot-item-card,.add-shot-card{width:280px}}.movie-generation-page{max-width:1600px;margin:0 auto;padding:var(--spacing-xl)}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg)}.empty-state h2{color:var(--text-primary);margin-bottom:var(--spacing-md)}.empty-state p{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.movie-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);background:linear-gradient(135deg,#4a9eff1a,#2ed5731a);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.header-content{display:flex;align-items:center;gap:var(--spacing-lg)}.header-icon{font-size:4rem;animation:float 3s ease-in-out infinite}.movie-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:2rem;font-weight:700}.movie-header p{margin:0;color:var(--text-secondary);font-size:1.1rem}.movie-content{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-xl)}.scenes-selection-panel{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.panel-header h2{margin:0;color:var(--text-primary);font-size:1.3rem}.selection-actions{display:flex;gap:var(--spacing-sm)}.btn-link{background:transparent;border:none;color:var(--accent-primary);cursor:pointer;font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-base)}.btn-link:hover{background:#4a9eff1a}.scenes-timeline{display:flex;flex-direction:column;gap:var(--spacing-lg)}.scene-timeline-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-md);border:2px solid var(--border-color);transition:all var(--transition-base);position:relative;overflow:hidden}.scene-timeline-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--border-color);transition:all var(--transition-base)}.scene-timeline-item.selected:before{background:var(--accent-primary);box-shadow:0 0 10px #4a9eff80}.scene-timeline-item.selected{border-color:var(--accent-primary);background:#4a9eff0d}.scene-timeline-item.generating{border-color:var(--accent-warning);box-shadow:0 0 0 3px #f39c121a}.scene-timeline-item.completed{border-color:#2ed573;background:#2ed5730d}.scene-timeline-number{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.scene-number-circle{width:40px;height:40px;border-radius:50%;background:var(--accent-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;box-shadow:var(--shadow-sm)}.scene-timeline-item.selected .scene-number-circle{background:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff4d}.timeline-connector{width:2px;flex:1;background:var(--border-color);margin:var(--spacing-sm) 0}.scene-timeline-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.scene-timeline-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap}.scene-checkbox-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.scene-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--accent-primary)}.scene-timeline-header h3{margin:0;color:var(--text-primary);font-size:1.1rem}.scene-badges{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.scene-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;border:1px solid}.scene-badge.interior{background:#4a9eff26;border-color:var(--accent-primary);color:var(--accent-primary)}.scene-badge.exterior{background:#2ed57326;border-color:#2ed573;color:#2ed573}.scene-badge.time{background:var(--bg-panel);border-color:var(--border-color);color:var(--text-secondary)}.scene-description{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.scene-details{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:.85rem;color:var(--text-secondary)}.scene-detail{display:flex;align-items:center;gap:var(--spacing-xs)}.detail-icon{font-size:1rem}.scene-progress{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.progress-bar{width:100%;height:6px;background:var(--bg-panel);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-hover));border-radius:var(--radius-sm);transition:width .3s ease}.progress-text{font-size:.8rem;color:var(--text-secondary);font-weight:600}.generation-panel{background:var(--bg-panel);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-color);height:fit-content;position:sticky;top:var(--spacing-xl);box-shadow:var(--shadow-md)}.generation-summary{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.generation-summary h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.summary-stats{display:flex;flex-direction:column;gap:var(--spacing-md)}.stat-item{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--text-secondary);font-size:.9rem}.stat-value{color:var(--text-primary);font-weight:600;font-size:1rem}.generate-movie-btn{width:100%;padding:var(--spacing-lg);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-primary-hover) 100%);box-shadow:0 4px 15px #4a9eff66;transition:all var(--transition-base)}.generate-movie-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4a9eff99}.generate-movie-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{animation:pulse 1.5s ease-in-out infinite}.movie-preview{margin-top:var(--spacing-xl)}.movie-preview h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary)}.video-preview{width:100%;background:#000;border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--spacing-lg)}.generated-movie{width:100%;height:auto;display:block}.movie-actions{display:flex;gap:var(--spacing-md)}.movie-actions .btn{flex:1}@media(max-width:1200px){.movie-content{grid-template-columns:1fr}.generation-panel{position:static}}.vjs-svg-icon{display:inline-block;background-repeat:no-repeat;background-position:center;fill:currentColor;height:1.8em;width:1.8em}.vjs-svg-icon:before{content:none!important}.vjs-svg-icon:hover,.vjs-control:focus .vjs-svg-icon{filter:drop-shadow(0 0 .25em #fff)}.vjs-modal-dialog .vjs-modal-dialog-content,.video-js .vjs-modal-dialog,.vjs-button>.vjs-icon-placeholder:before,.video-js .vjs-big-play-button .vjs-icon-placeholder:before{position:absolute;top:0;left:0;width:100%;height:100%}.vjs-button>.vjs-icon-placeholder:before,.video-js .vjs-big-play-button .vjs-icon-placeholder:before{text-align:center}@font-face{font-family:VideoJS;src:url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABTsAAsAAAAAIpAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAADsAAABUIIslek9TLzIAAAFEAAAAPgAAAFZRiV32Y21hcAAAAYQAAAEJAAAD5p42+VxnbHlmAAACkAAADtIAABckI4l972hlYWQAABFkAAAAKwAAADYsvIjpaGhlYQAAEZAAAAAdAAAAJA+RCL1obXR4AAARsAAAABcAAAC8Q2YAAGxvY2EAABHIAAAAYAAAAGB7CIGGbWF4cAAAEigAAAAfAAAAIAFAAI9uYW1lAAASSAAAASUAAAIK1cf1oHBvc3QAABNwAAABfAAAAnXdFqh1eJxjYGRgYOBiMGCwY2BycfMJYeDLSSzJY5BiYGGAAJA8MpsxJzM9kYEDxgPKsYBpDiBmg4gCACY7BUgAeJxjYGR7yDiBgZWBgaWQ5RkDA8MvCM0cwxDOeI6BgYmBlZkBKwhIc01hcPjI+FGPHcRdyA4RZgQRADaGCyYAAHic7dPXbcMwAEXRK1vuvffem749XAbKV3bjBA6fXsaIgMMLEWoQJaAEFKNnlELyQ4K27zib5PNF6vl8yld+TKr5kH0+cUw0xv00Hwvx2DResUyFKrV4XoMmLdp06NKjz4AhI8ZMmDJjzoIlK9Zs2LJjz4EjJ85cuHLjziPe/0UWL17mf2tqKLz/9jK9f8tXpGCoRdPKhtS0RqFkWvVQNtSKoVYNtWaoddPXEBqG2jQ9XWgZattQO4baNdSeofYNdWCoQ0MdGerYUCeGOjXUmaHODXVhqEtDXRnq2lA3hro11J2h7g31YKhHQz0Z6tlQL4Z6NdSbod4N9WGoT9MfHF6GmhnZLxyDcRMAAAB4nJ1YC1hU17U+a5/HMA4iA3NmVBDmoQwP5TFnHlFeA4gYiUFRQINoSCBAyK3G2yi+0aipYtFcHYo2xsb4NiY3+VrNxSaX5uvt495ozNdoYoxmem2/L8HGpLc+InB279pnhlGr5mvL4eyz99nrrL32eu1/DQcc/okdYgdHOA6MQKp4r9gx0EcMHMezOalVasW5BM7NcXoSb9fFgE6KtSSBxWz1FYDPG+vMBGcKb9cebu2VS5s2aaTkCvRSf6C7Y+Ppibm5E09v7IDs2/3uZQtbD0zIyppwoHXh/93ukmyYgdePNRp65p5v+3v/9otQl2O7wP34cT88p8Md2YxpYLQZoRcy6FlSBRnwnGAe6BPMSCZo+7NJVqS0cE4uHendzhSnbPH6TDqL1+Nme5LZXkCHnGyoH0kne30WH+gswhm3q+pt/mTas9NLS64GnjmSlTPw0wVQT/ewRaBgxtydy3cuUB9/6SW+vb5yRvr+t0eOfPKJZ/9t3+4tL7xj32Xd3thCxi+ge6ifdsAN+l5+wi5HQ/cCoeull1AszS7CUfEcJzK7sKWJAdJhCd0sPM4+EY7QDm5ov08hXRQXE5bf6PV5Q5+IjW7X7Nku92Ask4l2hCRRD6TPqISiCJeQna3SCFwrhrNzXHzo4yFevBwxpzxk8WCIIfkvVEKVy32SbT8n68gzgaslpaiO2zIGIyuSb7RNf9HSuN26y/7OC1tgEmpiyA6aD4qcgTOiLThwGG0eB694FI8NHLLN6OBlRVaMxNAFS4JdXUG6mW8PwpKuYLCLXKGbu8iwYNdgO06Sn3Th+/vyZAxs8Ro30DjHe9gy8Fywi24OMm7Qyzh3MTZVOMYhLBnoC+J79lpTUyQmorjhnMwlcQ5uPEYGpDjsOkkH49BjQLQBqs3jFtFdJNlksYmoQFDArLh8Xh+Qd6Ghcsb6FUuehDi+U/lqD71K/qiegeV1imcwjl7ExwiSrf4BZyCujV6cVcFo6VX+G9IcPyFjJnUufbU/jzrL1X99as36reXl8K32nFaOr+E8jWJEcJ55DpMVfSMe95/AJaOsGBH2GJCNpiRQbK4C8BjdmQA22QY2j03Em13i2YHqtNLU1NI04Yj2HJgA6fQc6VPNpA/D+Ryks554NnVy2mB72uRUfPLsqR4N0LOBQKArwJYO+5W2fgZX8oC1HR6HjNaQTVIG2FPwnTcXXGZZfNB7TE6pTKZUwaw91XWLAoFFGcnB5PHjsckgBjbWutrL+0h5Y1xw3DRGDumsnXb3MJwXrJIN5U7m0rgJ3yG5w4he5ckFG4pmNEkOm0/xOO4r4yL87wqtQM+hiJIVp+6iG2wPBKD35ElGkDx+UfC2v1mFG1o+M3AjNFty8biKMXwzyxnZLds8wYD2BxmCPHAldPOeLsy/0BugftYhVYFAhO8SqQ0j3oK7dHJZnI/jxmUS4onlxskSF8thmvNZjIrRZwEPxr0lBuLRuz3oy/FOHCsxwOPYh2M+e9u3J5pgPYz9gp6G7C9m0A11F9ddqKMfV+4sbq45/YspOysXvT+3pdFdYNg2fHbW8Dz301MqDVuGrz0Fuh0YMW8mddrpqzST7rV9BcvqPoNvadRndWp0p8HvbiqrFj5yFQ/vNFSXDpxpLEFWp+DcrF3FT1afWshFcmCfeAMjEvO65i0Y6XijQfSRPWx3TV/Df7Km3E1l+kLt56s/rwVzuRusNMhudznkwdLaS+QNdeal2jDPP4l9qHc98vTYZOSkxzD+njBWVWjFPKgipx6DkWvXQiW8OYcewVHE5yukinDMcfGgc0opDltYKDxIGBedkzc6jSfE7tlvESCDFUw0Hx0opS+U0lHCxNottbNWSxX9zZVvEhKWUSyBpaXwBc2a98M6UqPeXAs/GDon8Ax7hsthO8cM5HU7Ad0UvRR9lHmtyQKZ4MAe814X5h9MSUkQmhf96eVJ6p90OjIiqSIjvykvr2l5U55O/fPQKD+jIomYpNyGJQ25uQ2kIikRfAmuBHCPsWqkSDEqgZ5KDI2sifS/R43MbZg0idFHbCPNxXxZws1ACVE6hAhOdJwRkJLFBLPZpRGYJ50pko6XzMkgmSx40ljik6AQcKhFnLcQE6rF7PXFe1Ocoj0T3AXgSgJTDIhHRfHlYZKuSzc6uievOJGXY+i5GJkkTp7UM3y0LqATDbtFcbdBxO7o4T25JYlEjoH0uynUh8rapkxp62QN70svSF+hT4gGPlovlmcm/ComLi7mV4kTykV9NFWjE/QrwgQ4uIcAP0rQF4VZYRP2o3PhHHzfPMJj9Ir+uzKUlrH49ntT18AVvj1sc3YGjUT/Mt2Dxawa8ArcA7bCQIpvfwAYu22vEG/No/5RvPdA7g+AelLrPwzy+LtkLPhnpIxH14m4EYq8eeMHbPEPNm6G7Nv9B4jcFPZ8bJj0SEjP3MPgQdKTqqEoy2v6G32P/Y6dxOv04AxnoAeq+GILvUavtYCBXm+BaIhuodcfrN5B/V2EYMCPh+SxavjGyPwV0x4CJgUPGT0mQaODGBACIJZGsMXwAD0LGXx7l3CdAcKMIKI+f5CepWeD0BvyU/GcdBxPF8SwejC6LGZmAURFdsSWKR5HyHld2kbdIZO1Ixx+bnnzU7n5+blPNV9jnUDWhP2tC68tbN3PVIldsQPxSAcSpjOav7Q05uXn5zW2LLvDXn9B6syscPy9iDLEMmSrJz6nYuWMipukjM0AH8JkGS+XFyMRkzSCH7KD/hwm172SAyZYumHlefr5AddrtA0O0TnwaVZxcRY9Bfukn9Gf05N1r9DV9MoBsJ1f+ZrqUvtPHizJAntWybv7hmqLt6QLuK6ZS9Fqi1jO5rDoWPZXXII5Tgajg53cIXCjDCGIcYrRIY2n6+mXOa/W0bdhau3ryiEYe2FV/5oeaIYK/5w5frCyll6/cYO8DiNhw6t1MBWmznt91QX62UF1N7l0eHBZTRGpKaqpKVIPF9UcIzmReud9TSY75+K899GHbBu6wjoR7RKKZVYiYxSPf5/2wJT5e3NAhmUbVn5KLx1Ujg0+BGvpAIh0DezInTkzF37KVocxrKU3r1+XLtAe2lO3l66kfQfB/unKY+q8N375Ru8bc4pJXfEcESU95q+p8ZNZRTWH1d9FzvUdYXk5rLkcdkEisoKKVHQW/b3GEx6tPaYcoJfOr9wAbSBnv1IHpep0OExr4LPMkpJM+j7sly7UHkOzXjoAZljHCGiyegtNlwljM0v+c19ET9Pvst09a2Mtgcf5/ZSzYO5h1156+eyydfAsxGa9XAuF6vzjh6CssLq6ECysperXX0sX5h5ZdpZe3guxsGIPEtHk/aqXX1hVqP5HYVVVISkrrNqvXorIc+5Ou91Hnr/LcD2afi6eX7UBloOcs7cOpqgGaNfs1g7bNbs9z6wASaylN69d0/TFTIz6Ws8+oGV3mE2612wRTHKcVUbhjKadebloMc+dyXgMVtVK6BwMB/+mVW09igdRBWaRtNQX59d/VD//xdQ0TCiYNj1KT9sq6Wdu5WTbqk3qDXyDaLa1fv621LS01G3z61sD6lH8lAxDLicV921s6Bf92JOYvzNYCL1khbqBXEFUzC521N5NyzNaQIWhjyFyDoBIVrAjmv2UEaLlI+c6zw1jmVIPLLLZZUTj6GxGHW+mq1tgHXR2D85p4Q934+jLbtjVLcyCdS10NVzpHqxp4Q/hK7WopY/NRGx9HGsPGdFjOjcpjBnGYMVqY/4eqT5khWEHWUup2A/pTw7pdWgsWft7ETUERL96nRg0HNFPmCYba6pylECaExX89A9WLUOVB4oKLu/o1oqSYHCgLzBUlAz8hNFDRpeSU1XT+LRmDUgPaKbYdHDn9suF/tu13nHJij0N97LfS0QmqONuyONk7zvUI6Qa0pF9f2+oABL92AT6e0U//z9YqAiWtJLU1JK0gS+1aacwamiNqK067u9ZQ8f1d4qLodMzz3uL89Z68V/Hnr++hXWUuHgw8dfi972PeTyPefu3aNNucemQ74qFuIaJnVkOu4Q+yjuwmmC1FqZpl1i4uzoPxjkpPf3Xv545tl26Rr+dOvUd+omqJzch9dOeU7f10Y64nMcKK137DccIZq2WdXtdZjbEoLSzHwiMtrjYLDxpHQW8gjMX6XFYAE2zSWVD04EGYSs9MbO6sEo20BMEAB4mpvSypsKjZ4Stgzb+c3A9/MQT2+vrBy+qvyFxLUtLlSRF/Ri2wjfZ2dus2Q8lXx4608/jnqK5OOap6NY2PSjYYnECCjiEeLJll/pbmqfeIK+ps3+MxrlEhqmTPipVP7kqlF4VhpEb6r+Q7YOJg38kJ9SHBf3NBl6+9YchfbUjb5ahLSzUM3kPHmwFAsZ5rpai0S7E5xWzZ1j+fW7zsUWP2g5NXTw52ySCTrgG0+lbw60l2Y/CB185CoA8NK+tbRKxfjy6pm5hzQRRR+cMqv1Jbiw6STivtEvt3DRcy0QEh92JlUGo2PG4tSKHl00YD6xc8CK+YPYyy3io2lN8BcSjKRzrIV6ypOAobqxViJPaT9M9Hy5szY33mp7OX/Zu89L/7Ww5vqY2Y8b0pKgoiUhG5cPDPzq8qTV/WkzUOIvXVVA96kmjcBrr3HrYC/Wn+fYP6Z7T1rqy3zknbvqma/FvVk96fNXGkuaXrdHW5JGSxZT/2I/O73v+yNWafMdzc5NdxYurHs6h86e01sLKLz9EBrg+x36rxAaED7hRnAMx7Vzu+9wabh3zG8XLQjx0ablUJzmxdErxYT3kzQSd0SSafVqF5PXgpp0OyYJ1EyNHpGUZmvK575ySzd85JSqF7IBzSAbMM04+MbE58xF3/njXOGecSaermlw2y9PsSQdytLJVr8t+wg+rR8cZYoeNxVIzNdk3Bngi8U5LAlgTFoQnzJCa5EsCgYhCaGL+qPj7TdhG31p9tej3R04N//PXxNwJvyUqwaJqRPJY98TJ5TPndmflRAkAhBfe46sfKW5wizSge08Xb7Ca/GUVs55trngkKkrUS2WPzKttaaqq+idmahugkY+W6fN0I6i3gPt/x88U4wAAeJxjYGRgYADiGU9YXsXz23xl4GZnAIFH7fO+IdMc/WBxDgYmEAUASbMKwAB4nGNgZGBgZwABjj4Ghv//OfoZGBlQgT4ARicDZAAAAHicY2BgYGAfxJijD8Fmu4EqBwCSpgKpAAAAAAAADgBoAH4AzADgAQIBQgFsAZgB7gIuAooC0AL8A2IDjAOoA+AEMASwBNoFCAVaBcAGCAYuBnAGrAb2B04HigfSCCoIcAiGCJwIyAkkCVYJiAmsCfIKIApWCsQLknicY2BkYGDQZ2hmYGcAASYg5gJCBob/YD4DABqrAdAAeJxdkE1qg0AYhl8Tk9AIoVDaVSmzahcF87PMARLIMoFAl0ZHY1BHdBJIT9AT9AQ9RQ9Qeqy+yteNMzDzfM+88w0K4BY/cNAMB6N2bUaPPBLukybCLvleeAAPj8JD+hfhMV7hC3u4wxs7OO4NzQSZcI/8Ltwnfwi75E/hAR7wJTyk/xYeY49fYQ/PztM+jbTZ7LY6OWdBJdX/pqs6NYWa+zMxa13oKrA6Uoerqi/JwtpYxZXJ1coUVmeZUWVlTjq0/tHacjmdxuL90OR8O0UEDYMNdtiSEpz5XQGqzlm30kzUdAYFFOb8R7NOZk0q2lwAyz1i7oAr1xoXvrOgtYhZx8wY5KRV269JZ5yGpmzPTjQhvY9je6vEElPOuJP3mWKnP5M3V+YAAAB4nG2ReVPbMBDF/ULi2EkDBFqO3gdHLxUzDB9IkdexBllydRD49ihO3Ckz7B/a31utZnafkkGyiXnyclxhgB0MMUKKMTLkmGCKV5hhF3vYxxwHOMRrvMERjnGCU7zFO7zHB3zEJ3zGF3zFN5zhHBe4xHf8wE/8wm8w/MEVimTYKv44XR9MSCsUjVoeHE3vjQoNsSZ4mmxZmVWPjSz7jlou6/0qKOWEJdKMtCe793/hQfqxa6XWZHMXFl56RS4TvPXSaDeoy0zUUZB109KstDK8lHo5q6Qi1hcOnqkImubPS6aqRq7mlnaEWabub4iYblba3SRmgldS0+FWdhNtt04F14JUaqkl7tcpOpJtErvNt3Bd9HRT5JWxK25Ldjvp6br4hzfFiIdSmlzTg2fSUzNrLd1LE1ynxq4OVaVoKLjzJ60UPtj1RKzHzsbjly6inVnFBS2MucviPncU7Rr7lfTxRepDs1A2j3ZHRc7PuzFYSfE3ZOd4kjwBy227hA==) format("woff");font-weight:400;font-style:normal}.vjs-icon-play,.video-js .vjs-play-control .vjs-icon-placeholder,.video-js .vjs-big-play-button .vjs-icon-placeholder:before{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-play:before,.video-js .vjs-play-control .vjs-icon-placeholder:before,.video-js .vjs-big-play-button .vjs-icon-placeholder:before{content:""}.vjs-icon-play-circle{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-play-circle:before{content:""}.vjs-icon-pause,.video-js .vjs-play-control.vjs-playing .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-pause:before,.video-js .vjs-play-control.vjs-playing .vjs-icon-placeholder:before{content:""}.vjs-icon-volume-mute,.video-js .vjs-mute-control.vjs-vol-0 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-volume-mute:before,.video-js .vjs-mute-control.vjs-vol-0 .vjs-icon-placeholder:before{content:""}.vjs-icon-volume-low,.video-js .vjs-mute-control.vjs-vol-1 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-volume-low:before,.video-js .vjs-mute-control.vjs-vol-1 .vjs-icon-placeholder:before{content:""}.vjs-icon-volume-mid,.video-js .vjs-mute-control.vjs-vol-2 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-volume-mid:before,.video-js .vjs-mute-control.vjs-vol-2 .vjs-icon-placeholder:before{content:""}.vjs-icon-volume-high,.video-js .vjs-mute-control .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-volume-high:before,.video-js .vjs-mute-control .vjs-icon-placeholder:before{content:""}.vjs-icon-fullscreen-enter,.video-js .vjs-fullscreen-control .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-fullscreen-enter:before,.video-js .vjs-fullscreen-control .vjs-icon-placeholder:before{content:""}.vjs-icon-fullscreen-exit,.video-js.vjs-fullscreen .vjs-fullscreen-control .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-fullscreen-exit:before,.video-js.vjs-fullscreen .vjs-fullscreen-control .vjs-icon-placeholder:before{content:""}.vjs-icon-spinner{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-spinner:before{content:""}.vjs-icon-subtitles,.video-js .vjs-subs-caps-button .vjs-icon-placeholder,.video-js.video-js:lang(en-GB) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js.video-js:lang(en-IE) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js.video-js:lang(en-AU) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js.video-js:lang(en-NZ) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js .vjs-subtitles-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-subtitles:before,.video-js .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js.video-js:lang(en-GB) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js.video-js:lang(en-IE) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js.video-js:lang(en-AU) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js.video-js:lang(en-NZ) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js .vjs-subtitles-button .vjs-icon-placeholder:before{content:""}.vjs-icon-captions,.video-js:lang(en) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js:lang(fr-CA) .vjs-subs-caps-button .vjs-icon-placeholder,.video-js .vjs-captions-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-captions:before,.video-js:lang(en) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js:lang(fr-CA) .vjs-subs-caps-button .vjs-icon-placeholder:before,.video-js .vjs-captions-button .vjs-icon-placeholder:before{content:""}.vjs-icon-hd{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-hd:before{content:""}.vjs-icon-chapters,.video-js .vjs-chapters-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-chapters:before,.video-js .vjs-chapters-button .vjs-icon-placeholder:before{content:""}.vjs-icon-downloading{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-downloading:before{content:""}.vjs-icon-file-download{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-file-download:before{content:""}.vjs-icon-file-download-done{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-file-download-done:before{content:""}.vjs-icon-file-download-off{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-file-download-off:before{content:""}.vjs-icon-share{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-share:before{content:""}.vjs-icon-cog{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-cog:before{content:""}.vjs-icon-square{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-square:before{content:""}.vjs-icon-circle,.vjs-seek-to-live-control .vjs-icon-placeholder,.video-js .vjs-volume-level,.video-js .vjs-play-progress{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-circle:before,.vjs-seek-to-live-control .vjs-icon-placeholder:before,.video-js .vjs-volume-level:before,.video-js .vjs-play-progress:before{content:""}.vjs-icon-circle-outline{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-circle-outline:before{content:""}.vjs-icon-circle-inner-circle{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-circle-inner-circle:before{content:""}.vjs-icon-cancel,.video-js .vjs-control.vjs-close-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-cancel:before,.video-js .vjs-control.vjs-close-button .vjs-icon-placeholder:before{content:""}.vjs-icon-repeat{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-repeat:before{content:""}.vjs-icon-replay,.video-js .vjs-play-control.vjs-ended .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-replay:before,.video-js .vjs-play-control.vjs-ended .vjs-icon-placeholder:before{content:""}.vjs-icon-replay-5,.video-js .vjs-skip-backward-5 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-replay-5:before,.video-js .vjs-skip-backward-5 .vjs-icon-placeholder:before{content:""}.vjs-icon-replay-10,.video-js .vjs-skip-backward-10 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-replay-10:before,.video-js .vjs-skip-backward-10 .vjs-icon-placeholder:before{content:""}.vjs-icon-replay-30,.video-js .vjs-skip-backward-30 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-replay-30:before,.video-js .vjs-skip-backward-30 .vjs-icon-placeholder:before{content:""}.vjs-icon-forward-5,.video-js .vjs-skip-forward-5 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-forward-5:before,.video-js .vjs-skip-forward-5 .vjs-icon-placeholder:before{content:""}.vjs-icon-forward-10,.video-js .vjs-skip-forward-10 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-forward-10:before,.video-js .vjs-skip-forward-10 .vjs-icon-placeholder:before{content:""}.vjs-icon-forward-30,.video-js .vjs-skip-forward-30 .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-forward-30:before,.video-js .vjs-skip-forward-30 .vjs-icon-placeholder:before{content:""}.vjs-icon-audio,.video-js .vjs-audio-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-audio:before,.video-js .vjs-audio-button .vjs-icon-placeholder:before{content:""}.vjs-icon-next-item{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-next-item:before{content:""}.vjs-icon-previous-item{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-previous-item:before{content:""}.vjs-icon-shuffle{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-shuffle:before{content:""}.vjs-icon-cast{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-cast:before{content:""}.vjs-icon-picture-in-picture-enter,.video-js .vjs-picture-in-picture-control .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-picture-in-picture-enter:before,.video-js .vjs-picture-in-picture-control .vjs-icon-placeholder:before{content:""}.vjs-icon-picture-in-picture-exit,.video-js.vjs-picture-in-picture .vjs-picture-in-picture-control .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-picture-in-picture-exit:before,.video-js.vjs-picture-in-picture .vjs-picture-in-picture-control .vjs-icon-placeholder:before{content:""}.vjs-icon-facebook{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-facebook:before{content:""}.vjs-icon-linkedin{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-linkedin:before{content:""}.vjs-icon-twitter{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-twitter:before{content:""}.vjs-icon-tumblr{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-tumblr:before{content:""}.vjs-icon-pinterest{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-pinterest:before{content:""}.vjs-icon-audio-description,.video-js .vjs-descriptions-button .vjs-icon-placeholder{font-family:VideoJS;font-weight:400;font-style:normal}.vjs-icon-audio-description:before,.video-js .vjs-descriptions-button .vjs-icon-placeholder:before{content:""}.video-js{display:inline-block;vertical-align:top;box-sizing:border-box;color:#fff;background-color:#000;position:relative;padding:0;font-size:10px;line-height:1;font-weight:400;font-style:normal;font-family:Arial,Helvetica,sans-serif;word-break:initial}.video-js:-moz-full-screen{position:absolute}.video-js:-webkit-full-screen{width:100%!important;height:100%!important}.video-js[tabindex="-1"]{outline:none}.video-js *,.video-js *:before,.video-js *:after{box-sizing:inherit}.video-js ul{font-family:inherit;font-size:inherit;line-height:inherit;list-style-position:outside;margin:0}.video-js.vjs-fluid,.video-js.vjs-16-9,.video-js.vjs-4-3,.video-js.vjs-9-16,.video-js.vjs-1-1{width:100%;max-width:100%}.video-js.vjs-fluid:not(.vjs-audio-only-mode),.video-js.vjs-16-9:not(.vjs-audio-only-mode),.video-js.vjs-4-3:not(.vjs-audio-only-mode),.video-js.vjs-9-16:not(.vjs-audio-only-mode),.video-js.vjs-1-1:not(.vjs-audio-only-mode){height:0}.video-js.vjs-16-9:not(.vjs-audio-only-mode){padding-top:56.25%}.video-js.vjs-4-3:not(.vjs-audio-only-mode){padding-top:75%}.video-js.vjs-9-16:not(.vjs-audio-only-mode){padding-top:177.7777777778%}.video-js.vjs-1-1:not(.vjs-audio-only-mode){padding-top:100%}.video-js.vjs-fill:not(.vjs-audio-only-mode){width:100%;height:100%}.video-js .vjs-tech{position:absolute;top:0;left:0;width:100%;height:100%}.video-js.vjs-audio-only-mode .vjs-tech{display:none}body.vjs-full-window,body.vjs-pip-window{padding:0;margin:0;height:100%}.vjs-full-window .video-js.vjs-fullscreen,body.vjs-pip-window .video-js{position:fixed;overflow:hidden;z-index:1000;inset:0}.video-js.vjs-fullscreen:not(.vjs-ios-native-fs),body.vjs-pip-window .video-js{width:100%!important;height:100%!important;padding-top:0!important;display:block}.video-js.vjs-fullscreen.vjs-user-inactive{cursor:none}.vjs-pip-container .vjs-pip-text{position:absolute;bottom:10%;font-size:2em;background-color:#000000b3;padding:.5em;text-align:center;width:100%}.vjs-layout-tiny.vjs-pip-container .vjs-pip-text,.vjs-layout-x-small.vjs-pip-container .vjs-pip-text,.vjs-layout-small.vjs-pip-container .vjs-pip-text{bottom:0;font-size:1.4em}.vjs-hidden{display:none!important}.vjs-disabled{opacity:.5;cursor:default}.video-js .vjs-offscreen{height:1px;left:-9999px;position:absolute;top:0;width:1px}.vjs-lock-showing{display:block!important;opacity:1!important;visibility:visible!important}.vjs-no-js{padding:20px;color:#fff;background-color:#000;font-size:18px;font-family:Arial,Helvetica,sans-serif;text-align:center;width:300px;height:150px;margin:0 auto}.vjs-no-js a,.vjs-no-js a:visited{color:#66a8cc}.video-js .vjs-big-play-button{font-size:3em;line-height:1.5em;height:1.63332em;width:3em;display:block;position:absolute;top:50%;left:50%;padding:0;margin-top:-.81666em;margin-left:-1.5em;cursor:pointer;opacity:1;border:.06666em solid #fff;background-color:#2b333f;background-color:#2b333fb3;border-radius:.3em;transition:all .4s}.vjs-big-play-button .vjs-svg-icon{width:1em;height:1em;position:absolute;top:50%;left:50%;line-height:1;transform:translate(-50%,-50%)}.video-js:hover .vjs-big-play-button,.video-js .vjs-big-play-button:focus{border-color:#fff;background-color:#73859f;background-color:#73859f80;transition:all 0s}.vjs-controls-disabled .vjs-big-play-button,.vjs-has-started .vjs-big-play-button,.vjs-using-native-controls .vjs-big-play-button,.vjs-error .vjs-big-play-button{display:none}.vjs-has-started.vjs-paused.vjs-show-big-play-button-on-pause:not(.vjs-seeking,.vjs-scrubbing,.vjs-error) .vjs-big-play-button{display:block}.video-js button{background:none;border:none;color:inherit;display:inline-block;font-size:inherit;line-height:inherit;text-transform:none;text-decoration:none;transition:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.video-js.vjs-spatial-navigation-enabled .vjs-button:focus{outline:.0625em solid white;box-shadow:none}.vjs-control .vjs-button{width:100%;height:100%}.video-js .vjs-control.vjs-close-button{cursor:pointer;height:3em;position:absolute;right:0;top:.5em;z-index:2}.video-js .vjs-modal-dialog{background:#000c;background:linear-gradient(180deg,#000c,#fff0);overflow:auto}.video-js .vjs-modal-dialog>*{box-sizing:border-box}.vjs-modal-dialog .vjs-modal-dialog-content{font-size:1.2em;line-height:1.5;padding:20px 24px;z-index:1}.vjs-menu-button{cursor:pointer}.vjs-menu-button.vjs-disabled{cursor:default}.vjs-workinghover .vjs-menu-button.vjs-disabled:hover .vjs-menu{display:none}.vjs-menu .vjs-menu-content{display:block;padding:0;margin:0;font-family:Arial,Helvetica,sans-serif;overflow:auto}.vjs-menu .vjs-menu-content>*{box-sizing:border-box}.vjs-scrubbing .vjs-control.vjs-menu-button:hover .vjs-menu{display:none}.vjs-menu li{display:flex;justify-content:center;list-style:none;margin:0;padding:.2em 0;line-height:1.4em;font-size:1.2em;text-align:center;text-transform:lowercase}.vjs-menu li.vjs-menu-item:focus,.vjs-menu li.vjs-menu-item:hover,.js-focus-visible .vjs-menu li.vjs-menu-item:hover{background-color:#73859f;background-color:#73859f80}.vjs-menu li.vjs-selected,.vjs-menu li.vjs-selected:focus,.vjs-menu li.vjs-selected:hover,.js-focus-visible .vjs-menu li.vjs-selected:hover{background-color:#fff;color:#2b333f}.vjs-menu li.vjs-selected .vjs-svg-icon,.vjs-menu li.vjs-selected:focus .vjs-svg-icon,.vjs-menu li.vjs-selected:hover .vjs-svg-icon,.js-focus-visible .vjs-menu li.vjs-selected:hover .vjs-svg-icon{fill:#000}.video-js .vjs-menu *:not(.vjs-selected):focus:not(:focus-visible),.js-focus-visible .vjs-menu *:not(.vjs-selected):focus:not(.focus-visible){background:none}.vjs-menu li.vjs-menu-title{text-align:center;text-transform:uppercase;font-size:1em;line-height:2em;padding:0;margin:0 0 .3em;font-weight:700;cursor:default}.vjs-menu-button-popup .vjs-menu{display:none;position:absolute;bottom:0;width:10em;left:-3em;height:0em;margin-bottom:1.5em;border-top-color:#2b333fb3}.vjs-pip-window .vjs-menu-button-popup .vjs-menu{left:unset;right:1em}.vjs-menu-button-popup .vjs-menu .vjs-menu-content{background-color:#2b333f;background-color:#2b333fb3;position:absolute;width:100%;bottom:1.5em;max-height:15em}.vjs-layout-tiny .vjs-menu-button-popup .vjs-menu .vjs-menu-content,.vjs-layout-x-small .vjs-menu-button-popup .vjs-menu .vjs-menu-content{max-height:5em}.vjs-layout-small .vjs-menu-button-popup .vjs-menu .vjs-menu-content{max-height:10em}.vjs-layout-medium .vjs-menu-button-popup .vjs-menu .vjs-menu-content{max-height:14em}.vjs-layout-large .vjs-menu-button-popup .vjs-menu .vjs-menu-content,.vjs-layout-x-large .vjs-menu-button-popup .vjs-menu .vjs-menu-content,.vjs-layout-huge .vjs-menu-button-popup .vjs-menu .vjs-menu-content{max-height:25em}.vjs-workinghover .vjs-menu-button-popup.vjs-hover .vjs-menu,.vjs-menu-button-popup .vjs-menu.vjs-lock-showing{display:block}.video-js .vjs-menu-button-inline{transition:all .4s;overflow:hidden}.video-js .vjs-menu-button-inline:before{width:2.222222222em}.video-js .vjs-menu-button-inline:hover,.video-js .vjs-menu-button-inline:focus,.video-js .vjs-menu-button-inline.vjs-slider-active{width:12em}.vjs-menu-button-inline .vjs-menu{opacity:0;height:100%;width:auto;position:absolute;left:4em;top:0;padding:0;margin:0;transition:all .4s}.vjs-menu-button-inline:hover .vjs-menu,.vjs-menu-button-inline:focus .vjs-menu,.vjs-menu-button-inline.vjs-slider-active .vjs-menu{display:block;opacity:1}.vjs-menu-button-inline .vjs-menu-content{width:auto;height:100%;margin:0;overflow:hidden}.video-js .vjs-control-bar{display:none;width:100%;position:absolute;bottom:0;left:0;right:0;height:3em;background-color:#2b333f;background-color:#2b333fb3}.video-js.vjs-spatial-navigation-enabled .vjs-control-bar{gap:1px}.video-js:not(.vjs-controls-disabled,.vjs-using-native-controls,.vjs-error) .vjs-control-bar.vjs-lock-showing{display:flex!important}.vjs-has-started .vjs-control-bar,.vjs-audio-only-mode .vjs-control-bar{display:flex;visibility:visible;opacity:1;transition:visibility .1s,opacity .1s}.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar{visibility:visible;opacity:0;pointer-events:none;transition:visibility 1s,opacity 1s}.vjs-controls-disabled .vjs-control-bar,.vjs-using-native-controls .vjs-control-bar,.vjs-error .vjs-control-bar{display:none!important}.vjs-audio.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar,.vjs-audio-only-mode.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar{opacity:1;visibility:visible;pointer-events:auto}.video-js .vjs-control{position:relative;text-align:center;margin:0;padding:0;height:100%;width:4em;flex:none}.video-js .vjs-control.vjs-visible-text{width:auto;padding-left:1em;padding-right:1em}.vjs-button>.vjs-icon-placeholder:before{font-size:1.8em;line-height:1.67}.vjs-button>.vjs-icon-placeholder{display:block}.vjs-button>.vjs-svg-icon{display:inline-block}.video-js .vjs-control:focus:before,.video-js .vjs-control:hover:before,.video-js .vjs-control:focus{text-shadow:0em 0em 1em white}.video-js *:not(.vjs-visible-text)>.vjs-control-text{border:0;clip:rect(0 0 0 0);height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.video-js .vjs-custom-control-spacer{display:none}.video-js .vjs-progress-control{cursor:pointer;flex:auto;display:flex;align-items:center;min-width:4em;touch-action:none}.video-js .vjs-progress-control.disabled{cursor:default}.vjs-live .vjs-progress-control{display:none}.vjs-liveui .vjs-progress-control{display:flex;align-items:center}.video-js .vjs-progress-holder{flex:auto;transition:all .2s;height:.3em}.video-js .vjs-progress-control .vjs-progress-holder{margin:0 10px}.video-js .vjs-progress-control:hover .vjs-progress-holder,.video-js.vjs-scrubbing.vjs-touch-enabled .vjs-progress-control .vjs-progress-holder{font-size:1.6666666667em}.video-js .vjs-progress-control:hover .vjs-progress-holder.disabled{font-size:1em}.video-js .vjs-progress-holder .vjs-play-progress,.video-js .vjs-progress-holder .vjs-load-progress,.video-js .vjs-progress-holder .vjs-load-progress div{position:absolute;display:block;height:100%;margin:0;padding:0;width:0}.video-js .vjs-play-progress{background-color:#fff}.video-js .vjs-play-progress:before{font-size:.9em;position:absolute;right:-.5em;line-height:.35em;z-index:1}.vjs-svg-icons-enabled .vjs-play-progress:before{content:none!important}.vjs-play-progress .vjs-svg-icon{position:absolute;top:-.35em;right:-.4em;width:.9em;height:.9em;pointer-events:none;line-height:.15em;z-index:1}.video-js .vjs-load-progress{background:#73859f80}.video-js .vjs-load-progress div{background:#73859fbf}.video-js .vjs-time-tooltip{background-color:#fff;background-color:#fffc;border-radius:.3em;color:#000;float:right;font-family:Arial,Helvetica,sans-serif;font-size:1em;padding:6px 8px 8px;pointer-events:none;position:absolute;top:-3.4em;visibility:hidden;z-index:1}.video-js .vjs-progress-holder:focus .vjs-time-tooltip{display:none}.video-js .vjs-progress-control:hover .vjs-time-tooltip,.video-js .vjs-progress-control:hover .vjs-progress-holder:focus .vjs-time-tooltip,.video-js.vjs-scrubbing.vjs-touch-enabled .vjs-progress-control .vjs-time-tooltip{display:block;font-size:.6em;visibility:visible}.video-js .vjs-progress-control.disabled:hover .vjs-time-tooltip{font-size:1em}.video-js .vjs-progress-control .vjs-mouse-display{display:none;position:absolute;width:1px;height:100%;background-color:#000;z-index:1}.video-js .vjs-progress-control:hover .vjs-mouse-display,.video-js.vjs-scrubbing.vjs-touch-enabled .vjs-progress-control .vjs-mouse-display{display:block}.video-js.vjs-user-inactive .vjs-progress-control .vjs-mouse-display,.video-js.vjs-touch-enabled:not(.vjs-scrubbing) .vjs-progress-control .vjs-mouse-display{visibility:hidden;opacity:0;transition:visibility 1s,opacity 1s}.vjs-mouse-display .vjs-time-tooltip{color:#fff;background-color:#000;background-color:#000c}.video-js .vjs-slider{position:relative;cursor:pointer;padding:0;margin:0 .45em;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;background-color:#73859f;background-color:#73859f80}.video-js .vjs-slider.disabled{cursor:default}.video-js .vjs-slider:focus{text-shadow:0em 0em 1em white;box-shadow:0 0 1em #fff}.video-js.vjs-spatial-navigation-enabled .vjs-slider:focus{outline:.0625em solid white}.video-js .vjs-mute-control{cursor:pointer;flex:none}.video-js .vjs-volume-control{cursor:pointer;margin-right:1em;display:flex}.video-js .vjs-volume-control.vjs-volume-horizontal{width:5em}.video-js .vjs-volume-panel .vjs-volume-control{visibility:visible;opacity:0;width:1px;height:1px;margin-left:-1px}.video-js .vjs-volume-panel{transition:width 1s}.video-js .vjs-volume-panel.vjs-hover .vjs-volume-control,.video-js .vjs-volume-panel:active .vjs-volume-control,.video-js .vjs-volume-panel:focus .vjs-volume-control,.video-js .vjs-volume-panel .vjs-volume-control:active,.video-js .vjs-volume-panel.vjs-hover .vjs-mute-control~.vjs-volume-control,.video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active{visibility:visible;opacity:1;position:relative;transition:visibility .1s,opacity .1s,height .1s,width .1s,left 0s,top 0s}.video-js .vjs-volume-panel.vjs-hover .vjs-volume-control.vjs-volume-horizontal,.video-js .vjs-volume-panel:active .vjs-volume-control.vjs-volume-horizontal,.video-js .vjs-volume-panel:focus .vjs-volume-control.vjs-volume-horizontal,.video-js .vjs-volume-panel .vjs-volume-control:active.vjs-volume-horizontal,.video-js .vjs-volume-panel.vjs-hover .vjs-mute-control~.vjs-volume-control.vjs-volume-horizontal,.video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active.vjs-volume-horizontal{width:5em;height:3em;margin-right:0}.video-js .vjs-volume-panel.vjs-hover .vjs-volume-control.vjs-volume-vertical,.video-js .vjs-volume-panel:active .vjs-volume-control.vjs-volume-vertical,.video-js .vjs-volume-panel:focus .vjs-volume-control.vjs-volume-vertical,.video-js .vjs-volume-panel .vjs-volume-control:active.vjs-volume-vertical,.video-js .vjs-volume-panel.vjs-hover .vjs-mute-control~.vjs-volume-control.vjs-volume-vertical,.video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active.vjs-volume-vertical{left:-3.5em;transition:left 0s}.video-js .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-hover,.video-js .vjs-volume-panel.vjs-volume-panel-horizontal:active,.video-js .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-slider-active{width:10em;transition:width .1s}.video-js .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-mute-toggle-only{width:4em}.video-js .vjs-volume-panel .vjs-volume-control.vjs-volume-vertical{height:8em;width:3em;left:-3000em;transition:visibility 1s,opacity 1s,height 1s 1s,width 1s 1s,left 1s 1s,top 1s 1s}.video-js .vjs-volume-panel .vjs-volume-control.vjs-volume-horizontal{transition:visibility 1s,opacity 1s,height 1s 1s,width 1s,left 1s 1s,top 1s 1s}.video-js .vjs-volume-panel{display:flex}.video-js .vjs-volume-bar{margin:1.35em .45em}.vjs-volume-bar.vjs-slider-horizontal{width:5em;height:.3em}.vjs-volume-bar.vjs-slider-vertical{width:.3em;height:5em;margin:1.35em auto}.video-js .vjs-volume-level{position:absolute;bottom:0;left:0;background-color:#fff}.video-js .vjs-volume-level:before{position:absolute;font-size:.9em;z-index:1}.vjs-slider-vertical .vjs-volume-level{width:.3em}.vjs-slider-vertical .vjs-volume-level:before{top:-.5em;left:-.3em;z-index:1}.vjs-svg-icons-enabled .vjs-volume-level:before{content:none}.vjs-volume-level .vjs-svg-icon{position:absolute;width:.9em;height:.9em;pointer-events:none;z-index:1}.vjs-slider-horizontal .vjs-volume-level{height:.3em}.vjs-slider-horizontal .vjs-volume-level:before{line-height:.35em;right:-.5em}.vjs-slider-horizontal .vjs-volume-level .vjs-svg-icon{right:-.3em;transform:translateY(-50%)}.vjs-slider-vertical .vjs-volume-level .vjs-svg-icon{top:-.55em;transform:translate(-50%)}.video-js .vjs-volume-panel.vjs-volume-panel-vertical{width:4em}.vjs-volume-bar.vjs-slider-vertical .vjs-volume-level{height:100%}.vjs-volume-bar.vjs-slider-horizontal .vjs-volume-level{width:100%}.video-js .vjs-volume-vertical{width:3em;height:8em;bottom:8em;background-color:#2b333f;background-color:#2b333fb3}.video-js .vjs-volume-horizontal .vjs-menu{left:-2em}.video-js .vjs-volume-tooltip{background-color:#fff;background-color:#fffc;border-radius:.3em;color:#000;float:right;font-family:Arial,Helvetica,sans-serif;font-size:1em;padding:6px 8px 8px;pointer-events:none;position:absolute;top:-3.4em;visibility:hidden;z-index:1}.video-js .vjs-volume-control:hover .vjs-volume-tooltip,.video-js .vjs-volume-control:hover .vjs-progress-holder:focus .vjs-volume-tooltip{display:block;font-size:1em;visibility:visible}.video-js .vjs-volume-vertical:hover .vjs-volume-tooltip,.video-js .vjs-volume-vertical:hover .vjs-progress-holder:focus .vjs-volume-tooltip{left:1em;top:-12px}.video-js .vjs-volume-control.disabled:hover .vjs-volume-tooltip{font-size:1em}.video-js .vjs-volume-control .vjs-mouse-display{display:none;position:absolute;width:100%;height:1px;background-color:#000;z-index:1}.video-js .vjs-volume-horizontal .vjs-mouse-display{width:1px;height:100%}.video-js .vjs-volume-control:hover .vjs-mouse-display{display:block}.video-js.vjs-user-inactive .vjs-volume-control .vjs-mouse-display{visibility:hidden;opacity:0;transition:visibility 1s,opacity 1s}.vjs-mouse-display .vjs-volume-tooltip{color:#fff;background-color:#000;background-color:#000c}.vjs-poster{display:inline-block;vertical-align:middle;cursor:pointer;margin:0;padding:0;position:absolute;inset:0;height:100%}.vjs-has-started .vjs-poster,.vjs-using-native-controls .vjs-poster{display:none}.vjs-audio.vjs-has-started .vjs-poster,.vjs-has-started.vjs-audio-poster-mode .vjs-poster,.vjs-pip-container.vjs-has-started .vjs-poster{display:block}.vjs-poster img{width:100%;height:100%;object-fit:contain}.video-js .vjs-live-control{display:flex;align-items:flex-start;flex:auto;font-size:1em;line-height:3em}.video-js:not(.vjs-live) .vjs-live-control,.video-js.vjs-liveui .vjs-live-control{display:none}.video-js .vjs-seek-to-live-control{align-items:center;cursor:pointer;flex:none;display:inline-flex;height:100%;padding-left:.5em;padding-right:.5em;font-size:1em;line-height:3em;width:auto;min-width:4em}.video-js.vjs-live:not(.vjs-liveui) .vjs-seek-to-live-control,.video-js:not(.vjs-live) .vjs-seek-to-live-control{display:none}.vjs-seek-to-live-control.vjs-control.vjs-at-live-edge{cursor:auto}.vjs-seek-to-live-control .vjs-icon-placeholder{margin-right:.5em;color:#888}.vjs-svg-icons-enabled .vjs-seek-to-live-control{line-height:0}.vjs-seek-to-live-control .vjs-svg-icon{width:1em;height:1em;pointer-events:none;fill:#888}.vjs-seek-to-live-control.vjs-control.vjs-at-live-edge .vjs-icon-placeholder{color:red}.vjs-seek-to-live-control.vjs-control.vjs-at-live-edge .vjs-svg-icon{fill:red}.video-js .vjs-time-control{flex:none;font-size:1em;line-height:3em;min-width:2em;width:auto;padding-left:1em;padding-right:1em}.vjs-live .vjs-time-control,.vjs-live .vjs-time-divider,.video-js .vjs-current-time,.video-js .vjs-duration{display:none}.vjs-time-divider{display:none;line-height:3em}.vjs-normalise-time-controls:not(.vjs-live) .vjs-time-control{display:flex}.video-js .vjs-play-control{cursor:pointer}.video-js .vjs-play-control .vjs-icon-placeholder{flex:none}.vjs-text-track-display{position:absolute;inset:0 0 3em;pointer-events:none}.vjs-error .vjs-text-track-display{display:none}.video-js.vjs-controls-disabled .vjs-text-track-display,.video-js.vjs-user-inactive.vjs-playing .vjs-text-track-display{bottom:1em}.video-js .vjs-text-track{font-size:1.4em;text-align:center;margin-bottom:.1em}.vjs-subtitles{color:#fff}.vjs-captions{color:#fc6}.vjs-tt-cue{display:block}video::-webkit-media-text-track-display{transform:translateY(-3em)}.video-js.vjs-controls-disabled video::-webkit-media-text-track-display,.video-js.vjs-user-inactive.vjs-playing video::-webkit-media-text-track-display{transform:translateY(-1.5em)}.video-js.vjs-force-center-align-cues .vjs-text-track-cue{text-align:center!important;width:80%!important}@supports not (inset: 10px){.video-js .vjs-text-track-display>div{inset:0}}.video-js .vjs-picture-in-picture-control{cursor:pointer;flex:none}.video-js.vjs-audio-only-mode .vjs-picture-in-picture-control,.vjs-pip-window .vjs-picture-in-picture-control{display:none}.video-js .vjs-fullscreen-control{cursor:pointer;flex:none}.video-js.vjs-audio-only-mode .vjs-fullscreen-control,.vjs-pip-window .vjs-fullscreen-control{display:none}.vjs-playback-rate>.vjs-menu-button,.vjs-playback-rate .vjs-playback-rate-value{position:absolute;top:0;left:0;width:100%;height:100%}.vjs-playback-rate .vjs-playback-rate-value{pointer-events:none;font-size:1.5em;line-height:2;text-align:center}.vjs-playback-rate .vjs-menu{width:4em;left:0}.vjs-error .vjs-error-display .vjs-modal-dialog-content{font-size:1.4em;text-align:center}.vjs-loading-spinner{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.85;text-align:left;border:.6em solid rgba(43,51,63,.7);box-sizing:border-box;background-clip:padding-box;width:5em;height:5em;border-radius:50%;visibility:hidden}.vjs-seeking .vjs-loading-spinner,.vjs-waiting .vjs-loading-spinner{display:flex;justify-content:center;align-items:center;animation:vjs-spinner-show 0s linear .3s forwards}.vjs-error .vjs-loading-spinner{display:none}.vjs-loading-spinner:before,.vjs-loading-spinner:after{content:"";position:absolute;box-sizing:inherit;width:inherit;height:inherit;border-radius:inherit;opacity:1;border:inherit;border-color:transparent;border-top-color:#fff}.vjs-seeking .vjs-loading-spinner:before,.vjs-seeking .vjs-loading-spinner:after,.vjs-waiting .vjs-loading-spinner:before,.vjs-waiting .vjs-loading-spinner:after{animation:vjs-spinner-spin 1.1s cubic-bezier(.6,.2,0,.8) infinite,vjs-spinner-fade 1.1s linear infinite}.vjs-seeking .vjs-loading-spinner:before,.vjs-waiting .vjs-loading-spinner:before{border-top-color:#fff}.vjs-seeking .vjs-loading-spinner:after,.vjs-waiting .vjs-loading-spinner:after{border-top-color:#fff;animation-delay:.44s}@keyframes vjs-spinner-show{to{visibility:visible}}@keyframes vjs-spinner-spin{to{transform:rotate(360deg)}}@keyframes vjs-spinner-fade{0%{border-top-color:#73859f}20%{border-top-color:#73859f}35%{border-top-color:#fff}60%{border-top-color:#73859f}to{border-top-color:#73859f}}.video-js.vjs-audio-only-mode .vjs-captions-button{display:none}.vjs-chapters-button .vjs-menu ul{width:24em}.video-js.vjs-audio-only-mode .vjs-descriptions-button{display:none}.vjs-subs-caps-button+.vjs-menu .vjs-captions-menu-item .vjs-svg-icon{width:1.5em;height:1.5em}.video-js .vjs-subs-caps-button+.vjs-menu .vjs-captions-menu-item .vjs-menu-item-text .vjs-icon-placeholder{vertical-align:middle;display:inline-block;margin-bottom:-.1em}.video-js .vjs-subs-caps-button+.vjs-menu .vjs-captions-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before{font-family:VideoJS;content:"";font-size:1.5em;line-height:inherit}.video-js.vjs-audio-only-mode .vjs-subs-caps-button{display:none}.video-js .vjs-audio-button+.vjs-menu .vjs-descriptions-menu-item .vjs-menu-item-text .vjs-icon-placeholder,.video-js .vjs-audio-button+.vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder{vertical-align:middle;display:inline-block;margin-bottom:-.1em}.video-js .vjs-audio-button+.vjs-menu .vjs-descriptions-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before,.video-js .vjs-audio-button+.vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before{font-family:VideoJS;content:" ";font-size:1.5em;line-height:inherit}.video-js.vjs-layout-small .vjs-current-time,.video-js.vjs-layout-small .vjs-time-divider,.video-js.vjs-layout-small .vjs-duration,.video-js.vjs-layout-small .vjs-remaining-time,.video-js.vjs-layout-small .vjs-playback-rate,.video-js.vjs-layout-small .vjs-volume-control,.video-js.vjs-layout-x-small .vjs-current-time,.video-js.vjs-layout-x-small .vjs-time-divider,.video-js.vjs-layout-x-small .vjs-duration,.video-js.vjs-layout-x-small .vjs-remaining-time,.video-js.vjs-layout-x-small .vjs-playback-rate,.video-js.vjs-layout-x-small .vjs-volume-control,.video-js.vjs-layout-tiny .vjs-current-time,.video-js.vjs-layout-tiny .vjs-time-divider,.video-js.vjs-layout-tiny .vjs-duration,.video-js.vjs-layout-tiny .vjs-remaining-time,.video-js.vjs-layout-tiny .vjs-playback-rate,.video-js.vjs-layout-tiny .vjs-volume-control{display:none}.video-js.vjs-layout-small .vjs-volume-panel.vjs-volume-panel-horizontal:hover,.video-js.vjs-layout-small .vjs-volume-panel.vjs-volume-panel-horizontal:active,.video-js.vjs-layout-small .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-slider-active,.video-js.vjs-layout-small .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-hover,.video-js.vjs-layout-x-small .vjs-volume-panel.vjs-volume-panel-horizontal:hover,.video-js.vjs-layout-x-small .vjs-volume-panel.vjs-volume-panel-horizontal:active,.video-js.vjs-layout-x-small .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-slider-active,.video-js.vjs-layout-x-small .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-hover,.video-js.vjs-layout-tiny .vjs-volume-panel.vjs-volume-panel-horizontal:hover,.video-js.vjs-layout-tiny .vjs-volume-panel.vjs-volume-panel-horizontal:active,.video-js.vjs-layout-tiny .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-slider-active,.video-js.vjs-layout-tiny .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-hover{width:auto;width:initial}.video-js.vjs-layout-x-small .vjs-progress-control,.video-js.vjs-layout-tiny .vjs-progress-control{display:none}.video-js.vjs-layout-x-small .vjs-custom-control-spacer{flex:auto;display:block}.vjs-modal-dialog.vjs-text-track-settings{background-color:#2b333f;background-color:#2b333fbf;color:#fff;height:70%}.vjs-spatial-navigation-enabled .vjs-modal-dialog.vjs-text-track-settings{height:80%}.vjs-error .vjs-text-track-settings{display:none}.vjs-text-track-settings .vjs-modal-dialog-content{display:table}.vjs-text-track-settings .vjs-track-settings-colors,.vjs-text-track-settings .vjs-track-settings-font,.vjs-text-track-settings .vjs-track-settings-controls{display:table-cell}.vjs-text-track-settings .vjs-track-settings-controls{text-align:right;vertical-align:bottom}@supports (display: grid){.vjs-text-track-settings .vjs-modal-dialog-content{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr;padding:20px 24px 0}.vjs-track-settings-controls .vjs-default-button{margin-bottom:20px}.vjs-text-track-settings .vjs-track-settings-controls{grid-column:1/-1}.vjs-layout-small .vjs-text-track-settings .vjs-modal-dialog-content,.vjs-layout-x-small .vjs-text-track-settings .vjs-modal-dialog-content,.vjs-layout-tiny .vjs-text-track-settings .vjs-modal-dialog-content{grid-template-columns:1fr}}.vjs-text-track-settings select{font-size:inherit}.vjs-track-setting>select{margin-right:1em;margin-bottom:.5em}.vjs-text-track-settings fieldset{margin:10px;border:none}.vjs-text-track-settings fieldset span{display:inline-block;padding:0 .6em .8em}.vjs-text-track-settings fieldset span>select{max-width:7.3em}.vjs-text-track-settings legend{color:#fff;font-weight:700;font-size:1.2em}.vjs-text-track-settings .vjs-label{margin:0 .5em .5em 0}.vjs-track-settings-controls button:focus,.vjs-track-settings-controls button:active{outline-style:solid;outline-width:medium;background-image:linear-gradient(0deg,#fff 88%,#73859f)}.vjs-track-settings-controls button:hover{color:#2b333fbf}.vjs-track-settings-controls button{background-color:#fff;background-image:linear-gradient(-180deg,#fff 88%,#73859f);color:#2b333f;cursor:pointer;border-radius:2px}.vjs-track-settings-controls .vjs-default-button{margin-right:1em}.vjs-title-bar{background:#000000e6;background:linear-gradient(180deg,#000000e6,#000000b3 60%,#0000);font-size:1.2em;line-height:1.5;transition:opacity .1s;padding:.666em 1.333em 4em;pointer-events:none;position:absolute;top:0;width:100%}.vjs-error .vjs-title-bar{display:none}.vjs-title-bar-title,.vjs-title-bar-description{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vjs-title-bar-title{font-weight:700;margin-bottom:.333em}.vjs-playing.vjs-user-inactive .vjs-title-bar{opacity:0;transition:opacity 1s}.video-js .vjs-skip-forward-5,.video-js .vjs-skip-forward-10,.video-js .vjs-skip-forward-30,.video-js .vjs-skip-backward-5,.video-js .vjs-skip-backward-10,.video-js .vjs-skip-backward-30{cursor:pointer}.video-js .vjs-transient-button{position:absolute;height:3em;display:flex;align-items:center;justify-content:center;background-color:#32323280;cursor:pointer;opacity:1;transition:opacity 1s}.video-js:not(.vjs-has-started) .vjs-transient-button{display:none}.video-js.not-hover .vjs-transient-button:not(.force-display),.video-js.vjs-user-inactive .vjs-transient-button:not(.force-display){opacity:0}.video-js .vjs-transient-button span{padding:0 .5em}.video-js .vjs-transient-button.vjs-left{left:1em}.video-js .vjs-transient-button.vjs-right{right:1em}.video-js .vjs-transient-button.vjs-top{top:1em}.video-js .vjs-transient-button.vjs-near-top{top:4em}.video-js .vjs-transient-button.vjs-bottom{bottom:4em}.video-js .vjs-transient-button:hover{background-color:#323232e6}@media print{.video-js>*:not(.vjs-tech):not(.vjs-poster){visibility:hidden}}.vjs-resize-manager{position:absolute;top:0;left:0;width:100%;height:100%;border:none;z-index:-1000}.js-focus-visible .video-js *:focus:not(.focus-visible){outline:none}.video-js *:focus:not(:focus-visible){outline:none}.video-editor-page{display:flex;height:calc(100vh - var(--toolbar-height, 90px));background:#1a1a1a;color:#fff;overflow:hidden}.video-editor-sidebar{width:500px;background:#252525;border-right:1px solid #3a3a3a;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:var(--spacing-md);border-bottom:1px solid #3a3a3a;display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{margin:0;font-size:1rem;font-weight:600;color:#fff}.sidebar-header-actions{display:flex;gap:var(--spacing-sm)}.icon-button{background:transparent;border:none;color:#fff;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:background var(--transition-base);font-size:1rem}.icon-button:hover{background:#3a3a3a}.composition-selector{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #3a3a3a;display:flex;align-items:center;gap:var(--spacing-xs)}.composition-dropdown{flex:1;background:#1a1a1a;border:1px solid #3a3a3a;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:border-color var(--transition-base)}.composition-dropdown:hover{border-color:var(--accent-primary)}.composition-dropdown:focus{outline:none;border-color:var(--accent-primary)}.video-editor-page .assets-grid,.video-editor-sidebar .assets-grid{flex:1;overflow-y:auto;padding:var(--spacing-md);display:grid!important;grid-template-columns:216px 216px!important;gap:var(--spacing-md)!important;align-content:start!important;justify-content:start!important;width:100%!important;grid-auto-flow:row!important}.video-editor-sidebar .assets-grid .asset-thumbnail{display:flex!important;flex-direction:column!important;background:#1a1a1a!important;border:1px solid #3a3a3a!important;border-radius:var(--radius-sm)!important;overflow:hidden!important;cursor:grab!important;position:relative!important;transition:transform var(--transition-base),border-color var(--transition-base)!important;box-shadow:0 2px 8px #0003!important;width:216px!important;min-width:216px!important;max-width:216px!important;height:auto!important;min-height:165px!important;flex-shrink:0!important;padding:0!important;grid-column:span 1!important;grid-row:auto!important}.video-editor-sidebar .assets-grid .asset-thumbnail:active{cursor:grabbing!important}.video-editor-sidebar .assets-grid .asset-thumbnail:hover{transform:scale(1.03)!important;border-color:var(--accent-primary)!important;box-shadow:0 4px 16px #6c4ab680!important;z-index:10!important}.video-editor-sidebar .assets-grid .asset-thumbnail-image{position:relative!important;width:216px!important;height:165px!important;min-width:216px!important;min-height:165px!important;max-width:216px!important;max-height:165px!important;overflow:hidden!important;flex-shrink:0!important;display:block!important;background:#1a1a1a!important}.video-editor-sidebar .assets-grid .asset-thumbnail-image img,.video-editor-sidebar .assets-grid .asset-thumbnail-image video{width:100%!important;height:100%!important;object-fit:contain!important;display:block!important;flex-shrink:0!important}.video-editor-sidebar .assets-grid .asset-thumbnail-name{padding:var(--spacing-xs)!important;font-size:.7rem!important;color:#fff!important;text-align:left!important;background:transparent!important;border-top:none!important;white-space:normal!important;overflow:hidden!important;text-overflow:ellipsis!important;font-weight:400!important;line-height:1.3!important;flex-shrink:0!important;display:block!important;max-width:216px!important}.video-editor-sidebar .assets-grid .asset-thumbnail-name .asset-name-text{display:block!important;margin-bottom:2px!important;color:#fff!important}.video-editor-sidebar .assets-grid .asset-thumbnail-name .asset-date-text{display:block!important;font-size:.7rem!important;color:#888!important}.play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem}.video-editor-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.video-preview-container{flex:1;background:#1a1a1a;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);min-height:0}.video-preview{width:100%;height:100%;max-width:100%;max-height:100%;background:#000;border-radius:var(--radius-md);overflow:hidden;position:relative}.video-buffering-overlay{position:absolute;inset:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:1rem}.buffering-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.buffering-text{color:#fff;font-size:1.1rem;font-weight:500}.buffering-progress{width:300px;max-width:80%;background:#ffffff1a;border-radius:4px;height:8px;position:relative;overflow:hidden}.buffering-progress-bar{height:100%;background:linear-gradient(90deg,#4a9eff,#6bb6ff);border-radius:4px;transition:width .3s ease}.buffering-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.75rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5)}.video-frame{width:100%;height:100%;position:relative}.video-frame video,.video-frame img{width:100%;height:100%;object-fit:contain}.video-overlay-text{position:absolute;bottom:var(--spacing-md);right:var(--spacing-md);color:#fff;font-size:.875rem;background:#00000080;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}.empty-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#888;font-size:1rem}.video-timeline-container{background:#252525;border-top:1px solid #3a3a3a;display:flex;flex-direction:column;min-height:200px}.timeline-controls{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #3a3a3a;display:flex;align-items:center;gap:var(--spacing-md)}.play-button{background:var(--accent-primary);border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--transition-base)}.play-button:hover{background:var(--accent-primary-hover)}.time-display{font-family:Courier New,monospace;font-size:.875rem;color:#fff;min-width:120px}.zoom-slider{width:100px;height:4px;background:#3a3a3a;border-radius:2px;outline:none;-webkit-appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer}.zoom-slider::-moz-range-thumb{width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.volume-control{display:flex;align-items:center;gap:var(--spacing-xs)}.volume-slider{width:80px;height:4px;background:#3a3a3a;border-radius:2px;outline:none;-webkit-appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer}.export-button{background:var(--accent-primary);border:none;color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-weight:600;transition:background var(--transition-base);margin-left:auto}.export-button:hover{background:var(--accent-primary-hover)}.timeline-track{flex:1;position:relative;background:#1a1a1a;min-height:120px;padding:var(--spacing-md) 0;overflow-x:auto;overflow-y:hidden}.time-markers{position:absolute;top:0;left:0;right:0;height:20px;border-bottom:1px solid #3a3a3a}.time-marker{position:absolute;top:0;height:100%;border-left:1px solid #3a3a3a;transition:border-color var(--transition-base);cursor:pointer}.time-marker:hover{border-left-color:var(--accent-primary)}.marker-label{position:absolute;top:2px;left:4px;font-size:.75rem;color:#888;pointer-events:none;-webkit-user-select:none;user-select:none}.playhead{position:absolute;top:0;bottom:0;width:2px;background:#fff;z-index:10;pointer-events:none}.playhead-line{width:100%;height:100%;background:#fff}.playhead-circle{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:14px;height:14px;background:#fff;border-radius:50%;border:2px solid #1a1a1a}.clips-container{position:absolute;inset:20px 0 0;padding:var(--spacing-md) 0}.timeline-clip{position:absolute;height:80px;background:#3a3a3a;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);overflow:hidden;cursor:move;display:flex;flex-direction:column}.timeline-clip:hover{border-color:var(--accent-primary-hover);box-shadow:0 2px 8px #6c4ab64d}.clip-thumbnail{flex:1;overflow:hidden;position:relative}.clip-thumbnail img,.clip-thumbnail video{width:100%;height:100%;object-fit:cover}.video-frame-strip{display:flex;width:100%;height:100%;overflow:hidden}.video-frame-thumbnail{height:100%;border-right:1px solid rgba(255,255,255,.1);transition:opacity .2s,transform .2s;flex-shrink:0}.video-frame-thumbnail:hover{opacity:.8;transform:scale(1.05);z-index:10;border-right:1px solid var(--accent-primary)}.video-frame-thumbnail:last-child{border-right:none}.video-frame-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#888;font-size:.75rem;background:#2a2a2a}.clip-controls{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs);background:#000000b3;font-size:.75rem}.clip-delete{background:transparent;border:none;color:#f44;cursor:pointer;font-size:1rem;padding:0 var(--spacing-xs)}.clip-duration-input{width:50px;background:#1a1a1a;border:1px solid #3a3a3a;color:#fff;padding:2px 4px;border-radius:var(--radius-sm);font-size:.75rem}.add-clip-button{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);background:var(--accent-primary);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center}.audio-track{display:flex;border-top:1px solid #3a3a3a;min-height:60px}.track-label{width:80px;padding:var(--spacing-sm);border-right:1px solid #3a3a3a;display:flex;align-items:center;font-size:.875rem;color:#888}.audio-clips{flex:1;position:relative;background:#1a1a1a}.audio-clip{position:absolute;height:100%;background:#4a4a4a;border:1px solid #6a6a6a;border-radius:var(--radius-sm);display:flex;align-items:center;padding:0 var(--spacing-sm);font-size:.75rem;color:#fff}.audio-upload-section{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid #3a3a3a}.audio-upload-button{display:inline-block;background:#3a3a3a;border:1px dashed #6a6a6a;color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:background var(--transition-base)}.audio-upload-button:hover{background:#4a4a4a}.assets-grid::-webkit-scrollbar,.timeline-track::-webkit-scrollbar{width:8px;height:8px}.assets-grid::-webkit-scrollbar-track,.timeline-track::-webkit-scrollbar-track{background:#1a1a1a}.assets-grid::-webkit-scrollbar-thumb,.timeline-track::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:4px}.assets-grid::-webkit-scrollbar-thumb:hover,.timeline-track::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.composition-controls{padding:var(--spacing-md);border-bottom:1px solid #3a3a3a;display:flex;flex-direction:column;gap:var(--spacing-sm)}.composition-name-input{width:100%;background:#1a1a1a;border:1px solid #3a3a3a;color:#fff;padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem}.composition-name-input:focus{outline:none;border-color:var(--accent-primary)}.composition-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-save-composition{background:var(--accent-primary);border:none;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:background var(--transition-base)}.btn-save-composition:hover{background:var(--accent-primary-hover)}.auto-save-toggle{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:#888;cursor:pointer}.auto-save-toggle input[type=checkbox]{cursor:pointer}.properties-panel{width:350px;background:#252525;border-left:1px solid #3a3a3a;display:flex;flex-direction:column;overflow:hidden}.properties-header{padding:var(--spacing-md);border-bottom:1px solid #3a3a3a;display:flex;justify-content:space-between;align-items:center}.properties-header h3{margin:0;font-size:1rem;font-weight:600;color:#fff}.properties-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.property-group{margin-bottom:var(--spacing-md)}.property-group label{display:block;font-size:.875rem;color:#ccc;margin-bottom:var(--spacing-xs)}.property-group input[type=range]{width:100%;height:4px;background:#3a3a3a;border-radius:2px;outline:none;-webkit-appearance:none;margin-bottom:var(--spacing-xs)}.property-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer}.property-group input[type=range]::-moz-range-thumb{width:12px;height:12px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.property-group input[type=number],.property-group input[type=text],.property-group select{width:100%;background:#1a1a1a;border:1px solid #3a3a3a;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem}.property-group input[type=color]{width:100%;height:40px;border:1px solid #3a3a3a;border-radius:var(--radius-sm);cursor:pointer}.property-group span{display:inline-block;margin-left:var(--spacing-xs);font-size:.75rem;color:#888}.timeline-clip.selected{border-color:#fff;box-shadow:0 0 0 2px var(--accent-primary)}.clip-transition-badge,.clip-speed-badge{position:absolute;top:2px;right:2px;background:#000c;color:#fff;padding:2px 6px;border-radius:3px;font-size:.65rem;font-weight:600}.clip-speed-badge{top:20px}.text-overlay{-webkit-user-select:none;user-select:none;z-index:100}.text-overlays-track{display:flex;border-top:1px solid #3a3a3a;min-height:50px}.text-clips{flex:1;position:relative;background:#1a1a1a}.text-clip{position:absolute;height:100%;background:#6c4ab64d;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);display:flex;align-items:center;padding:0 var(--spacing-sm);font-size:.75rem;color:#fff;cursor:pointer}.text-overlays-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.text-overlay-item{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:var(--radius-sm);padding:var(--spacing-md)}.text-overlay-header{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.text-input{flex:1;background:#252525;border:1px solid #3a3a3a;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem}.btn-add-text{width:100%;background:var(--accent-primary);border:none;color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-weight:600;margin-bottom:var(--spacing-md);transition:background var(--transition-base)}.btn-add-text:hover{background:var(--accent-primary-hover)}.effects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-top:var(--spacing-md)}.effect-item{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:var(--radius-sm);padding:var(--spacing-md);text-align:center;cursor:pointer;transition:all var(--transition-base);font-size:.875rem}.effect-item:hover{border-color:var(--accent-primary);background:#2a2a2a}.effect-item.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.speed-control{display:flex;align-items:center;gap:var(--spacing-xs)}.speed-select{background:#1a1a1a;border:1px solid #3a3a3a;color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer}.speed-select:focus{outline:none;border-color:var(--accent-primary)}.icon-button:disabled{opacity:.5;cursor:not-allowed}.icon-button:disabled:hover{background:transparent}.empty-assets{padding:var(--spacing-lg);text-align:center;color:#888;font-size:.875rem}.shot-builder{width:100%;padding:var(--spacing-xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;isolation:isolate}.shot-builder:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.shot-builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.shot-builder-header .header-actions{display:flex;gap:var(--spacing-md);align-items:center}.shot-builder-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.shot-builder-header p{margin:0;color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-xs)}.shots-count-badge{color:var(--accent-primary);font-weight:600;padding:2px 8px;background:#6c4ab61a;border-radius:var(--radius-sm);border:1px solid rgba(108,74,182,.3);font-size:.85rem}.shot-builder-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.shot-builder-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.asset-panel{width:280px;flex-shrink:0;background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);max-height:800px;display:flex;flex-direction:column;overflow:hidden}.asset-panel-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-elevated)}.asset-panel-header h3{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.2rem}.asset-panel-header p{margin:0;color:var(--text-secondary);font-size:.85rem}.asset-panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.asset-section{margin-bottom:var(--spacing-xl)}.asset-section:last-child{margin-bottom:0}.asset-section-title{display:flex;align-items:center;gap:var(--spacing-xs);margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:.95rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.asset-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.asset-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:grab;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;position:relative}.asset-item:active{cursor:grabbing}.asset-item:hover{border-color:var(--accent-primary);background:var(--bg-panel);transform:translate(4px);box-shadow:var(--shadow-sm)}.asset-item:active{cursor:grabbing;opacity:.5}.asset-item[draggable=true]{cursor:grab}.asset-item[draggable=true]:active{cursor:grabbing}.asset-item:not(:active)[draggable=true]:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px #6c4ab64d}.asset-thumbnail{width:48px;height:48px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;border:1px solid var(--border-color)}.asset-thumbnail img{width:100%;height:100%;object-fit:cover}.asset-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bg-panel);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-shrink:0}.asset-info{flex:1;min-width:0}.asset-name{font-weight:600;color:var(--text-primary);font-size:.875rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-description{color:var(--text-secondary);font-size:.75rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.asset-empty{padding:var(--spacing-md);text-align:center;color:var(--text-tertiary);font-size:.85rem;font-style:italic}.shot-builder .shot-canvas{flex:1;min-height:600px;max-height:800px;background:var(--bg-canvas);background-image:linear-gradient(rgba(108,74,182,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(108,74,182,.03) 1px,transparent 1px);background-size:50px 50px;border-radius:var(--radius-lg);border:2px solid var(--glass-border);overflow:auto;cursor:grab;box-shadow:inset 0 0 50px #0006,var(--shadow-md);position:relative}.shot-builder .shot-canvas:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(108,74,182,.05) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(108,74,182,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.shot-builder .shot-canvas:active{cursor:grabbing}.shot-builder .shot-canvas-content{position:relative;min-width:2000px;min-height:1000px;width:100%;height:100%}.shot-builder .shot-card{position:absolute;width:160px;min-height:130px;max-height:300px;background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:2px solid var(--accent-primary);border-radius:var(--radius-lg);cursor:grab;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:10;box-shadow:var(--shadow-md),0 0 15px #6c4ab633;-webkit-user-select:none;user-select:none;overflow:hidden;display:flex;flex-direction:column;position:relative}.shot-builder .shot-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:.8}.shot-builder .shot-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-xl),0 0 25px #6c4ab666;z-index:20;border-color:var(--accent-primary-hover)}.shot-builder .shot-card.dragging{cursor:grabbing;z-index:100;transform:scale(1.08) rotate(2deg);box-shadow:var(--shadow-glow-strong),0 15px 40px #0009;opacity:.95;border-width:3px;animation:pulse-glow 1s ease-in-out infinite}.shot-builder .shot-card.editing{border-color:var(--accent-warning);box-shadow:0 0 20px #f39c124d}.shot-builder .shot-card.drop-target{border-color:var(--accent-primary)!important;box-shadow:0 0 25px #6c4ab699!important;border-width:3px!important;transform:scale(1.05);background:#6c4ab61a!important;animation:pulse-glow 1s ease-in-out infinite}.shot-builder .shot-card.drop-target:before{opacity:1!important;height:4px!important}.shot-builder .shot-card-header{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;background:var(--bg-elevated);border-bottom:1px solid var(--border-color);border-radius:var(--radius-md) var(--radius-md) 0 0;flex-shrink:0}.shot-builder .shot-number{font-weight:700;color:var(--accent-primary);font-size:.75rem}.shot-builder .shot-actions{display:flex;gap:var(--spacing-xs)}.shot-builder .shot-action-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.75rem;padding:2px 3px;border-radius:var(--radius-sm);transition:all var(--transition-base);line-height:1}.shot-builder .shot-action-btn:hover{background:var(--bg-panel);color:var(--text-primary);transform:scale(1.1)}.shot-builder .shot-action-btn.watch-btn:hover{background:#6c4ab633;color:var(--accent-primary)}.shot-builder .shot-card-body{padding:6px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:5px;min-height:0}.shot-builder .shot-title{margin:0 0 3px;color:var(--text-primary);font-size:.8rem;font-weight:600;line-height:1.2;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.shot-builder .shot-description{margin:0 0 3px;color:var(--text-secondary);font-size:.7rem;line-height:1.25;word-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.shot-builder .shot-section{margin-bottom:4px}.shot-builder .shot-section:last-child{margin-bottom:0}.shot-builder .shot-section strong{display:block;margin-bottom:3px;color:var(--text-primary);font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.shot-builder .shot-tags{display:flex;flex-wrap:wrap;gap:3px}.shot-builder .shot-tag{padding:2px 5px;border-radius:3px;font-size:.65rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:inline-block;background:#6c4ab633;color:var(--accent-primary);border:1px solid rgba(108,74,182,.3)}.shot-builder .shot-tag.location-tag{background:#9b59b633;color:#9b59b6;border:1px solid #9b59b6}.shot-builder .shot-tag.character-tag{background:#f39c1233;color:var(--accent-warning);border:1px solid var(--accent-warning)}.shot-builder .shot-tag.asset-tag{background:#6c4ab633;color:var(--accent-primary);border:1px solid var(--accent-primary)}.shot-builder .asset-item.my-asset{border-left:3px solid var(--accent-primary)}.shot-builder .shot-script-preview{background:var(--bg-elevated);padding:3px 5px;border-radius:3px;border:1px solid var(--border-color);color:var(--text-secondary);font-size:.65rem;font-style:italic;line-height:1.2;max-height:35px;overflow:hidden;word-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.shot-modal{max-width:700px;max-height:90vh;overflow-y:auto}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px #6c4ab666}50%{box-shadow:0 0 30px #6c4ab6cc}}.shot-video-modal{max-width:900px;max-height:90vh;overflow-y:auto}.shot-details-section{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);border:1px solid var(--border-color)}.shot-details-section h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary);font-size:1.25rem;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.shot-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-item.full-width{grid-column:1 / -1}.detail-item strong{color:var(--text-primary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.detail-item span{color:var(--text-secondary);font-size:.95rem;word-wrap:break-word}.components-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.components-section strong{display:block;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:.95rem}.components-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.component-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary)}.component-thumb{width:24px;height:24px;border-radius:50%;object-fit:cover}.shot-image-modal{max-width:1000px;max-height:90vh;overflow-y:auto}.prompt-section{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);border:1px solid var(--border-color)}.prompt-section h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1.25rem}.prompt-input{width:100%;min-height:120px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.generated-images-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-color)}.generated-images-section h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary);font-size:1.25rem}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.generated-image-card{position:relative;width:100%;height:250px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);background:var(--bg-elevated)}.generated-image-card img{width:100%;height:100%;object-fit:cover}.generated-image-card .image-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.8) 100%);opacity:0;transition:opacity var(--transition-base);display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-md)}.generated-image-card:hover .image-overlay{opacity:1}.image-prompt{color:var(--text-primary);font-size:.85rem}.image-prompt strong{display:block;margin-bottom:var(--spacing-xs);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.image-prompt p{margin:0;line-height:1.4;word-wrap:break-word}.image-actions{display:flex;justify-content:flex-end;gap:var(--spacing-xs)}.btn-icon-small{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-base)}.btn-icon-small:hover{background:var(--accent-primary-transparent);border-color:var(--accent-primary);transform:scale(1.1)}.generation-progress{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color)}.generation-progress p{margin:var(--spacing-sm) 0 0 0;color:var(--text-secondary);font-size:.9rem;text-align:center}.scenes-page{max-width:1600px;margin:0 auto}.scenes-header{margin-bottom:var(--spacing-2xl);text-align:center}.scenes-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:2.5rem;letter-spacing:-.05em}.scenes-header p{margin:0;color:var(--text-secondary);font-size:1.05rem}.scenes-controls{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.scene-selector{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.scene-selector label{color:var(--text-primary);font-weight:500;font-size:.9375rem;white-space:nowrap}.scene-select{flex:1;min-width:250px;max-width:400px}.shot-builder-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.selected-scene-info{padding:var(--spacing-lg);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.selected-scene-info:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent)}.selected-scene-info h2{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:1.5rem}.selected-scene-info p{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.scene-stats{display:flex;gap:var(--spacing-md);align-items:center;font-size:.9rem;flex-wrap:wrap}.stat-badge{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);display:inline-flex;align-items:center;gap:var(--spacing-xs)}.shots-stat{background:#6c4ab61a;border-color:#6c4ab64d;color:var(--text-primary)}.shots-stat strong{color:var(--accent-primary);font-size:1.1em;font-weight:700}.stat-hint{color:var(--text-tertiary);font-size:.85em;font-style:italic;margin-left:var(--spacing-xs)}.empty-scene-state{text-align:center;padding:var(--spacing-3xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);animation:fadeIn .5s ease-out}.empty-scene-state .empty-icon{font-size:4.5rem;margin-bottom:var(--spacing-lg);color:var(--accent-primary);animation:float 3s ease-in-out infinite}.empty-scene-state h2{margin-bottom:var(--spacing-md);color:var(--text-primary);font-size:2rem}.empty-scene-state p{margin-bottom:var(--spacing-xl);color:var(--text-secondary);font-size:1rem}.scene-create-modal{max-width:700px;max-height:90vh;overflow-y:auto}.asset-create-modal{max-width:800px;max-height:90vh;overflow-y:auto}.asset-create-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.prompt-textarea{min-height:120px;resize:vertical;font-family:inherit}.prompt-hint{margin-top:var(--spacing-xs);color:var(--accent-primary);font-size:.85rem;font-style:italic}.generate-image-section{text-align:center;padding:var(--spacing-xl);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px dashed var(--border-color)}.generate-image-section .hint-text{margin-top:var(--spacing-md);color:var(--text-tertiary);font-size:.85rem}.generation-progress-section{padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color)}.generated-image-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.generated-image{width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-elevated)}.regenerate-btn{align-self:flex-start}.asset-edit-modal{max-width:700px;max-height:90vh;overflow-y:auto}.asset-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.asset-preview{position:relative;width:100%;max-height:300px;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--accent-primary);background:var(--bg-elevated)}.asset-preview img{width:100%;height:100%;object-fit:contain}.selected-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--accent-primary);color:var(--text-primary);padding:6px 12px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-md);z-index:2}.generate-btn{width:100%;margin-bottom:var(--spacing-md)}.generation-progress-section{padding:var(--spacing-lg);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.progress-bar{width:100%;height:10px;background:var(--bg-panel);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-md);transition:width .5s ease-out}.progress-text{text-align:center;color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--spacing-md)}.generation-animation{text-align:center;margin-top:var(--spacing-md)}.spinner{font-size:3rem;animation:spin 2s linear infinite}.versions-gallery{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.versions-title{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:1.1rem;font-weight:600}.versions-hint{margin:0 0 var(--spacing-md) 0;color:var(--text-tertiary);font-size:.85rem;font-style:italic}.versions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md)}.version-card{position:relative;width:100%;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--border-color);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-base)}.version-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-primary)}.version-card.selected{border-color:var(--accent-primary);border-width:3px;box-shadow:0 0 0 3px var(--accent-primary-transparent)}.version-card img{width:100%;height:100%;object-fit:cover}.version-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.7) 100%);opacity:0;transition:opacity var(--transition-base);display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-sm)}.version-card:hover .version-overlay{opacity:1}.version-selected-badge{background:var(--accent-primary);color:var(--text-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;align-self:flex-start}.version-number{color:var(--text-primary);font-size:.85rem;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.8);align-self:flex-end}.prompt-textarea{min-height:120px;resize:vertical;font-family:inherit;background:var(--bg-elevated);color:var(--text-secondary);cursor:not-allowed}.prompt-hint{margin-top:var(--spacing-xs);color:var(--text-tertiary);font-size:.85rem;font-style:italic}.date-display{padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color);color:var(--text-secondary);font-size:.95rem}.asset-share-modal{max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--text-primary);font-size:1.75rem}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:var(--spacing-xs);transition:all var(--transition-base);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.close-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.asset-share-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{color:var(--text-primary);font-size:.95rem;font-weight:500}.asset-preview-small{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color)}.asset-preview-small img{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-md)}.asset-name-preview{color:var(--text-primary);font-weight:500;font-size:.95rem}.share-input-container{margin-bottom:var(--spacing-sm)}.share-form{display:flex;gap:var(--spacing-sm)}.share-input{flex:1}.shared-users-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.shared-user-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--accent-primary-transparent);color:var(--accent-primary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.875rem;border:1px solid var(--accent-primary)}.remove-share-btn{background:transparent;border:none;color:var(--accent-primary);cursor:pointer;font-size:.75rem;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-base)}.remove-share-btn:hover{background:var(--accent-primary);color:var(--text-primary)}.hint-text{color:var(--text-tertiary);font-size:.85rem;font-style:italic;margin-top:var(--spacing-xs)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);margin-top:var(--spacing-lg)}.compact-asset-controller{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:900px;background:linear-gradient(135deg,#0a0a14bf,#0f0f1ebf);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:10px 16px;display:flex;flex-direction:column;gap:8px;z-index:1000;box-shadow:0 -8px 32px #0009,0 0 0 1px #8b5cf61a,inset 0 1px #ffffff0d;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideUpFade .4s ease-out}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.compact-asset-controller.drag-over{border-color:#3b82f699;background:linear-gradient(135deg,#0f0f1ed9,#141428d9);box-shadow:0 -8px 32px #3b82f666,0 0 0 1px #3b82f64d,inset 0 1px #ffffff1a;transform:translate(-50%) scale(1.01)}.controller-main-wrapper{display:flex;gap:12px;align-items:flex-start}.controller-mode-selector{display:flex;flex-direction:row;gap:4px;align-items:center;flex-shrink:0;padding:4px;background:#8b5cf60d;border-radius:10px;border:1px solid rgba(139,92,246,.1)}.mode-btn{width:56px;height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffff80;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:4px 6px;position:relative;overflow:hidden}.mode-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.mode-btn:hover:before{left:100%}.mode-btn:hover{background:linear-gradient(135deg,#8b5cf626,#8b5cf60d);border-color:#8b5cf666;color:#ffffffe6;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf633}.mode-btn.active{background:linear-gradient(135deg,#8b5cf640,#8b5cf626);border-color:#8b5cf699;color:#a78bfa;box-shadow:0 0 20px #8b5cf64d,inset 0 1px #ffffff1a}.mode-btn.active:after{content:"";position:absolute;inset:-2px;border-radius:8px;padding:2px;background:linear-gradient(135deg,#8b5cf680,#3b82f680);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:borderGlow 2s ease-in-out infinite}@keyframes borderGlow{0%,to{opacity:.5}50%{opacity:1}}.mode-icon{width:16px;height:16px;stroke:currentColor;transition:all .3s}.mode-btn.active .mode-icon{filter:drop-shadow(0 0 4px rgba(139,92,246,.6))}.mode-label{font-size:.55rem;font-weight:700;letter-spacing:.5px;line-height:1;text-transform:uppercase;background:linear-gradient(135deg,#ffffffe6,#fff9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mode-btn.active .mode-label{background:linear-gradient(135deg,#a78bfa,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.controller-main-content{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.controller-references{display:flex;align-items:center;gap:8px;padding:6px 0}.references-label{font-size:.7rem;color:#8b5cf6b3;font-weight:700;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.5px}.references-list{display:flex;gap:6px;flex-wrap:wrap;flex:1}.reference-item{position:relative;width:28px;height:28px;border-radius:6px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);border:1.5px solid rgba(139,92,246,.3);box-shadow:0 2px 8px #0000004d}.reference-item:hover{border-color:#8b5cf699;transform:scale(1.15) translateY(-2px);box-shadow:0 4px 12px #8b5cf666;z-index:10}.reference-thumbnail{width:100%;height:100%;object-fit:cover}.remove-reference-btn{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,#ef4444,#dc2626);border:2px solid rgba(20,20,30,.95);border-radius:50%;width:16px;height:16px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;line-height:1;padding:0;flex-shrink:0;transition:all .2s;z-index:1;box-shadow:0 2px 6px #ef444466}.remove-reference-btn:hover{transform:scale(1.2);box-shadow:0 4px 12px #ef444499}.controller-main{display:flex;gap:10px;align-items:center}.controller-prompt-input{flex:1;padding:10px 14px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none;min-width:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.controller-prompt-input::placeholder{color:#ffffff4d;font-style:italic}.controller-prompt-input:focus{border-color:#8b5cf699;background:linear-gradient(135deg,#ffffff14,#ffffff0a);box-shadow:0 0 0 4px #8b5cf61a,0 4px 12px #8b5cf633}.controller-prompt-input:disabled{opacity:.5;cursor:not-allowed}.controller-generate-btn{width:44px;height:44px;background:linear-gradient(135deg,#8b5cf6,#6366f1,#3b82f6);border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:0 4px 16px #8b5cf666,0 0 0 1px #ffffff1a inset;position:relative;overflow:hidden}.controller-generate-btn:before{content:"";position:absolute;inset:0;border-radius:12px;padding:2px;background:linear-gradient(135deg,#8b5cf6cc,#3b82f6cc);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s}.controller-generate-btn:hover:before{opacity:1}.controller-generate-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 8px 24px #8b5cf680,0 0 0 1px #fff3 inset;background:linear-gradient(135deg,#a78bfa,#818cf8,#60a5fa)}.controller-generate-btn:active:not(:disabled){transform:translateY(0) scale(1)}.controller-generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.controller-generate-btn.generating{background:linear-gradient(135deg,#8b5cf6,#7c3aed);animation:pulseGlow 2s ease-in-out infinite}@keyframes pulseGlow{0%,to{box-shadow:0 4px 16px #8b5cf666,0 0 0 1px #ffffff1a inset}50%{box-shadow:0 4px 24px #8b5cf699,0 0 0 1px #fff3 inset,0 0 30px #8b5cf64d}}.generate-icon,.generate-spinner{width:20px;height:20px;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 2px rgba(255,255,255,.5))}.generate-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.controller-filters{display:flex;gap:6px;align-items:center;justify-content:center;flex-wrap:wrap;padding-top:8px;border-top:1px solid rgba(139,92,246,.15);margin-top:4px}.controller-selected-tags{display:flex;gap:6px;align-items:center;justify-content:center;flex-wrap:wrap;padding-top:6px;border-top:1px solid rgba(139,92,246,.15);margin-top:4px}.selected-tag{padding:4px 10px;background:linear-gradient(135deg,#8b5cf633,#8b5cf61a);border:1px solid rgba(139,92,246,.4);border-radius:8px;color:#c4b5fd;font-size:.7rem;font-weight:600;display:flex;align-items:center;gap:4px;transition:all .2s;box-shadow:0 2px 8px #8b5cf633}.selected-tag:hover{background:linear-gradient(135deg,#8b5cf64d,#8b5cf633);border-color:#8b5cf699;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.selected-tag.reference-count{background:linear-gradient(135deg,#3b82f633,#3b82f61a);border-color:#3b82f666;color:#93c5fd}.selected-tag.reference-count:hover{background:linear-gradient(135deg,#3b82f64d,#3b82f633);border-color:#3b82f699;box-shadow:0 4px 12px #3b82f64d}@media(max-width:768px){.compact-asset-controller{padding:8px 12px;width:95%}.controller-main-wrapper{gap:8px}.mode-btn{width:56px;height:44px}.controller-prompt-input{font-size:.85rem;padding:8px 12px}.controller-generate-btn{width:40px;height:40px}.controller-filters{gap:4px}}.my-assets-page{max-width:100%;width:100%;margin:0;padding:var(--spacing-xl);padding-bottom:140px;display:flex;flex-direction:column;min-height:calc(100vh - var(--toolbar-height, 70px));transition:padding-bottom .3s cubic-bezier(.4,0,.2,1);box-sizing:border-box}.my-assets-page.with-collapsed-panel{padding-bottom:80px}.assets-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl);gap:var(--spacing-lg);width:100%;box-sizing:border-box}.assets-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:2.5rem;letter-spacing:-.05em}.assets-header p{margin:0;color:var(--text-secondary);font-size:1.05rem}.my-assets-page .assets-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))!important;gap:var(--spacing-lg)!important;flex:1;overflow-y:auto;padding-bottom:var(--spacing-xl);margin-bottom:var(--spacing-xl);width:100%!important;box-sizing:border-box;align-items:start;grid-auto-rows:min-content}@media(min-width:2000px){.my-assets-page .assets-grid{grid-template-columns:repeat(6,1fr)!important;gap:var(--spacing-lg)!important}}@media(min-width:1600px)and (max-width:1999px){.my-assets-page .assets-grid{grid-template-columns:repeat(5,1fr)!important;gap:var(--spacing-lg)!important}}@media(min-width:1200px)and (max-width:1599px){.my-assets-page .assets-grid{grid-template-columns:repeat(4,1fr)!important;gap:var(--spacing-lg)!important}}@media(min-width:900px)and (max-width:1199px){.my-assets-page .assets-grid{grid-template-columns:repeat(3,1fr)!important;gap:var(--spacing-md)!important}}@media(min-width:600px)and (max-width:899px){.my-assets-page .assets-grid{grid-template-columns:repeat(2,1fr)!important;gap:var(--spacing-md)!important}}@media(max-width:599px){.my-assets-page .assets-grid{grid-template-columns:1fr!important;gap:var(--spacing-md)!important}}.empty-assets-state{grid-column:1 / -1;text-align:center;padding:var(--spacing-3xl);background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);animation:fadeIn .5s ease-out}.empty-assets-state .empty-icon{font-size:4.5rem;margin-bottom:var(--spacing-lg);color:var(--accent-primary);animation:float 3s ease-in-out infinite}.empty-assets-state h2{margin-bottom:var(--spacing-md);color:var(--text-primary);font-size:2rem}.empty-assets-state p{margin-bottom:var(--spacing-md);color:var(--text-secondary);font-size:1rem}.empty-assets-state .hint{color:var(--text-tertiary);font-size:.9rem;font-style:italic}.my-assets-page .asset-card{background:var(--gradient-card)!important;-webkit-backdrop-filter:var(--glass-blur)!important;backdrop-filter:var(--glass-blur)!important;border-radius:var(--radius-xl)!important;border:1px solid var(--glass-border)!important;box-shadow:var(--shadow-md)!important;overflow:hidden!important;transition:all var(--transition-base)!important;position:relative!important;aspect-ratio:1!important;width:100%!important;max-width:100%!important;height:auto!important;min-height:250px!important;isolation:isolate!important;display:flex!important;flex-direction:column!important;cursor:grab!important}.my-assets-page .asset-card:active{cursor:grabbing!important}.my-assets-page .asset-card.loading,.my-assets-page .asset-card.error{cursor:default!important}.my-assets-page .asset-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary);z-index:10}.my-assets-page .asset-image-container{position:relative!important;width:100%!important;height:100%!important;overflow:hidden!important;background:var(--bg-elevated)!important;min-height:250px!important;max-width:100%!important;max-height:100%!important;flex:1!important}.my-assets-page .asset-image-container img,.my-assets-page .asset-image-container .asset-image{width:100%!important;height:100%!important;min-height:250px!important;max-width:100%!important;max-height:100%!important;object-fit:cover!important;transition:transform var(--transition-base)!important;display:block!important}.my-assets-page .asset-card:hover .asset-image-container img{transform:scale(1.05)}.my-assets-page .asset-video-wrapper{position:relative;width:100%!important;height:100%!important;min-height:250px!important;max-width:100%!important;max-height:100%!important;overflow:hidden!important;background:#000!important;cursor:pointer}.my-assets-page .asset-video{width:100%!important;height:100%!important;min-height:250px!important;max-width:100%!important;max-height:100%!important;object-fit:cover!important;display:block!important;cursor:pointer!important}.my-assets-page .asset-video-thumbnail{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.my-assets-page .asset-video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;z-index:5;transition:background var(--transition-base);pointer-events:none}.my-assets-page .asset-card:hover .asset-video-play-overlay{background:#00000080}.my-assets-page .btn-play-video{width:64px;height:64px;border-radius:50%;background:#6c4ab6e6;border:3px solid rgba(255,255,255,.9);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0006;padding-left:4px;pointer-events:auto;z-index:6;position:relative}.my-assets-page .btn-play-video:hover{background:#6c4ab6;transform:scale(1.1);box-shadow:0 6px 20px #6c4ab699;border-color:#fff}.my-assets-page .asset-video-controls{position:absolute;inset:0;z-index:4;cursor:pointer;pointer-events:auto}.my-assets-page .asset-title-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 70%,transparent 100%);padding:var(--spacing-md) var(--spacing-lg);color:var(--text-primary);z-index:2}.asset-title{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:.85rem;font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.8)}.asset-date-time{display:block;color:var(--text-secondary);font-size:.8rem;text-shadow:0 1px 4px rgba(0,0,0,.8)}.my-assets-page .asset-overlay{position:absolute;inset:0;background:#0009;opacity:0;transition:opacity var(--transition-base);display:flex;align-items:center;justify-content:center;z-index:3;pointer-events:none}.my-assets-page .asset-card:hover .asset-overlay{opacity:1;pointer-events:auto}.my-assets-page .asset-card:has(.asset-video-wrapper) .asset-overlay{background:#0006}.asset-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.btn-icon{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:1.2rem;padding:var(--spacing-sm);transition:all var(--transition-base);width:44px;height:44px;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff4d;transform:scale(1.15);box-shadow:0 4px 12px #0006}.my-assets-page .share-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--accent-primary);color:var(--text-primary);padding:6px 10px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;z-index:4;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-prompt-container{position:sticky;bottom:0;background:var(--gradient-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);padding:var(--spacing-lg);margin-top:var(--spacing-xl);z-index:10}.chat-messages{max-height:200px;overflow-y:auto;margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-color)}.chat-placeholder{text-align:center;padding:var(--spacing-lg);color:var(--text-tertiary)}.chat-placeholder p{margin:var(--spacing-xs) 0}.chat-placeholder .hint-text{font-size:.85rem;font-style:italic}.chat-message{margin-bottom:var(--spacing-sm)}.chat-message:last-child{margin-bottom:0}.message-content{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.user-message,.ai-message{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);max-width:80%}.user-message{background:var(--accent-primary-transparent);color:var(--text-primary);margin-left:auto;flex-direction:row-reverse}.ai-message{background:var(--bg-panel);color:var(--text-secondary)}.message-icon{font-size:1.2rem;flex-shrink:0}.chat-input-form{display:flex;gap:var(--spacing-sm);align-items:center}.chat-input{flex:1;padding:var(--spacing-md);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:all var(--transition-base)}.chat-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-transparent)}.chat-send-btn{padding:var(--spacing-md) var(--spacing-lg);white-space:nowrap;min-width:100px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.asset-card.loading{opacity:.8}.asset-loading-state{width:100%;height:100%;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-primary);gap:16px}.loading-spinner-large{width:48px;height:48px;border:4px solid rgba(139,92,246,.2);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.asset-loading-state p{margin:0;font-size:.9rem;color:var(--text-secondary)}.asset-card.error{border-color:#ef4444}.asset-error-state{width:100%;height:100%;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ef44441a;color:var(--text-primary);gap:12px;padding:20px;text-align:center}.error-icon{font-size:2.5rem}.my-assets-page .asset-prompt-section{padding:12px;border-top:1px solid rgba(255,255,255,.1);background:#0003}.my-assets-page .btn-toggle-prompt{width:100%;padding:10px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-top:none;border-radius:0 0 8px 8px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.my-assets-page .btn-toggle-prompt:hover{background:#ffffff14;border-color:#3b82f666}.my-assets-page .btn-toggle-prompt svg{width:14px;height:14px}} .asset-error-state p{margin:0;font-size:.9rem;color:var(--text-primary)}.error-message{font-size:.8rem!important;color:var(--text-tertiary)!important;font-style:italic}.admin-prompts-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl)}.admin-prompts-header{margin-bottom:var(--spacing-2xl)}.admin-prompts-header h1{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:2rem}.admin-subtitle{color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-size:1rem}.admin-controls{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.language-selector{display:flex;align-items:center;gap:var(--spacing-sm)}.language-selector label{color:var(--text-primary);font-weight:500}.language-selector select{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{to{transform:rotate(360deg)}}.admin-prompts-content{display:flex;flex-direction:column;gap:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.prompt-category{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.category-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-color)}.category-header h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.3rem}.category-description{margin:0;color:var(--text-secondary);font-size:.9rem}.prompt-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.prompt-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.prompt-field label{color:var(--text-primary);font-weight:500;font-size:.95rem}.prompt-textarea{width:100%;padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;font-family:Courier New,monospace;line-height:1.6;resize:vertical;transition:all var(--transition-base)}.prompt-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c4ab626}.prompt-textarea-large{min-height:300px}.field-stats{font-size:.8rem;color:var(--text-tertiary);margin-top:var(--spacing-xs)}.testing-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-top:var(--spacing-2xl)}.testing-section h2{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1.5rem}.section-description{color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-size:.9rem}.test-controls{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.test-input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.test-input-group label{color:var(--text-primary);font-weight:500;font-size:.95rem}.test-input{width:100%;padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;font-family:Courier New,monospace;line-height:1.6;resize:vertical}.test-results{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:2px solid var(--border-color)}.test-results h3{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1.2rem}.result-section{margin-bottom:var(--spacing-lg)}.result-section h4{margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-size:1rem;font-weight:600}.result-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);font-family:Courier New,monospace;font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;max-height:400px;overflow-y:auto;color:var(--text-secondary)}.result-content.ai-response{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--accent-primary)}#root{width:100%;height:100vh;margin:0;padding:0}*{box-sizing:border-box}
