@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Work+Sans:wght@400;500;600;700&display=swap";@layer properties,theme,base,components,utilities;@layer theme{:root,:host{--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.hidden{display:none}.resize{resize:both}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.italic{font-style:italic}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}#root{--background:#fff;--foreground:#171717;width:100%;margin:0;padding:0}@media(prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Work Sans,sans-serif}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.toast-viewport{z-index:2000;flex-direction:column;gap:12px;display:flex;position:fixed;top:20px;right:20px}.toast{color:#f8fafc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172aeb;border:1px solid #94a3b840;border-radius:12px;align-items:center;gap:12px;min-width:260px;max-width:360px;padding:14px 16px;animation:.2s ease-out toast-slide-in;display:flex;box-shadow:0 14px 30px #0f172a40}.toast-success{background:#10b981eb;border-color:#6ee7b773}.toast-error{background:#ef4444eb;border-color:#fca5a580}.toast-warning{background:#f59e0beb;border-color:#fde0478c}.toast-info{background:#3b82f6eb;border-color:#93c5fd8c}.toast-message{flex:1;font-size:.95rem;font-weight:500;line-height:1.3}.toast-close{color:inherit;cursor:pointer;opacity:.8;background:0 0;border:0;padding:2px 4px;font-size:1.1rem;line-height:1}.toast-close:hover{opacity:1}@keyframes toast-slide-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@media(max-width:700px){.toast-viewport{top:auto;left:12px;right:12px;bottom:calc(16px + env(safe-area-inset-bottom))}.toast{width:100%;max-width:none}}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}body{margin:0}.landing{position:relative;min-height:100vh;padding:28px clamp(20px,4vw,56px) 70px;color:#f5f1e8;font-family:Work Sans,sans-serif;background:linear-gradient(160deg,#0c0a1e,#1a1640 40%,#1e1a3a,#16132e);overflow-x:hidden}.landing:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 50% 20%,rgba(102,126,234,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(118,75,162,.08) 0%,transparent 40%);pointer-events:none;z-index:0}.landing:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");opacity:.25;pointer-events:none;z-index:1}.landing,.landing *{box-sizing:border-box}.landing-vignette{position:fixed;inset:0;background:radial-gradient(ellipse at center,transparent 50%,rgba(10,11,20,.45) 100%);pointer-events:none;z-index:2}.landing-nav{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 24px;font-family:Work Sans,sans-serif}.landing-brand{display:flex;align-items:center;gap:14px;font-weight:600;letter-spacing:.02em}.brand-mark{position:relative;display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:700;box-shadow:0 4px 12px #667eea4d;overflow:hidden}.brand-mark:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2) 100%)}.brand-mark-inner{position:relative;z-index:1}.brand-name{font-family:Inter,sans-serif;font-size:20px;font-weight:700;color:#f5f1e8}.landing-links{display:flex;gap:8px;font-size:14px;font-weight:500}.landing-links a{padding:8px 16px;color:#f5f1e899;text-decoration:none;border-radius:8px;transition:all .2s ease}.landing-links a:hover{color:#f5f1e8;background:#667eea26}.landing-cta{display:flex;align-items:center;gap:16px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 26px;border-radius:10px;font-size:15px;font-weight:600;border:none;text-decoration:none;cursor:pointer;font-family:Work Sans,sans-serif;transition:all .15s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 16px #667eea4d}.btn-primary:hover{box-shadow:0 6px 24px #667eea73}.btn-ghost{border:1px solid rgba(167,139,250,.3);color:#f5f1e8;background:#a78bfa0f}.btn-ghost:hover{background:#a78bfa24;border-color:#a78bfa80}.btn-large{padding:16px 34px;font-size:16px;border-radius:12px}.landing-hero{position:relative;z-index:3;display:flex;align-items:flex-start;justify-content:start;min-height:100vh;max-width:1400px;margin:0 auto}.hero-btn{padding:18px 48px;width:100%;max-width:320px}.hero-content-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:clamp(60px,8vw,100px);align-items:center;width:100%;padding:80px 0}.hero-spotlight{position:absolute;top:-100px;left:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.1) 0%,transparent 70%);pointer-events:none;filter:blur(80px)}.hero-copy{display:flex;flex-direction:column;gap:26px;animation:fadeInUp .9s ease both;max-width:580px}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.2em;font-size:11px;font-weight:600;color:#a78bfae6;font-family:Work Sans,sans-serif}.eyebrow-dot{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);animation:pulse 2s ease-in-out infinite;box-shadow:0 0 8px #667eea99}.hero-copy h1{font-family:Inter,sans-serif;font-size:clamp(44px,6vw,72px);line-height:1.05;color:#f5f1e8;margin:0;font-weight:800;letter-spacing:-.02em}.hero-line{display:block}.hero-highlight{position:relative;background:linear-gradient(135deg,#667eea,#a78bfa,#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-lede{font-size:18px;line-height:1.7;color:#f5f1e8a6;font-weight:400;margin:0}.hero-actions{display:flex;flex-wrap:wrap;gap:16px;padding-top:4px;justify-content:center}.hero-visual{position:relative;animation:fadeInUp 1s ease both;animation-delay:.2s}.demo-container{position:relative}.story-demo{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 20px 40px #00000080;height:clamp(500px,70vh,700px)}.demo-scene-fullscreen{position:absolute;inset:0;background:linear-gradient(160deg,#0f0c29,#1a1e2e);overflow:hidden}.scene-real-image{position:absolute;inset:0;opacity:1;transform:scale(1);transition:all 1.2s cubic-bezier(.4,0,.2,1)}.scene-real-image.transitioning{opacity:0;transform:scale(1.05);transition:all .8s cubic-bezier(.4,0,.2,1)}.scene-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center}.scene-info-bubble{position:absolute;top:24px;left:24px;background:#000000b3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:14px 18px;display:flex;flex-direction:column;gap:6px;opacity:1;transition:opacity 1.2s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #0009;max-width:280px}.scene-info-bubble.transitioning{opacity:0;transition:opacity .8s cubic-bezier(.4,0,.2,1)}.character-name-label{font-size:18px;font-weight:700;color:#fffffff2;letter-spacing:-.01em}.character-description{font-size:13px;font-weight:400;color:#ffffffb3;line-height:1.4}.genre-tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#a78bfae6;background:#667eea26;padding:4px 10px;border-radius:6px;margin-top:4px;align-self:flex-start;border:1px solid rgba(102,126,234,.3)}.demo-dialogue-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(to top,rgba(10,11,20,.95) 0%,rgba(10,11,20,.7) 70%,transparent 100%);pointer-events:none}.dialogue-box{background:#0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:20px 24px;box-shadow:0 4px 24px #0009,inset 0 0 0 1px #ffffff0d,inset 0 1px #ffffff14}.dialogue-text{font-size:17px;line-height:1.7;color:#fffffff2;margin:0;min-height:24px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.dialogue-cursor{display:inline-block;width:2px;height:20px;background:#a78bfae6;margin-left:2px;animation:blink 1s step-end infinite}.pricing-section{position:relative;z-index:3;padding:60px 0}.section-header{max-width:700px;margin:0 auto 36px;text-align:center}.section-tag{display:inline-block;padding:6px 14px;border-radius:20px;background:#667eea26;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:#a78bfaf2;font-family:Work Sans,sans-serif;margin-bottom:12px;border:1px solid rgba(102,126,234,.3)}.section-header h2{font-family:Inter,sans-serif;font-size:clamp(32px,4vw,44px);margin:0 0 12px;line-height:1.15;color:#f5f1e8;font-weight:700}.section-header p{color:#f5f1e8b3;font-size:16px;line-height:1.6;margin:0}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;max-width:1000px;margin:0 auto}.pricing-card{background:#ffffff06;border-radius:16px;padding:28px 24px;border:1px solid rgba(255,255,255,.07);box-shadow:0 12px 32px #0000004d;transition:all .15s ease}.pricing-card:hover{border-color:#667eea4d;box-shadow:0 16px 40px #0006}.pricing-card.featured{background:#667eea14;border-color:#667eea40;box-shadow:0 12px 32px #667eea1f}.pricing-card.featured:hover{border-color:#667eea66;box-shadow:0 16px 40px #667eea33}.pricing-badge{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:6px;margin-bottom:14px}.pricing-card h3{font-family:Inter,sans-serif;font-size:24px;margin:0 0 8px;color:#f5f1e8;font-weight:700}.pricing-price{font-family:Inter,sans-serif;font-size:36px;font-weight:700;color:#a78bfae6;margin:0 0 6px}.pricing-price span{font-size:18px;color:#f5f1e899}.pricing-period{font-size:13px;color:#f5f1e899;margin-bottom:20px}.pricing-features{list-style:none;padding:0;margin:0 0 24px}.pricing-features li{padding:9px 0;color:#f5f1e8b3;font-size:14px;border-bottom:1px solid rgba(255,255,255,.06);font-weight:400}.pricing-features li:last-child{border-bottom:none}.landing-footer{position:relative;z-index:3;padding:60px 0 28px;border-top:1px solid rgba(255,255,255,.06);margin-top:80px}.footer-content{display:grid;grid-template-columns:1.5fr 2fr;gap:60px;margin-bottom:48px}.footer-brand-section{display:flex;flex-direction:column;gap:16px}.footer-brand{display:flex;align-items:center;gap:14px;font-weight:600}.footer-brand .brand-mark{width:36px;height:36px;font-size:14px}.footer-tagline{font-size:14px;color:#f5f1e899;line-height:1.6;max-width:300px}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}.footer-column{display:flex;flex-direction:column;gap:12px}.footer-column h4{font-family:Inter,sans-serif;font-size:14px;font-weight:700;color:#f5f1e8;margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em}.footer-column a{font-size:14px;color:#f5f1e88c;text-decoration:none;transition:color .15s ease}.footer-column a:hover{color:#f5f1e8e6}.footer-bottom{padding-top:28px;border-top:1px solid rgba(255,255,255,.05);text-align:center}.footer-bottom p{font-size:13px;color:#f5f1e880;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}@media(max-width:980px){.landing-hero{min-height:auto}.hero-content-wrapper{grid-template-columns:1fr;gap:50px;padding:40px 0}.pricing-cards{grid-template-columns:1fr}}@media(max-width:680px){.landing{padding:16px 16px 40px}.landing-nav{flex-direction:row;align-items:center;justify-content:space-between;padding:10px 0;gap:12px}.landing-brand{gap:10px}.brand-mark{width:38px;height:38px;font-size:15px;border-radius:10px}.brand-name{font-size:16px}.landing-cta .btn{padding:10px 18px;font-size:14px;border-radius:10px}.hero-content-wrapper{padding:24px 0;gap:32px}.hero-copy{gap:20px;text-align:center;align-items:center}.hero-copy h1{font-size:clamp(32px,8vw,44px)}.hero-lede{font-size:16px;line-height:1.6}.hero-actions{flex-direction:column;align-items:center;width:100%}.hero-btn{width:100%;max-width:none}.story-demo{height:clamp(320px,55vh,450px);border-radius:16px}.scene-info-bubble{top:12px;left:12px;right:12px;max-width:none;padding:12px 14px;flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px}.character-name-label{font-size:15px}.character-description{display:none}.genre-tag{font-size:9px;padding:3px 8px;margin-top:0}.demo-dialogue-overlay{padding:12px}.dialogue-box{padding:14px 16px}.dialogue-text{font-size:14px;line-height:1.6}.pricing-section{padding:40px 0}.section-header{margin-bottom:28px}.section-header h2{font-size:clamp(26px,6vw,32px)}.section-header p{font-size:14px}.pricing-cards{gap:20px}.pricing-card{padding:24px 20px;border-radius:16px}.pricing-card h3{font-size:20px}.pricing-price{font-size:32px}.pricing-card .btn-large{padding:14px 24px;font-size:15px}.landing-footer{padding:48px 0 24px;margin-top:60px}.footer-content{grid-template-columns:1fr;gap:32px}.footer-brand-section{align-items:center;text-align:center}.footer-tagline{max-width:none}.footer-links{grid-template-columns:repeat(3,1fr);gap:16px;text-align:center}.footer-column{gap:8px}.footer-column h4{font-size:12px;margin-bottom:4px}.footer-column a{font-size:13px}}@media(max-width:400px){.brand-name{font-size:14px}.landing-cta .btn{padding:8px 14px;font-size:13px}.hero-copy h1{font-size:28px}.hero-lede{font-size:15px}.story-demo{height:clamp(280px,50vh,380px)}.scene-info-bubble{padding:10px 12px}.character-name-label{font-size:14px}.dialogue-text{font-size:13px}.footer-links{grid-template-columns:1fr;gap:24px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}*{margin:0;padding:0;box-sizing:border-box}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#667eea66;border-radius:10px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#667eea99;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:rgba(102,126,234,.4) transparent}.app{min-height:100vh;background:linear-gradient(160deg,#0c0a1e,#1a1640 40%,#1e1a3a,#16132e);font-family:Work Sans,Segoe UI,sans-serif;color:#e8e4f0;position:relative;overflow-x:hidden}.app:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 0%,rgba(102,126,234,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(118,75,162,.06) 0%,transparent 50%);pointer-events:none;z-index:0}.container{max-width:1100px;margin:0 auto;padding:32px 24px;position:relative;z-index:1}.navbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;margin-bottom:40px;padding:12px 20px;border-radius:16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar a{color:#ffffffb3;text-decoration:none;font-weight:500;padding:10px 18px;border-radius:10px;transition:all .2s ease}.navbar a:hover{background:#ffffff1a;color:#fff;transform:translateY(-1px)}.navbar a.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.breadcrumb-nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px;padding:12px 16px;border-radius:14px;background:#0e101ee0;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 24px #00000040}.breadcrumb-left{display:flex;align-items:center;gap:12px}.breadcrumb-list{display:flex;align-items:center;flex-wrap:wrap;gap:6px;color:#ffffffb3;font-size:.95em}.breadcrumb-text{white-space:nowrap}.breadcrumb-item{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;color:#fff9;text-decoration:none;font-size:.88em;font-weight:500;border:1px solid transparent;transition:all .15s ease}.breadcrumb-item:hover{color:#ffffffe6;background:#ffffff0f}.breadcrumb-item:focus-visible{outline:2px solid rgba(167,139,250,.7);outline-offset:2px}.breadcrumb-item.active{color:#fffffff2;background:#667eea26;border-color:#667eea40}.breadcrumb-home{font-weight:600}.breadcrumb-icon{font-size:1.1em;line-height:1}.breadcrumb-separator{color:#ffffff59;margin:0 2px}.nav-actions,.nav-right{display:flex;align-items:center;gap:12px}.nav-user{display:flex;align-items:center}.nav-action-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;color:#fff;text-decoration:none;font-size:.82em;font-weight:600;background:linear-gradient(135deg,#667eeae6,#764ba2e6);border:1px solid rgba(167,139,250,.3);box-shadow:0 2px 8px #667eea33;transition:all .15s ease}.nav-action-btn:hover{box-shadow:0 4px 16px #667eea59;border-color:#a78bfa80}.nav-action-btn:focus-visible{outline:2px solid rgba(167,139,250,.7);outline-offset:2px}.nav-action-btn:active{transform:scale(.98)}.nav-action-secondary{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ffffffbf;box-shadow:none}.nav-action-secondary:hover{background:#ffffff1a;border-color:#fff3;color:#fffffff2;box-shadow:none}h1{text-align:center;color:#fff;margin-bottom:8px;font-family:Inter,Work Sans,sans-serif;font-size:2.2em;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#f0ecff,#c4b5fd,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{text-align:center;color:#ffffff73;margin-bottom:32px;font-size:1em;font-weight:400;letter-spacing:.01em}.upload-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:40px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:30px;text-align:center}.upload-section h2{color:#a78bfa;margin-bottom:25px;font-size:1.6em;font-weight:600}.file-input-wrapper{position:relative;display:inline-block;margin-bottom:20px}.file-input-wrapper input[type=file]{display:none}.file-input-label{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px 30px;border-radius:12px;cursor:pointer;display:inline-block;transition:all .3s ease;font-size:1em;font-weight:500}.file-input-label:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.file-name{margin-top:10px;color:#ffffff80;font-style:italic}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:15px 40px;border-radius:12px;cursor:pointer;font-size:1.1em;font-weight:500;transition:all .3s ease;margin-top:20px}.upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.upload-btn:disabled,.upload-btn.disabled{background:#ffffff1a;color:#fff6;cursor:not-allowed;transform:none;box-shadow:none}.back-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:10px 20px;border-radius:10px;cursor:pointer;font-size:1em;transition:all .3s ease}.back-btn:hover{background:#ffffff26;transform:translateY(-2px)}.status{margin-top:20px;padding:15px 20px;border-radius:10px;font-weight:500}.status.success{background:#34d39926;color:#34d399;border:1px solid rgba(52,211,153,.3)}.status.error{background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.3)}.scene-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:30px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:20px}.chat-section{background:#ffffff08;border-radius:20px;padding:30px}.scene-container{position:relative;width:100%;max-width:800px;height:450px;margin:0 auto 30px;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#0000004d}.scene-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0a1459;pointer-events:none;z-index:30}.character{position:absolute;left:50%;transform:translate(-50%);width:280px;height:420px;-o-object-fit:contain;object-fit:contain;z-index:10;transition:all .5s ease}.character-fade-in{animation:characterFadeIn .4s ease-in-out}.character-fade-out{animation:characterFadeOut .4s ease-in-out;z-index:9}@keyframes characterFadeIn{0%{opacity:0}to{opacity:1}}@keyframes characterFadeOut{0%{opacity:1}to{opacity:0}}.scene-image{position:absolute;bottom:0;left:50%;transform:translate(-50%);max-width:90%;max-height:90%;-o-object-fit:contain;object-fit:contain;z-index:11;transition:all .5s ease}.scene-fade-in{animation:sceneFadeIn .6s ease-in-out}.scene-fade-out{animation:sceneFadeOut .6s ease-in-out;z-index:10}@keyframes sceneFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sceneFadeOut{0%{opacity:1}to{opacity:0}}.chat-box{width:100%;max-width:800px;margin:0 auto 20px;padding:20px;border-radius:20px;height:200px;overflow-y:auto;background:#0000004d}.chat-message{margin-bottom:12px;padding:14px 18px;border-radius:20px;line-height:1.6;max-width:85%;display:flex;flex-direction:column;gap:6px;animation:messageSlideIn .3s ease-out;box-shadow:0 4px 15px #0000001a}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message-role{font-size:.7em;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.9}.chat-message-content{display:block;font-size:.95em}.chat-message-human{background:linear-gradient(135deg,#5a72d4,#6d4a96);color:#fff;margin-left:auto;border-radius:18px 18px 4px;box-shadow:0 2px 12px #667eea33}.chat-message-human .chat-message-role{color:#fffc}.chat-message-ai{background:#ffffffeb;color:#1a1a2e;border:none;margin-right:auto;border-radius:18px 18px 18px 4px;box-shadow:0 2px 12px #0000001f}.chat-message-ai .chat-message-role{color:#6d4a96;font-weight:700}.typing-indicator{display:flex;align-items:center;gap:4px;padding:14px 18px;background:#fffffff2;border-radius:20px 20px 20px 6px;margin-right:auto;max-width:80px;box-shadow:0 4px 20px #00000026}.typing-indicator span{width:8px;height:8px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;animation:typingBounce 1.4s ease-in-out infinite}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-8px);opacity:1}}.input-section{text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:stretch;width:100%}.input-nav-row{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;max-width:760px}.input-nav-row .input-wrapper{flex:1}.nav-input-btn{width:36px;height:36px;flex-shrink:0}.input-wrapper{display:flex;align-items:center;gap:8px;width:100%;max-width:600px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:26px;padding:6px 6px 6px 20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.input-wrapper:focus-within{border-color:#667eea99;background:#ffffff1f;box-shadow:0 0 20px #667eea33}.user-input{flex:1;padding:10px 0;border:none;font-size:1em;background:transparent;color:#fff;min-width:0}.user-input::-moz-placeholder{color:#ffffff80}.user-input::placeholder{color:#ffffff80}.user-input:focus{outline:none}.message-speaker-select{border:1px solid rgba(255,255,255,.24);background:#ffffff1f;color:#fffffff2;border-radius:999px;height:34px;padding:0 10px;font-size:.78em;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;flex-shrink:0}.message-speaker-select:focus{outline:none;border-color:#667eeab3}.message-speaker-select:disabled{opacity:.5;cursor:not-allowed}.message-speaker-select option{background:#1f2438;color:#fff}.suggest-btn{display:flex;align-items:center;justify-content:center;background:#ffffff1a;color:#ffffffd9;border:1px solid rgba(255,255,255,.22);width:36px;height:36px;border-radius:50%;cursor:pointer;transition:all .2s ease;flex-shrink:0}.suggest-btn svg{width:18px;height:18px}.suggest-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #667eea66;background:#ffffff2e}.suggest-btn:disabled{opacity:.5;cursor:not-allowed}.continue-scene-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#ffffff1f;color:#ffffffe6;border:1px solid rgba(255,255,255,.22);padding:7px 12px;border-radius:999px;font-size:.8em;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .2s ease;flex-shrink:0;white-space:nowrap}.continue-scene-btn svg{width:14px;height:14px}.continue-scene-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #667eea59;background:#ffffff2e}.continue-scene-btn:disabled{opacity:.5;cursor:not-allowed}.send-btn{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .2s ease;flex-shrink:0}.send-btn svg{width:18px;height:18px}.send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 15px #667eea80}.send-btn:active:not(:disabled){transform:scale(.95)}.send-btn:disabled{background:#ffffff1a;color:#ffffff40;cursor:not-allowed;transform:none}.regenerate-section{margin-top:20px;text-align:center}.regenerate-btn{background:#ffc107;color:#212529;border:none;padding:8px 20px;margin:2px;border-radius:15px;cursor:pointer;font-size:.9em;transition:all .3s ease}.regenerate-btn:hover{background:#e0a800;transform:translateY(-1px)}@media(max-width:768px){.container{padding:10px}.scene-container{width:100%;height:100%;position:relative;overflow:hidden}.character{width:180px;height:280px;right:20px}.input-wrapper{padding:5px 5px 5px 16px}.input-nav-row{max-width:720px}.nav-input-btn{width:34px;height:34px}.send-btn,.suggest-btn{width:36px;height:36px}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:20px}.spinner{position:relative;display:flex;align-items:center;justify-content:center}.spinner-small{width:30px;height:30px}.spinner-medium{width:50px;height:50px}.spinner-large{width:70px;height:70px}.spinner-ring{position:absolute;border-radius:50%;border:3px solid transparent;border-top-color:#667eea;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.spinner-small .spinner-ring{width:30px;height:30px;border-width:2px}.spinner-medium .spinner-ring{width:50px;height:50px;border-width:3px}.spinner-large .spinner-ring{width:70px;height:70px;border-width:4px}.spinner-ring:nth-child(1){animation-delay:-.45s;border-top-color:#667eea}.spinner-ring:nth-child(2){width:80%;height:80%;animation-delay:-.3s;border-top-color:#764ba2}.spinner-ring:nth-child(3){width:60%;height:60%;animation-delay:-.15s;border-top-color:#a78bfa}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{color:#fff9;font-size:1em;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center}.empty-state-icon{font-size:3em;margin-bottom:16px;opacity:.4}.empty-state-title{color:#ffffffb3;font-family:Inter,Work Sans,sans-serif;font-size:1.15em;font-weight:600;margin-bottom:8px}.empty-state-description{color:#fff6;font-size:.95em;max-width:360px;line-height:1.5}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.session-card{animation:fadeInUp .4s ease-out backwards}.session-card:nth-child(1){animation-delay:.1s}.session-card:nth-child(2){animation-delay:.15s}.session-card:nth-child(3){animation-delay:.2s}.session-card:nth-child(4){animation-delay:.25s}.session-card:nth-child(5){animation-delay:.3s}.session-card:nth-child(6){animation-delay:.35s}.upload-btn{position:relative;overflow:hidden}.upload-btn:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(to right,transparent,rgba(255,255,255,.1),transparent);transform:rotate(45deg);transition:.5s}.upload-btn:hover:after{left:100%}.upload-btn:focus,.continue-btn:focus{outline:none;box-shadow:0 0 0 3px #667eea66}.vn-page{--vn-chat-height: 280px;position:fixed;inset:0;overflow:hidden;background:#1a1a2e}.vn-scene-wrapper{position:absolute;inset:0;z-index:1}.vn-scene-wrapper .scene-section{background:transparent;border-radius:0;padding:0;box-shadow:none;margin:0;height:100%}.vn-scene-wrapper .scene-container{position:absolute;inset:0;width:100%;max-width:none;height:100%;margin:0;border-radius:0;overflow:hidden}.vn-scene-wrapper .character{position:absolute;top:0;left:0;transform:none;width:100%;height:100%;max-width:none;max-height:none;-o-object-fit:contain;object-fit:contain;-o-object-position:center center;object-position:center center}.vn-scene-wrapper .scene-image{position:absolute;top:0;left:0;transform:none;width:100%;height:100%;max-width:none;max-height:none;-o-object-fit:contain;object-fit:contain;-o-object-position:center top;object-position:center top}.vn-menu-toggle{position:fixed;top:20px;left:20px;z-index:100;width:44px;height:44px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:10px;transition:all .3s ease}.vn-menu-toggle:hover{background:#000000b3}.vn-menu-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease}.vn-menu-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.vn-menu-toggle.open span:nth-child(2){opacity:0}.vn-menu-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.vn-menu{position:fixed;top:0;left:-280px;width:280px;height:100%;background:#141428f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:99;display:flex;flex-direction:column;padding:80px 20px 20px;transition:left .3s ease;border-right:1px solid rgba(255,255,255,.1)}.vn-menu.open{left:0}.vn-menu-header{font-size:1.2em;font-weight:600;color:#fff;margin-bottom:30px;padding-bottom:15px;border-bottom:1px solid rgba(255,255,255,.1)}.vn-menu-item{display:block;padding:14px 16px;color:#fffc;text-decoration:none;border-radius:8px;margin-bottom:8px;transition:all .2s ease;background:none;border:none;font:inherit;cursor:pointer;text-align:left;width:100%}.vn-menu-item:hover{background:#ffffff1a;color:#fff}.vn-menu-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.vn-menu-backdrop{position:fixed;inset:0;background:#00000080;z-index:98}.vn-chat-toggle{z-index:100;width:36px;height:36px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;display:flex;justify-content:center;align-items:center;padding:6px;transition:all .3s ease;color:#fff}.vn-chat-toggle:hover{background:#000000b3}.vn-chat-toggle svg{width:18px;height:18px}.vn-chat-toggle.chat-hidden{background:#667eea99;border-color:#667eea66}.vn-chat-toggle.chat-hidden:hover{background:#667eeacc}.vn-chat-toggle-float{position:fixed;left:20px;bottom:20px;z-index:100}.vn-chat-wrapper{position:fixed;bottom:0;left:0;right:0;height:var(--vn-chat-height);z-index:50;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 70%,transparent 100%);padding:20px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .3s ease,opacity .3s ease}.vn-chat-wrapper.hidden{height:0;padding:0;background:transparent}.chat-section.chat-hidden-mode>*{display:none}.chat-section.chat-hidden-mode>.vn-history-nav-floating{display:flex}.vn-chat-wrapper.hidden .chat-box,.vn-chat-wrapper.hidden .vn-dialogue-container,.vn-chat-wrapper.hidden .vn-instructions-panel,.vn-chat-wrapper.hidden .input-section,.vn-chat-wrapper.hidden .vn-suggestions-panel{display:none!important}.vn-history-nav-floating{position:fixed;left:68px;bottom:20px;z-index:100;display:flex;gap:8px}.vn-chat-wrapper .chat-section{background:transparent;border-radius:0;padding:0;box-shadow:none;width:100%;max-width:900px;margin:0 auto}.vn-chat-wrapper .chat-box{background:#0f0f1ed9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(102,126,234,.2);border-radius:24px;height:280px;max-width:none;margin-bottom:16px;padding:18px;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0d}.vn-chat-wrapper .chat-message{max-width:70%;border-radius:20px}.vn-chat-wrapper .chat-message-ai{background:#fffffff2;color:#1a1a2e;border:none;border-radius:20px 20px 20px 6px;box-shadow:0 4px 20px #0003}.vn-chat-wrapper .chat-message-human{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px 20px 6px;box-shadow:0 4px 20px #667eea59}.vn-chat-wrapper .input-section{display:flex;flex-direction:column;justify-content:center;align-items:stretch;width:100%}.vn-chat-wrapper .input-nav-row{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;max-width:820px}.vn-chat-wrapper .input-wrapper{display:flex;align-items:center;gap:8px;width:100%;max-width:700px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:26px;padding:6px 6px 6px 20px;transition:all .3s ease;box-shadow:0 4px 15px #0003}.vn-chat-wrapper .input-wrapper:focus-within{border-color:#667eea80;background:#ffffff1f;box-shadow:0 4px 15px #0003,0 0 20px #667eea26}.vn-chat-wrapper .user-input{flex:1;background:transparent;border:none;color:#fff;padding:10px 0;font-size:1em;min-width:0}.vn-chat-wrapper .user-input::-moz-placeholder{color:#ffffff73}.vn-chat-wrapper .user-input::placeholder{color:#ffffff73}.vn-chat-wrapper .user-input:focus{outline:none}.vn-chat-wrapper .message-speaker-select{border-color:#fff3;background:#ffffff1a}.vn-chat-wrapper .send-btn{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;width:40px;height:40px;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.vn-chat-wrapper .send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 15px #667eea80}.vn-chat-wrapper .send-btn:active:not(:disabled){transform:scale(.95)}.vn-chat-wrapper .send-btn:disabled{background:#ffffff1a;color:#ffffff40;cursor:not-allowed}.vn-chat-wrapper .send-btn svg{width:18px;height:18px}@media(max-width:768px){.vn-page{--vn-chat-height: clamp(180px, 30vh, 240px)}.vn-chat-wrapper .chat-box{height:200px;border-radius:20px;padding:14px}.vn-chat-wrapper .input-wrapper{padding:5px 5px 5px 16px;border-radius:24px}.vn-chat-wrapper .input-nav-row{max-width:none;gap:8px}.vn-chat-wrapper .user-input{padding:8px 0}.vn-chat-wrapper .send-btn,.vn-chat-wrapper .suggest-btn{width:36px;height:36px}.vn-chat-wrapper .message-speaker-select{height:32px;padding:0 8px;font-size:.72em;max-width:88px}.continue-scene-btn span{display:none}.vn-chat-wrapper .continue-scene-btn{padding:6px 10px;font-size:.78em}.vn-chat-wrapper .chat-message{max-width:85%;padding:12px 14px}h1{font-size:2em}.navbar{padding:10px 12px;gap:8px}.navbar a{padding:8px 14px;font-size:.9em}.breadcrumb-nav{flex-direction:column;align-items:flex-start;padding:14px 16px}.breadcrumb-left{width:100%}.breadcrumb-list{row-gap:8px}.nav-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}}@media(max-width:480px){.vn-page{--vn-chat-height: clamp(160px, 28vh, 220px)}.container{padding:10px 8px}h1{font-size:1.6em}.app-subtitle{font-size:.95em;margin-bottom:25px}.navbar{flex-direction:column;gap:6px;padding:12px}.navbar a{width:100%;text-align:center;padding:12px 16px}.breadcrumb-nav{padding:10px 12px;gap:10px}.breadcrumb-list{width:100%;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.breadcrumb-list::-webkit-scrollbar{display:none}.breadcrumb-item{padding:6px 8px}.breadcrumb-text{font-size:.95em}.nav-actions{width:100%}.nav-action-btn{width:100%;justify-content:center}.upload-section{padding:25px 15px}.upload-btn{width:100%;padding:14px 20px}.back-btn{width:100%;text-align:center}.vn-scene-wrapper .character{bottom:var(--vn-chat-height)}.vn-chat-wrapper{padding:15px 12px;padding-bottom:calc(15px + env(safe-area-inset-bottom))}.vn-chat-wrapper .chat-box{height:200px;padding:12px}.vn-chat-wrapper .chat-message{max-width:90%;padding:12px 14px;font-size:1em}.vn-chat-wrapper .input-wrapper{max-width:none;padding:4px 4px 4px 14px}.input-nav-row{max-width:none;gap:8px}.input-nav-row .input-wrapper{max-width:none}.nav-input-btn{width:32px;height:32px}.vn-chat-wrapper .user-input{font-size:16px;padding:8px 0}.vn-chat-wrapper .send-btn,.vn-chat-wrapper .suggest-btn{width:34px;height:34px}.vn-chat-wrapper .message-speaker-select{height:30px;padding:0 8px;font-size:.68em;letter-spacing:.04em;max-width:84px}.vn-chat-wrapper .continue-scene-btn{padding:5px 9px;font-size:.75em}.vn-menu-toggle{top:12px;left:12px}.vn-chat-toggle-float{left:12px;bottom:12px}.vn-history-nav-floating{left:60px;bottom:12px}.input-wrapper{max-width:none;padding:4px 4px 4px 14px}.user-input{font-size:16px}.send-btn,.suggest-btn{width:34px;height:34px}.message-speaker-select{height:30px;padding:0 8px;font-size:.68em;max-width:84px}.continue-scene-btn{padding:5px 9px;font-size:.75em}}@supports (-webkit-touch-callout: none){.chat-box,.vn-chat-wrapper .chat-box{-webkit-overflow-scrolling:touch}.vn-chat-wrapper{padding-bottom:calc(20px + env(safe-area-inset-bottom))}.vn-scene-wrapper{top:env(safe-area-inset-top)}.vn-menu{padding-top:calc(80px + env(safe-area-inset-top))}.vn-menu-toggle{top:calc(20px + env(safe-area-inset-top))}.vn-chat-toggle-float,.vn-history-nav-floating{bottom:calc(20px + env(safe-area-inset-bottom))}}.vn-dialogue-container{position:relative;width:100%;max-width:900px;margin:0 auto}.vn-dialogue-header{display:flex;align-items:center;justify-content:space-between;max-width:900px;margin:0 auto -4px}.vn-speaker-row,.vn-dialogue-actions{display:flex;align-items:center;gap:10px}.vn-retry-btn,.vn-image-btn,.vn-edit-btn,.vn-delete-btn{width:36px;height:36px}.vn-instructions-panel{max-width:900px;margin:10px auto 0;padding:12px 16px;background:#080a16eb;border:1px solid rgba(102,126,234,.35);border-radius:12px;box-shadow:0 8px 24px #00000059;display:flex;flex-direction:column;gap:10px}.vn-instructions-label{color:#ffffffb3;font-size:.75em;letter-spacing:.12em;text-transform:uppercase}.vn-instructions-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0}.vn-instructions-input{flex:1;min-width:220px;background:#060610b3;border:1px solid rgba(255,255,255,.2);border-radius:999px;color:#fffffff2;font-size:.95em;padding:8px 14px}.vn-instructions-input::-moz-placeholder{color:#fff6}.vn-instructions-input::placeholder{color:#fff6}.vn-instructions-input:focus{outline:none;border-color:#667eeab3;box-shadow:0 0 0 2px #667eea33}.vn-instructions-submit{border:none;border-radius:999px;padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.vn-instructions-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #667eea66}.vn-instructions-submit:disabled{background:#ffffff1f;color:#fff6;cursor:not-allowed}.vn-instructions-cancel{border-radius:999px;padding:8px 14px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#fffc;cursor:pointer;transition:background .2s ease,color .2s ease}.vn-instructions-cancel:hover:not(:disabled){background:#ffffff29;color:#fff}.vn-instructions-cancel:disabled{opacity:.4;cursor:not-allowed}.vn-suggestions-panel{max-width:900px;margin:12px auto 0;padding:14px 16px;background:#080a16eb;border:1px solid rgba(102,126,234,.35);border-radius:12px;box-shadow:0 8px 24px #00000059;display:flex;flex-direction:column;gap:12px}.vn-suggestions-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.vn-suggestions-title{color:#ffffffb3;font-size:.75em;letter-spacing:.12em;text-transform:uppercase}.vn-suggestions-actions{display:flex;align-items:center;gap:8px}.vn-suggestions-refresh{border:none;border-radius:999px;padding:6px 14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.vn-suggestions-refresh:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #667eea66}.vn-suggestions-refresh:disabled{background:#ffffff1f;color:#fff6;cursor:not-allowed}.vn-suggestions-close{border-radius:999px;padding:6px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#fffc;cursor:pointer;transition:background .2s ease,color .2s ease}.vn-suggestions-close:hover:not(:disabled){background:#ffffff29;color:#fff}.vn-suggestions-close:disabled{opacity:.4;cursor:not-allowed}.vn-suggestions-list{display:flex;flex-direction:column;gap:10px}.vn-suggestion-option{border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:10px 14px;background:#ffffff0f;color:#ffffffeb;display:flex;align-items:flex-start;gap:12px;text-align:left;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border .2s ease}.vn-suggestion-option:hover:not(:disabled){transform:translateY(-1px);border-color:#667eea80;box-shadow:0 10px 24px #0c0e1a66}.vn-suggestion-option:disabled{opacity:.5;cursor:not-allowed}.vn-suggestion-index{font-size:.85em;font-weight:700;color:#fff9;padding-top:2px}.vn-suggestion-text{flex:1;line-height:1.4}.vn-suggestions-empty{color:#fff9;font-size:.9em}.vn-speaker-label{display:inline-block;padding:8px 24px 6px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:1em;letter-spacing:.5px;border-radius:12px 12px 0 0;margin-bottom:-1px;position:relative;z-index:2;box-shadow:0 -4px 15px #667eea4d}.vn-speaker-label.human{color:#60a5fa;border-color:#60a5fa80;text-shadow:0 0 10px rgba(96,165,250,.5)}.vn-dialogue-box{background:#0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:24px 28px;min-height:120px;max-height:32vh;overflow-y:scroll;position:relative;cursor:pointer;box-shadow:0 4px 24px #0009,inset 0 0 0 1px #ffffff0d,inset 0 1px #ffffff14;transition:border-color .2s ease}.vn-dialogue-box.editing{cursor:default;padding:0}.vn-dialogue-box:focus{outline:none;border-color:#a78bfa66}.vn-dialogue-box.human{border-color:#ffffff26}.vn-dialogue-box.human:focus{border-color:#60a5fa66}.vn-dialogue-text{color:#fffffff2;font-size:1.15em;line-height:1.8;min-height:60px;white-space:pre-wrap}.vn-dialogue-edit{width:100%;min-height:200px;background:#060610b3;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fffffff2;font-size:1.1em;line-height:1.7;font-family:inherit;box-sizing:border-box;padding:10px 12px;resize:vertical}.vn-dialogue-edit:focus{outline:none;border-color:#667eeab3}.vn-narrator-text{font-style:italic;color:#c8d2ffe6;margin-right:.3em}.vn-dialogue-text.typing:after{content:"|";animation:cursorBlink .7s infinite;color:#667eeacc;margin-left:2px}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.vn-click-indicator{position:absolute;bottom:12px;right:16px;color:#fff6;font-size:.8em;animation:pulse 2s ease-in-out infinite}.vn-streaming-indicator{position:absolute;bottom:12px;right:16px;display:flex;gap:4px}.vn-streaming-indicator span{width:6px;height:6px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;animation:typingBounce 1.4s ease-in-out infinite}.vn-streaming-indicator span:nth-child(1){animation-delay:0s}.vn-streaming-indicator span:nth-child(2){animation-delay:.2s}.vn-streaming-indicator span:nth-child(3){animation-delay:.4s}.vn-nav-container{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding:0 8px}.vn-nav-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;line-height:0;background:#00000080;border:1px solid rgba(255,255,255,.25);border-radius:50%;color:#ffffffe6;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vn-nav-btn:hover:not(:disabled){background:#667eea99;border-color:#667eeab3;color:#fff;transform:scale(1.05)}.vn-nav-btn.vn-delete-btn:hover:not(:disabled){background:#ef444499;border-color:#ef4444b3;color:#fff}.vn-nav-btn.vn-scene-btn{background:#ffc17a2e;border-color:#ffc17a66;color:#ffe1bef2}.vn-nav-btn.vn-scene-btn:hover:not(:disabled){background:#ffc17a73;border-color:#ffc17ab3;color:#1b120a}.vn-nav-btn:disabled{opacity:.3;cursor:not-allowed}.vn-nav-btn svg{width:20px;height:20px;display:block}.vn-message-counter{color:#ffffffb3;font-size:.9em;font-weight:600;font-variant-numeric:tabular-nums;padding:0 12px 6px;align-self:flex-end;text-align:right}.vn-history-indicator{position:absolute;top:-8px;right:16px;background:#eab308e6;color:#1a1a2e;padding:4px 12px;border-radius:12px;font-size:.75em;font-weight:600}@media(max-width:768px){.vn-dialogue-box{padding:18px 20px;min-height:100px;max-height:32vh;border-radius:4px;overflow-y:scroll}.vn-dialogue-box.editing{max-height:70vh;min-height:40vh;padding:0}.vn-dialogue-text{font-size:1.05em;line-height:1.7;min-height:60px}.vn-dialogue-edit{min-height:45vh;font-size:1.1em;line-height:1.7}.vn-speaker-label{padding:6px 18px 5px;font-size:.9em}.vn-nav-btn{width:40px;height:40px}.vn-nav-container{margin-top:10px}}@media(max-width:480px){.vn-dialogue-box{padding:14px 16px;min-height:80px;max-height:28vh;overflow-y:scroll}.vn-dialogue-box.editing{max-height:75vh;min-height:45vh;padding:0}.vn-dialogue-text{font-size:1em;min-height:60px}.vn-dialogue-edit{min-height:50vh;font-size:1.05em;line-height:1.7}.vn-speaker-label{padding:5px 14px 4px;font-size:.85em}.vn-nav-btn{width:36px;height:36px}.vn-nav-btn svg{width:16px;height:16px}}.story-plan-backdrop{position:fixed;inset:0;background:#06080e8c;border:none;padding:0;cursor:default;z-index:999}.story-plan-panel{position:fixed;top:20px;right:20px;width:min(440px,92vw);max-height:72vh;overflow-y:auto;background:linear-gradient(180deg,#0e1220f5,#080a12f0);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 18px 40px #00000073;color:#ffffffe6;z-index:1000}.story-plan-header{position:sticky;top:0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px;background:#0e1220f5;border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.story-plan-heading{display:flex;flex-direction:column;gap:10px}.story-plan-title{font-size:1rem;font-weight:600;letter-spacing:.02em}.story-plan-progress{display:flex;align-items:center;gap:10px;font-size:.78rem;color:#ffffffb3}.story-plan-progress-bar{position:relative;flex:1;height:6px;border-radius:999px;background:#ffffff1a;overflow:hidden}.story-plan-progress-bar span{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#6ad7d0,#8a9cf5);border-radius:999px}.story-plan-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end;margin-left:auto}.story-plan-action{border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffd9;padding:6px 12px;border-radius:999px;font-size:.78rem;cursor:pointer;transition:background .2s ease,border .2s ease}.story-plan-action:hover{background:#ffffff24}.story-plan-action.primary{background:linear-gradient(120deg,#6ad7d0cc,#8a9cf5cc);border-color:transparent;color:#0c0f1e;font-weight:600}.story-plan-action.subtle{border-color:transparent;color:#fff9}.story-plan-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffd9;cursor:pointer;transition:background .2s ease,border .2s ease}.story-plan-icon-btn:hover:not(:disabled){background:#ffffff29}.story-plan-icon-btn.close{font-size:18px;line-height:1}.story-plan-icon-btn svg{width:16px;height:16px}.story-plan-content,.story-plan-empty{padding:16px;display:flex;flex-direction:column;gap:16px}.story-plan-empty p{color:#ffffffb3;line-height:1.5}.story-plan-summary{display:flex;flex-direction:column;gap:12px}.story-plan-field{display:flex;flex-direction:column;gap:6px}.story-plan-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:#ffffff8c}.story-plan-value{font-size:.9rem;color:#ffffffd9;line-height:1.5}.story-plan-input,.story-plan-textarea{width:100%;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0c0e18cc;color:#ffffffe6;font-size:.86rem}.story-plan-textarea{resize:vertical}.story-plan-toggle{display:flex;align-items:center;gap:8px;font-size:.82rem;color:#ffffffb3}.story-plan-current{padding:12px;border-radius:12px;background:#6ad7d014;border:1px solid rgba(106,215,208,.18)}.story-plan-current-title{font-size:.95rem;font-weight:600;margin-top:6px}.story-plan-current-desc{font-size:.82rem;color:#ffffffbf;margin-top:4px;line-height:1.5}.story-plan-beats,.story-plan-beat-list{display:flex;flex-direction:column;gap:12px}.story-plan-beat{padding:12px;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.story-plan-beat.beat-current{border-color:#8a9cf573;background:#8a9cf51f}.story-plan-beat-header{display:flex;align-items:center;gap:10px;font-size:.72rem;color:#fff9;margin-bottom:8px}.story-plan-beat-index{font-weight:600}.story-plan-beat-status{padding:2px 8px;border-radius:999px;background:#ffffff14}.story-plan-beat-remove{margin-left:auto;background:none;border:none;color:#ffffff80;cursor:pointer}.story-plan-beat-body{display:flex;flex-direction:column;gap:6px}.story-plan-beat-title{font-size:.9rem;font-weight:600}.story-plan-beat-desc{font-size:.82rem;color:#ffffffbf}.story-plan-beat-criteria{font-size:.78rem;color:#ffffff8c}.story-plan-beat-edit{display:flex;flex-direction:column;gap:8px}.story-plan-add{align-self:flex-start;border:1px dashed rgba(255,255,255,.3);background:transparent;color:#ffffffb3;padding:6px 12px;border-radius:999px;cursor:pointer}.story-plan-regenerate{display:flex;flex-direction:column;gap:10px}.story-plan-muted{font-size:.78rem;color:#ffffff8c;line-height:1.4}.story-plan-regenerate-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.story-plan-inline-label{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:#ffffffb3}.story-plan-number{width:64px;padding:6px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#0c0e18cc;color:#ffffffd9;font-size:.8rem}.story-plan-beat.beat-completed .story-plan-beat-status{color:#79e3a2}.story-plan-beat.beat-in-progress .story-plan-beat-status{color:#f4d57e}.story-plan-beat.beat-pending .story-plan-beat-status{color:#fff9}.story-plan-beat.beat-skipped{opacity:.55}@media(max-width:768px){.story-plan-panel{top:10px;right:10px;left:10px;width:auto;max-height:60vh}}.chat-state-backdrop{position:fixed;inset:0;background:#06080e8c;border:none;padding:0;cursor:default;z-index:999}.chat-state-panel{position:fixed;top:20px;right:20px;left:auto;width:min(440px,92vw);max-height:72vh;overflow-y:auto;background:linear-gradient(180deg,#0e1220f5,#080a12f0);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 18px 40px #00000073;color:#ffffffe6;z-index:1000}.chat-state-header{position:sticky;top:0;padding:16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px;background:#0e1220f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-state-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-state-title{font-size:1rem;font-weight:600;letter-spacing:.02em}.chat-state-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.chat-state-action{border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffd9;padding:6px 12px;border-radius:999px;font-size:.78rem;cursor:pointer;transition:background .2s ease,border .2s ease}.chat-state-action:hover:not(:disabled){background:#ffffff24}.chat-state-action.primary{background:linear-gradient(120deg,#6ad7d0cc,#8a9cf5cc);color:#0c0f1e;border-color:transparent;font-weight:600}.chat-state-action.primary:hover:not(:disabled){background:linear-gradient(120deg,#6ad7d0,#8a9cf5)}.chat-state-action.subtle{border-color:transparent;color:#fff9}.chat-state-action.subtle:hover:not(:disabled){color:#ffffffd9;background:#ffffff0f}.chat-state-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffd9;cursor:pointer;transition:background .2s ease,border .2s ease}.chat-state-icon-btn:hover:not(:disabled){background:#ffffff29}.chat-state-icon-btn.close{font-size:18px;line-height:1}.chat-state-icon-btn svg{width:16px;height:16px}.chat-state-action-content{display:inline-flex;align-items:center;gap:8px}.chat-state-spinner{width:18px;height:18px}.chat-state-spinner .spinner-ring{border-top-color:#ffb77e}.chat-state-spinner .spinner-ring:nth-child(2){border-top-color:#ff8a68}.chat-state-spinner .spinner-ring:nth-child(3){border-top-color:#ffd2a2}.chat-state-content{padding:16px;display:flex;flex-direction:column;gap:16px}.chat-state-section{display:flex;flex-direction:column;gap:12px;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:#ffffff08}.chat-state-section-title{margin:0 0 4px;font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#ffffff73}.chat-state-field{display:flex;flex-direction:column;gap:6px}.chat-state-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff8c}.chat-state-value{font-size:.86rem;color:#ffffffd9;line-height:1.5}.chat-state-textarea{width:100%;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0c0e18cc;color:#ffffffe6;font-size:.82rem;resize:vertical}.chat-state-select{width:100%;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0c0e18cc;color:#ffffffe6;font-size:.82rem}.chat-state-inline-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.chat-state-toggles{display:flex;flex-direction:column;gap:8px;font-size:.8rem;color:#ffffffbf}.chat-state-toggle{display:flex;align-items:center;gap:8px}.chat-state-note{font-size:.78rem;color:#fff9;line-height:1.4}.chat-state-guidance{display:flex;flex-direction:column;gap:8px}@media(max-width:768px){.chat-state-panel{top:10px;left:10px;right:10px;width:auto;max-height:60vh}}.chat-upgrade-cta{width:100%;max-width:820px;margin:0 auto 10px;box-sizing:border-box;padding:10px 12px;border:1px solid rgba(255,158,158,.55);border-radius:10px;background:#3c1212eb;color:#ffe6e6;display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-upgrade-cta-button{border:0;border-radius:8px;padding:7px 12px;font-size:.85rem;font-weight:600;color:#1f1307;background:#ffd66f;cursor:pointer;white-space:nowrap}.chat-upgrade-cta-button:hover{background:#ffe392}@media(max-width:768px){.chat-upgrade-cta{flex-direction:column;align-items:stretch;text-align:left}}
