:root{--coral:#e07a6a;--coral-dark:#c4594b;--coral-light:#fdf0ee;--coral-glow:#e07a6a26;--gold:#e8b44c;--gold-light:#fff7e6;--gold-glow:#e8b44c33;--sage:#6daa73;--sage-light:#ecf5ed;--sky:#5ea8cc;--purple:#8b6db5;--purple-deep:#6b4d8e;--purple-light:#f1ecf7;--parchment:#fef9f2;--parchment-dark:#f5eddf;--cream:#fffbf5;--warm-gray:#f0ebe3;--text-ink:#2c2421;--text-body:#4a3f3a;--text-muted:#6b605a;--text-whisper:#b5aaa1;--shadow-soft:0 2px 12px #2c24210f;--shadow-md:0 4px 20px #2c24211a;--shadow-lg:0 8px 40px #2c242124;--shadow-book:0 12px 48px #2c24212e,0 2px 8px #2c242114;--shadow-glow:0 0 40px #e07a6a1f;--r-sm:8px;--r-md:14px;--r-lg:22px;--r-xl:32px;--r-book:4px 20px 20px 4px}[data-theme=dark]{--coral:#e8958a;--coral-dark:#d67b6e;--coral-light:#3d2a27;--coral-glow:#e8958a33;--gold:#e8c066;--gold-light:#3d3425;--gold-glow:#e8c06633;--sage:#7bbf82;--sage-light:#2a3d2c;--purple:#a585c7;--purple-deep:#9b7bb8;--purple-light:#352d40;--parchment:#1a1614;--parchment-dark:#252220;--cream:#1e1b19;--warm-gray:#2a2623;--text-ink:#f5f0eb;--text-body:#d5ccc4;--text-muted:#9a8e86;--text-whisper:#6a5e56;--shadow-soft:0 2px 12px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-book:0 12px 48px #0009,0 2px 8px #0000004d;--shadow-glow:0 0 40px #e8958a26;--surface:#252220;--surface-elevated:#2d2a27;--border-color:#3d3835}[data-theme=dark] .example-btn{background:var(--surface);border-color:var(--border-color);color:#4a3f3a;color:var(--text-body)}[data-theme=dark] .example-btn:hover{background:var(--surface-elevated);border-color:#e07a6a;border-color:var(--coral)}[data-theme=dark] .example-btn.active{background:#fdf0ee;background:var(--coral-light);border-color:#e07a6a;border-color:var(--coral)}[data-theme=dark] .story-form{background:var(--surface);border-color:var(--border-color)}[data-theme=dark] .form-group input[type=text],[data-theme=dark] .form-group textarea{background:var(--surface-elevated);border-color:var(--border-color);color:#2c2421;color:var(--text-ink)}[data-theme=dark] .form-group input[type=text]:focus,[data-theme=dark] .form-group textarea:focus{background:var(--surface-elevated);border-color:#e07a6a;border-color:var(--coral)}[data-theme=dark] .form-group input[type=text]::placeholder,[data-theme=dark] .form-group textarea::placeholder{color:#b5aaa1;color:var(--text-whisper)}[data-theme=dark] .btn-primary:disabled{background:#f0ebe3;background:var(--warm-gray);color:#b5aaa1;color:var(--text-whisper)}[data-theme=dark] .companion-card,[data-theme=dark] .progress-step,[data-theme=dark] .storybook-page{background:var(--surface)}[data-theme=dark] .nav-prev{background:var(--surface);border-color:var(--border-color);color:#6b605a;color:var(--text-muted)}[data-theme=dark] .nav-prev:hover:not(:disabled){border-color:#e07a6a;border-color:var(--coral);color:#e07a6a;color:var(--coral)}[data-theme=dark] .btn-secondary{background:var(--surface);border-color:#e07a6a;border-color:var(--coral)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--coral:#e8958a;--coral-dark:#d67b6e;--coral-light:#3d2a27;--coral-glow:#e8958a33;--gold:#e8c066;--gold-light:#3d3425;--gold-glow:#e8c06633;--sage:#7bbf82;--sage-light:#2a3d2c;--purple:#a585c7;--purple-deep:#9b7bb8;--purple-light:#352d40;--parchment:#1a1614;--parchment-dark:#252220;--cream:#1e1b19;--warm-gray:#2a2623;--text-ink:#f5f0eb;--text-body:#d5ccc4;--text-muted:#9a8e86;--text-whisper:#6a5e56;--shadow-soft:0 2px 12px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-book:0 12px 48px #0009,0 2px 8px #0000004d;--shadow-glow:0 0 40px #e8958a26;--surface:#252220;--surface-elevated:#2d2a27;--border-color:#3d3835}:root:not([data-theme=light]) .example-btn{background:var(--surface);border-color:var(--border-color);color:#4a3f3a;color:var(--text-body)}:root:not([data-theme=light]) .example-btn:hover{background:var(--surface-elevated);border-color:#e07a6a;border-color:var(--coral)}:root:not([data-theme=light]) .example-btn.active{background:#fdf0ee;background:var(--coral-light);border-color:#e07a6a;border-color:var(--coral)}:root:not([data-theme=light]) .story-form{background:var(--surface);border-color:var(--border-color)}:root:not([data-theme=light]) .form-group input[type=text],:root:not([data-theme=light]) .form-group textarea{background:var(--surface-elevated);border-color:var(--border-color);color:#2c2421;color:var(--text-ink)}:root:not([data-theme=light]) .form-group input[type=text]:focus,:root:not([data-theme=light]) .form-group textarea:focus{background:var(--surface-elevated);border-color:#e07a6a;border-color:var(--coral)}:root:not([data-theme=light]) .form-group input[type=text]::placeholder,:root:not([data-theme=light]) .form-group textarea::placeholder{color:#b5aaa1;color:var(--text-whisper)}:root:not([data-theme=light]) .btn-primary:disabled{background:#f0ebe3;background:var(--warm-gray);color:#b5aaa1;color:var(--text-whisper)}:root:not([data-theme=light]) .companion-card,:root:not([data-theme=light]) .progress-step,:root:not([data-theme=light]) .storybook-page{background:var(--surface)}:root:not([data-theme=light]) .nav-prev{background:var(--surface);border-color:var(--border-color);color:#6b605a;color:var(--text-muted)}:root:not([data-theme=light]) .nav-prev:hover:not(:disabled){border-color:#e07a6a;border-color:var(--coral);color:#e07a6a;color:var(--coral)}:root:not([data-theme=light]) .btn-secondary{background:var(--surface);border-color:#e07a6a;border-color:var(--coral)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fef9f2;background:var(--parchment);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.015'/%3E%3C/svg%3E");color:#4a3f3a;color:var(--text-body);font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;min-height:100vh}::selection{background:#e07a6a;background:var(--coral);color:#fff}::-moz-selection{background:#e07a6a;background:var(--coral);color:#fff}:focus-visible{outline:2px solid #e07a6a;outline:2px solid var(--coral);outline-offset:2px}.app{display:flex;flex-direction:column;min-height:100vh}.font-display{font-family:Quicksand,sans-serif}.font-handwritten{font-family:Caveat,cursive}.btn-primary{background:#c4594b;background:var(--coral-dark);border:none;border-radius:22px;border-radius:var(--r-lg);box-shadow:0 2px 12px #2c24210f,0 2px 0 #c4594b;box-shadow:var(--shadow-soft),0 2px 0 var(--coral-dark);color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:1.05rem;font-weight:600;letter-spacing:.2px;padding:14px 34px;position:relative;transition:all .35s cubic-bezier(.4,0,.2,1)}.btn-primary:hover{background:#a8453a;box-shadow:0 4px 20px #2c24211a,0 3px 0 #a8453a80;box-shadow:var(--shadow-md),0 3px 0 #a8453a80;transform:translateY(-3px)}.btn-primary:active{transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:0 2px 12px #2c24210f,0 1px 0 #a8453a;box-shadow:var(--shadow-soft),0 1px 0 #a8453a;transform:translateY(0) scaleY(.95) scaleX(1.02);transition:transform .1s ease,box-shadow .1s ease}.btn-primary:disabled{background:linear-gradient(135deg,#e5ddd5,#d5ccc4);box-shadow:none;color:#b5aaa1;color:var(--text-whisper);cursor:not-allowed;opacity:.7;transform:none}.btn-secondary{background:#fff;border:2px solid #e07a6a;border:2px solid var(--coral);border-radius:22px;border-radius:var(--r-lg);color:#e07a6a;color:var(--coral);cursor:pointer;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600;padding:12px 28px;transition:all .3s ease}.btn-secondary:hover{background:#fdf0ee;background:var(--coral-light);border-color:#c4594b;border-color:var(--coral-dark)}.btn-secondary:active{transform:scaleY(.95) scaleX(1.02);transition:transform .1s ease}.btn-cta{animation:ctaPulse 3s ease-in-out infinite;border-radius:50px;font-size:1.2rem;letter-spacing:.3px;overflow:hidden;padding:20px 56px;position:relative}@keyframes ctaPulse{0%,to{box-shadow:0 2px 12px #2c24210f,0 2px 0 #c4594b,0 0 0 0 #e07a6a00;box-shadow:var(--shadow-soft),0 2px 0 var(--coral-dark),0 0 0 0 #e07a6a00}50%{box-shadow:0 2px 12px #2c24210f,0 2px 0 #c4594b,0 0 20px 4px #e07a6a4d;box-shadow:var(--shadow-soft),0 2px 0 var(--coral-dark),0 0 20px 4px #e07a6a4d}}.btn-cta:before{animation:ctaShine 4s ease-in-out infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transform:skewX(-25deg);width:60%}@keyframes ctaShine{0%,80%,to{left:-100%}20%,60%{left:150%}}.btn-cta:hover:before{animation:none;left:150%;transition:left .5s ease}.back-btn{background:none;border:none;color:#6b605a;color:var(--text-muted);cursor:pointer;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;margin-bottom:16px;padding:8px 0;transition:color .2s}.back-btn:hover{color:#e07a6a;color:var(--coral)}.theme-toggle{align-items:center;background:#fffbf5;background:var(--cream);border:1.5px solid #b5aaa1;border:1.5px solid var(--text-whisper);border-radius:50%;box-shadow:0 4px 20px #2c24211a;box-shadow:var(--shadow-md);cursor:pointer;display:flex;height:44px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .3s ease;width:44px;z-index:1000}.theme-toggle:hover{border-color:#e07a6a;border-color:var(--coral);box-shadow:0 8px 40px #2c242124;box-shadow:var(--shadow-lg);transform:scale(1.1)}.theme-toggle:active{transform:scale(.95)}.theme-icon{font-size:1.3rem;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.theme-icon.moon,.theme-icon.sun{animation:themeSpin .5s cubic-bezier(.34,1.56,.64,1)}@keyframes themeSpin{0%{opacity:0;transform:rotate(-180deg) scale(.5)}to{opacity:1;transform:rotate(0deg) scale(1)}}.theme-toggle:hover .theme-icon{transform:rotate(20deg) scale(1.1)}.app-controls{display:flex;gap:10px;position:fixed;right:20px;top:20px;z-index:1000}.app-controls .sound-toggle,.app-controls .theme-toggle{position:static}.sound-toggle{align-items:center;background:#fffbf5;background:var(--cream);border:1.5px solid #b5aaa1;border:1.5px solid var(--text-whisper);border-radius:50%;box-shadow:0 4px 20px #2c24211a;box-shadow:var(--shadow-md);cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s ease;width:44px}.sound-toggle:hover{border-color:#e07a6a;border-color:var(--coral);box-shadow:0 8px 40px #2c242124;box-shadow:var(--shadow-lg);transform:scale(1.1)}.sound-toggle:active{transform:scale(.95)}.sound-icon{font-size:1.2rem;transition:transform .2s ease}.sound-toggle:hover .sound-icon{transform:scale(1.1)}.landing{align-items:center;background:radial-gradient(ellipse at 20% 50%,#e07a6a26 0,#0000 50%),radial-gradient(ellipse at 80% 30%,#e8b44c33 0,#0000 50%),radial-gradient(ellipse at 50% 80%,#6daa7314 0,#0000 50%),linear-gradient(170deg,#fffbf5,#fef9f2 40%,#f5eddf);background:radial-gradient(ellipse at 20% 50%,var(--coral-glow) 0,#0000 50%),radial-gradient(ellipse at 80% 30%,var(--gold-glow) 0,#0000 50%),radial-gradient(ellipse at 50% 80%,#6daa7314 0,#0000 50%),linear-gradient(170deg,var(--cream) 0,var(--parchment) 40%,var(--parchment-dark) 100%);display:flex;justify-content:center;min-height:100vh;opacity:0;overflow:hidden;padding:40px 24px;position:relative;transform:translateY(16px);transition:opacity 1s ease,transform 1s ease}.landing.visible{opacity:1;transform:translateY(0)}.landing:before{animation:drift 8s ease-in-out infinite;background:#e8b44c33;background:var(--gold-glow);filter:blur(60px);height:300px;right:-5%;top:10%;width:300px}.landing:after,.landing:before{border-radius:50%;content:"";position:absolute}.landing:after{animation:drift 10s ease-in-out infinite reverse;background:#e07a6a26;background:var(--coral-glow);bottom:15%;filter:blur(50px);height:250px;left:-8%;width:250px}@keyframes drift{0%,to{transform:translate(0)}50%{transform:translate(20px,-15px)}}.landing-content{max-width:620px;position:relative;text-align:center;z-index:1}.landing-logo{margin-bottom:20px}.logo-icon{animation:float 4s ease-in-out infinite;display:inline-block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));font-size:3.5rem}@keyframes float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}.landing-title{font-family:Quicksand,sans-serif;font-size:4.5rem;font-weight:700;letter-spacing:-1px;line-height:1.1;margin-bottom:12px}.title-equal{color:#e07a6a;color:var(--coral)}.title-tales{color:#6b4d8e;color:var(--purple-deep);font-weight:600}.title-char{display:inline-block;opacity:0;transform:translateY(20px) scale(.8)}.landing.visible .title-char{animation:letterReveal .5s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes letterReveal{0%{opacity:0;transform:translateY(20px) scale(.8)}60%{opacity:1;transform:translateY(-5px) scale(1.05)}to{opacity:1;transform:translateY(0) scale(1)}}.landing-subtitle{color:#4a3f3a;color:var(--text-body);font-family:Quicksand,sans-serif;font-size:1.25rem;font-style:italic;font-weight:400;line-height:1.5;margin-bottom:28px}.landing-description{color:#6b605a;color:var(--text-muted);font-size:1.02rem;line-height:1.75;margin-bottom:24px;margin-left:auto;margin-right:auto;max-width:520px}.social-proof-badge{align-items:center;background:#fff7e6;background:var(--gold-light);border:1px solid #e8b44c4d;border-radius:30px;color:#4a3f3a;color:var(--text-body);display:inline-flex;font-size:.95rem;gap:8px;margin-bottom:28px;opacity:0;padding:10px 22px;transform:translateY(10px)}.landing.visible .social-proof-badge{animation:badgeFadeIn .6s ease 1s forwards}@keyframes badgeFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.social-proof-badge .badge-icon{font-size:1.1rem}.social-proof-badge strong{color:#e07a6a;color:var(--coral);font-weight:700}.landing-stats{display:flex;flex-wrap:wrap;gap:40px;justify-content:center;margin-top:52px}.stat{align-items:center;display:flex;flex-direction:column;gap:4px;opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}.landing.visible .stat{opacity:1;transform:translateY(0)}.landing.visible .stat:first-child{transition-delay:.2s}.landing.visible .stat:nth-child(2){transition-delay:.35s}.landing.visible .stat:nth-child(3){transition-delay:.5s}.stat-number{color:#e07a6a;color:var(--coral);display:inline-block;font-family:Quicksand,sans-serif;font-size:1.6rem;font-weight:700;transition:transform .2s ease}.stat:hover .stat-number{transform:scale(1.1)}.stat-label{font-size:.82rem;line-height:1.4;max-width:130px;text-align:center}.landing-footnote,.stat-label{color:#b5aaa1;color:var(--text-whisper)}.landing-footnote{font-family:Caveat,cursive;font-size:1rem;margin-top:44px}.input-form-container{margin:0 auto;max-width:740px;opacity:0;padding:40px 24px 60px;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}.input-form-container.visible{opacity:1;transform:translateY(0)}.input-form-header{margin-bottom:36px;text-align:center}.input-form-header h2{color:#2c2421;color:var(--text-ink);font-family:Quicksand,sans-serif;font-size:2rem;font-weight:600;margin-bottom:8px}.input-form-header p{color:#6b605a;color:var(--text-muted);font-size:1.02rem}.examples-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));margin-bottom:36px}.example-btn{align-items:center;background:#fff;border:1.5px solid #0000;border-radius:14px;border-radius:var(--r-md);box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);color:#4a3f3a;color:var(--text-body);cursor:pointer;display:flex;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;gap:10px;overflow:hidden;padding:12px 16px;position:relative;text-align:left;transition:all .25s ease}.example-btn:before{background:radial-gradient(circle at center,#e07a6a26 0,#0000 70%);background:radial-gradient(circle at center,var(--coral-glow) 0,#0000 70%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.example-btn:hover:before{opacity:1}.example-btn:hover{border-color:#e07a6a;border-color:var(--coral);box-shadow:0 4px 20px #2c24211a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.example-btn:active{transform:translateY(0) scale(.97);transition:transform .1s ease}.example-btn.active{animation:pop .3s cubic-bezier(.175,.885,.32,1.275);background:#fdf0ee;background:var(--coral-light);border-color:#e07a6a;border-color:var(--coral);box-shadow:0 4px 20px #2c24211a,inset 0 0 0 1px #e07a6a;box-shadow:var(--shadow-md),inset 0 0 0 1px var(--coral)}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.05) translateY(-3px)}to{transform:scale(1) translateY(-2px)}}.example-emoji{flex-shrink:0;font-size:1.25rem;position:relative;transition:transform .25s ease;z-index:1}.example-btn:hover .example-emoji{transform:scale(1.15);transition:transform .25s cubic-bezier(.175,.885,.32,1.275)}.example-text{position:relative;z-index:1}.story-form{background:#fff;border:1px solid #0000000a;border-radius:32px;border-radius:var(--r-xl);box-shadow:0 8px 40px #2c242124;box-shadow:var(--shadow-lg);padding:36px}.form-group{margin-bottom:22px}.form-group label{color:#2c2421;color:var(--text-ink);display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.form-group input[type=text],.form-group textarea{background:#fffbf5;background:var(--cream);border:1.5px solid #e5ddd5;border-radius:14px;border-radius:var(--r-md);color:#2c2421;color:var(--text-ink);font-family:DM Sans,sans-serif;font-size:1rem;padding:14px 18px;resize:vertical;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;width:100%}.form-group input[type=text]:focus,.form-group textarea:focus{background:#fff;border-color:#e07a6a;border-color:var(--coral);box-shadow:0 0 0 4px #e07a6a26,0 4px 20px #2c24211a;box-shadow:0 0 0 4px var(--coral-glow),var(--shadow-md);outline:none;transform:translateY(-2px)}.char-counter{color:#b5aaa1;color:var(--text-whisper);font-family:DM Sans,sans-serif;font-size:.8rem;margin-top:6px;text-align:right}.char-counter .warning{color:#e07a6a;color:var(--coral);font-weight:600}.form-group input[type=range]{accent-color:#e07a6a;accent-color:var(--coral);-webkit-appearance:none;appearance:none;background:#f0ebe3;background:var(--warm-gray);border-radius:3px;height:6px;width:100%}.form-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#e07a6a;background:var(--coral);border:none;border-radius:50%;box-shadow:0 2px 6px #e07a6a66;cursor:pointer;height:20px;-webkit-transition:transform .2s ease,box-shadow .2s ease;transition:transform .2s ease,box-shadow .2s ease;width:20px}.form-group input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 3px 10px #e07a6a80;transform:scale(1.15)}.form-group input[type=range]:active::-webkit-slider-thumb{transform:scale(1.05)}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.age-labels{color:#b5aaa1;color:var(--text-whisper);display:flex;font-size:.82rem;justify-content:space-between;margin-top:4px}.btn-generate{border-radius:50px;font-size:1.15rem;margin-top:8px;padding:18px;width:100%}.generation-progress{animation:fadeSlideIn .7s ease;margin:80px auto;max-width:520px;padding:40px 24px;text-align:center}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.progress-header{margin-bottom:36px}.progress-header h2{color:#2c2421;color:var(--text-ink);font-family:Quicksand,sans-serif;font-size:1.8rem;font-weight:600;margin-bottom:24px}.progress-bar-container{background:#f0ebe3;background:var(--warm-gray);border-radius:3px;height:5px;margin-bottom:10px;overflow:hidden;width:100%}.progress-bar{background:linear-gradient(90deg,#e07a6a,#e8b44c,#6daa73);background:linear-gradient(90deg,var(--coral),var(--gold),var(--sage));border-radius:3px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.elapsed-time{color:#6b605a;color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500}.progress-steps{display:flex;flex-direction:column;gap:6px;margin-bottom:32px;position:relative}.progress-steps:before{background:#f0ebe3;background:var(--warm-gray);border-radius:2px;bottom:28px;content:"";left:38px;position:absolute;top:28px;width:3px;z-index:0}.progress-step{align-items:center;background:#fff;border:1px solid #0000;border-radius:14px;border-radius:var(--r-md);box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);display:flex;gap:16px;padding:16px 22px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:1}.progress-step.active{background:#fdf0ee;background:var(--coral-light);border-color:#e07a6a;border-color:var(--coral);box-shadow:0 4px 20px #2c24211a,0 0 0 4px #e07a6a26;box-shadow:var(--shadow-md),0 0 0 4px var(--coral-glow);transform:scale(1.02)}.progress-step.active:after{animation:activeDot 1.5s ease-in-out infinite;background:#e07a6a;background:var(--coral);border-radius:50%;content:"";height:8px;left:-4px;position:absolute;top:50%;transform:translateY(-50%);width:8px}@keyframes activeDot{0%,to{box-shadow:0 0 0 0 #e07a6a66}50%{box-shadow:0 0 0 8px #e07a6a00}}.progress-step.done{opacity:.7}.progress-step.done .step-icon{animation:checkBounce .4s cubic-bezier(.175,.885,.32,1.275);color:#6daa73;color:var(--sage);font-weight:700}@keyframes checkBounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.step-icon{align-items:center;background:#fff;border-radius:50%;display:flex;flex-shrink:0;font-size:1.35rem;height:32px;justify-content:center;position:relative;text-align:center;width:32px;z-index:2}.progress-step.done .step-icon{background:#ecf5ed;background:var(--sage-light)}.progress-step.active .step-icon{background:#fdf0ee;background:var(--coral-light)}.step-label{color:#4a3f3a;color:var(--text-body);font-size:.98rem;font-weight:500;text-align:left}.progress-step.active .step-icon{animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}}.woman-reveal{align-items:center;animation:womanRevealEntrance .6s cubic-bezier(.175,.885,.32,1.275);background:#fff7e6;background:var(--gold-light);border:1px solid #e8b44c33;border-radius:22px;border-radius:var(--r-lg);display:flex;flex-direction:column;gap:8px;overflow:hidden;padding:24px 28px;position:relative}@keyframes womanRevealEntrance{0%{opacity:0;transform:scale(.85) translateY(15px)}60%{opacity:1;transform:scale(1.03) translateY(-3px)}to{opacity:1;transform:scale(1) translateY(0)}}.woman-reveal .woman-reveal-sparkle{animation:sparkleFloat 2s ease-in-out infinite;font-size:1.2rem;position:absolute}.woman-reveal .woman-reveal-sparkle:first-child{right:20px;top:8px}.woman-reveal .woman-reveal-sparkle:nth-child(2){animation-delay:.5s;animation-duration:2.5s;bottom:8px;font-size:1rem;left:25px}.woman-reveal:after{animation:cardShimmer 1.5s ease-in-out .3s 2;background:linear-gradient(90deg,#0000,#fff9 50%,#0000);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:60%;z-index:10}@keyframes cardShimmer{0%{left:-100%}to{left:150%}}@keyframes sparkleFloat{0%,to{opacity:.7;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-6px) rotate(15deg)}}.woman-reveal-label{color:#6b605a;color:var(--text-muted);font-family:Caveat,cursive;font-size:1rem}.woman-reveal strong{color:#2c2421;color:var(--text-ink);font-family:Quicksand,sans-serif;font-size:1.3rem}.woman-reveal-achievement{color:#6b605a;color:var(--text-muted);font-size:.9rem;line-height:1.55;text-align:center}.wait-tip{align-items:flex-start;background:#f1ecf7;background:var(--purple-light);border-radius:14px;border-radius:var(--r-md);display:flex;gap:12px;margin-top:24px;opacity:0;padding:18px 22px;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease}.wait-tip.visible{opacity:1;transform:translateY(0)}.wait-tip .tip-icon{flex-shrink:0;font-size:1.3rem}.wait-tip p{color:#6b4d8e;color:var(--purple-deep);font-size:.92rem;font-style:italic;line-height:1.5;margin:0}.typewriter-cursor{animation:blink .9s ease-in-out infinite;color:#e07a6a;color:var(--coral);display:inline-block;font-weight:300;margin-left:1px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.storybook{animation:fadeSlideIn .7s ease;margin:0 auto;max-width:880px;min-height:100vh;padding:28px 24px 48px;perspective:1200px}.storybook-page-container{position:relative;transform-style:preserve-3d}.storybook-header{margin-bottom:28px;position:relative;text-align:center}.exit-btn{background:none;border:none;border-radius:8px;border-radius:var(--r-sm);color:#6b605a;color:var(--text-muted);cursor:pointer;font-size:1.5rem;padding:8px 12px;position:absolute;right:0;top:0;transition:all .2s ease;z-index:10}.exit-btn:hover{background:#fdf0ee;background:var(--coral-light);color:#e07a6a;color:var(--coral)}.exit-btn:active{transform:scale(.95)}.story-title{color:#6b4d8e;color:var(--purple-deep);font-family:Quicksand,sans-serif;font-size:2.4rem;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:16px}.page-indicator-container{align-items:center;display:flex;flex-direction:column;gap:10px}.page-indicator{align-items:center;display:flex;gap:12px;justify-content:center}.page-dot{background:#0000;border:2px solid #e07a6a;border:2px solid var(--coral);border-radius:50%;cursor:pointer;height:12px;padding:0;position:relative;transform:scale(1);transition:all .35s cubic-bezier(.34,1.56,.64,1);width:12px}.page-dot:before{background:#2c2421;background:var(--text-ink);border-radius:6px;bottom:calc(100% + 8px);color:#fff;content:attr(data-page);font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;padding:4px 10px;pointer-events:none;transform:translateX(-50%) scale(.8);transition:all .2s ease;white-space:nowrap}.page-dot:after,.page-dot:before{left:50%;opacity:0;position:absolute}.page-dot:after{border:4px solid #0000;border-top:4px solid var(--text-ink);bottom:calc(100% + 4px);content:"";transform:translateX(-50%);transition:opacity .2s ease}.page-dot:hover:after,.page-dot:hover:before{opacity:1}.page-dot:hover:before{transform:translateX(-50%) scale(1)}.page-dot:hover:not(.active){background:#e07a6a40;border-color:#c4594b;border-color:var(--coral-dark);transform:scale(1.2)}.page-dot:focus{box-shadow:0 0 0 4px #e07a6a66;outline:none}.page-dot.active{background:#e07a6a;background:var(--coral);box-shadow:0 0 0 3px #e07a6a26;box-shadow:0 0 0 3px var(--coral-glow);transform:scale(1.4)}.page-dot.seen:not(.active){background:#e07a6a59}.reading-progress{background:#f0ebe3;background:var(--warm-gray);border-radius:2px;height:3px;max-width:200px;overflow:hidden;width:100%}.reading-progress-fill{background:linear-gradient(90deg,#e07a6a,#e8b44c);background:linear-gradient(90deg,var(--coral),var(--gold));border-radius:2px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.storybook-page{-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#fff;border:1px solid #00000008;border-radius:32px;border-radius:var(--r-xl);box-shadow:0 12px 48px #2c24212e,0 2px 8px #2c242114;box-shadow:var(--shadow-book);margin-bottom:28px;overflow:hidden;position:relative;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.4,0,.2,1),opacity .35s ease-out,box-shadow .3s ease}.storybook-page:before{background:linear-gradient(180deg,#e07a6a,#e8b44c);background:linear-gradient(to bottom,var(--coral),var(--gold));border-radius:4px 0 0 4px;bottom:0;content:"";left:0;position:absolute;top:0;width:4px;z-index:2}.storybook-page.exit-left{opacity:0;transform:translateX(-80px) translateZ(-40px) rotateY(8deg) scale(.95)}.storybook-page.exit-right{opacity:0;transform:translateX(80px) translateZ(-40px) rotateY(-8deg) scale(.95)}.storybook-page.enter-left{animation:pageFromRight .55s cubic-bezier(.34,1.56,.64,1) forwards}.storybook-page.enter-right{animation:pageFromLeft .55s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes pageFromRight{0%{box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);opacity:0;transform:translateX(80px) translateZ(-40px) rotateY(-8deg) scale(.95)}70%{opacity:1;transform:translateX(-5px) translateZ(10px) rotateY(1deg) scale(1.01)}to{box-shadow:0 12px 48px #2c24212e,0 2px 8px #2c242114;box-shadow:var(--shadow-book);opacity:1;transform:translateX(0) translateZ(0) rotateY(0) scale(1)}}@keyframes pageFromLeft{0%{box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);opacity:0;transform:translateX(-80px) translateZ(-40px) rotateY(8deg) scale(.95)}70%{opacity:1;transform:translateX(5px) translateZ(10px) rotateY(-1deg) scale(1.01)}to{box-shadow:0 12px 48px #2c24212e,0 2px 8px #2c242114;box-shadow:var(--shadow-book);opacity:1;transform:translateX(0) translateZ(0) rotateY(0) scale(1)}}.page-illustration{aspect-ratio:16/10;background:linear-gradient(135deg,#fef9f2,#fdf0ee,#fff7e6);background:linear-gradient(135deg,var(--parchment),var(--coral-light),var(--gold-light));overflow:hidden;position:relative;width:100%}.illustration-img,.page-illustration img{animation:imageReveal 1s ease;height:100%;object-fit:cover;width:100%}@keyframes imageReveal{0%{-webkit-clip-path:inset(0 0 100% 0);clip-path:inset(0 0 100% 0);filter:blur(4px);opacity:0;transform:scale(1.04)}30%{-webkit-clip-path:inset(0 0 70% 0);clip-path:inset(0 0 70% 0);opacity:1}to{-webkit-clip-path:inset(0 0 0 0);clip-path:inset(0 0 0 0);filter:blur(0);opacity:1;transform:scale(1)}}.illustration-placeholder{align-items:center;animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#fef9f2,#fdf0ee 50%,#fef9f2);background:linear-gradient(90deg,var(--parchment) 0,var(--coral-light) 50%,var(--parchment) 100%);background-size:200% 100%;color:#b5aaa1;color:var(--text-whisper);display:flex;flex-direction:column;gap:10px;height:100%;justify-content:center;width:100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.illustration-placeholder span{font-size:2.5rem;opacity:.6}.illustration-placeholder p{color:#6b605a;color:var(--text-muted);font-family:Caveat,cursive;font-size:1rem}.page-content{padding:36px 44px 32px}.page-label{background:#fdf0ee;background:var(--coral-light);border-radius:20px;color:#c4594b;color:var(--coral-dark);display:inline-block;font-family:Caveat,cursive;font-size:1rem;font-weight:500;margin-bottom:18px;padding:4px 16px}.page-text{color:#2c2421;color:var(--text-ink);font-size:1.22rem;font-weight:400;line-height:1.9}.page-number,.page-text{font-family:Quicksand,sans-serif}.page-number{animation:fadeInUp .6s ease .3s forwards;color:#b5aaa1;color:var(--text-whisper);font-size:.9rem;font-weight:500;margin-top:24px;opacity:0;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.storybook-nav{display:flex;gap:16px;justify-content:space-between}.nav-btn{border-radius:22px;border-radius:var(--r-lg);cursor:pointer;flex:1 1;font-family:DM Sans,sans-serif;font-size:.98rem;font-weight:600;padding:15px 20px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.nav-prev{background:#fff;border:1.5px solid #e5ddd5;color:#6b605a;color:var(--text-muted)}.nav-prev:hover:not(:disabled){border-color:#e07a6a;border-color:var(--coral);box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);color:#e07a6a;color:var(--coral);transform:translateY(-3px)}.nav-prev:disabled{cursor:not-allowed;opacity:.35}.nav-btn:active:not(:disabled){transform:translateY(1px) scaleX(1.03) scaleY(.97);transition:transform .1s ease}.nav-next{background:#e07a6a;background:var(--coral);border:none;box-shadow:0 2px 12px #2c24210f,0 2px 0 #c4594b;box-shadow:var(--shadow-soft),0 2px 0 var(--coral-dark);color:#fff}.nav-next:hover{background:#c4594b;background:var(--coral-dark);transform:translateY(-2px)}.nav-hint{color:#b5aaa1;color:var(--text-whisper);font-family:Caveat,cursive;font-size:.95rem;margin-top:14px;text-align:center}.companion-section{animation:fadeSlideIn .6s ease;margin:0 auto;max-width:680px}.companion-section h2{color:#6b4d8e;color:var(--purple-deep);font-family:Quicksand,sans-serif;font-size:2rem;font-weight:600;margin-bottom:32px;text-align:center}.companion-card{animation:cardSlideIn .5s ease forwards;background:#fff;border:1px solid #00000008;border-radius:22px;border-radius:var(--r-lg);box-shadow:0 2px 12px #2c24210f;box-shadow:var(--shadow-soft);margin-bottom:18px;opacity:0;padding:28px 32px;transform:translateY(15px);transition:box-shadow .25s,transform .25s}.companion-card:first-child{animation-delay:.1s}.companion-card:nth-child(2){animation-delay:.2s}.companion-card:nth-child(3){animation-delay:.3s}@keyframes cardSlideIn{to{opacity:1;transform:translateY(0)}}.companion-card:hover{box-shadow:0 4px 20px #2c24211a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.companion-card h3{color:#e07a6a;color:var(--coral);font-family:Quicksand,sans-serif;font-size:1.15rem;font-weight:600;margin-bottom:10px}.woman-card{background:linear-gradient(135deg,#fff,#fff7e6);background:linear-gradient(135deg,#fff,var(--gold-light));border-left:4px solid #e8b44c;border-left:4px solid var(--gold)}.woman-era{color:#6b605a;color:var(--text-muted);font-family:Caveat,cursive;font-size:1rem;margin-bottom:8px}.discussion-prompts{list-style:none;padding:0}.discussion-prompts li{color:#4a3f3a;color:var(--text-body);font-size:.95rem;line-height:1.55;padding:8px 0 8px 28px;position:relative}.discussion-prompts li:before{content:"💬";font-size:.9rem;left:0;position:absolute}.qa-badge{align-items:center;animation:slideInFade .5s ease;background:#ecf5ed;background:var(--sage-light);border:1px solid #6daa7340;border-radius:14px;border-radius:var(--r-md);display:flex;flex-wrap:wrap;gap:14px;margin-bottom:24px;padding:18px 24px}@keyframes slideInFade{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.qa-icon{animation:bounceIn .6s cubic-bezier(.175,.885,.32,1.275) .2s both;font-size:1.3rem}@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.qa-text{color:#2c2421;color:var(--text-ink);flex:1 1;font-size:.95rem;font-weight:500}.qa-score{color:#6daa73;color:var(--sage);font-family:Quicksand,sans-serif;font-size:1rem;font-weight:700}.companion-nav{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:36px}.fallback-banner{align-items:center;animation:bannerSlideIn .5s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,#6b4d8e,#8b6db5);background:linear-gradient(135deg,var(--purple-deep),var(--purple));border-radius:22px;border-radius:var(--r-lg);box-shadow:0 4px 20px #2c24211a;box-shadow:var(--shadow-md);color:#fff;display:flex;gap:12px;left:50%;max-width:600px;padding:14px 24px;position:fixed;top:20px;transform:translateX(-50%);width:calc(100% - 40px);z-index:999}.fallback-banner .fallback-icon{animation:iconPulse 2s ease-in-out infinite;font-size:1.4rem}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.fallback-banner p{font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;margin:0}@keyframes bannerSlideIn{0%{opacity:0;transform:translateX(-50%) translateY(-30px) scale(.95)}60%{opacity:1;transform:translateX(-50%) translateY(5px) scale(1.02)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.btn-demo{background:#fff6!important;font-weight:700!important;min-height:44px;min-width:44px}.error-banner{align-items:center;animation:bannerSlideIn .5s cubic-bezier(.34,1.56,.64,1);background:#c4594b;background:var(--coral-dark);border-radius:22px;border-radius:var(--r-lg);box-shadow:0 8px 40px #2c242124;box-shadow:var(--shadow-lg);color:#fff;display:flex;flex-direction:column;font-size:.95rem;font-weight:500;gap:12px;left:50%;max-width:600px;padding:16px 24px;position:fixed;text-align:center;top:20px;transform:translateX(-50%);width:calc(100% - 40px);z-index:1000}.error-message{font-size:1rem;margin:0}.error-tip{font-size:.85rem;font-style:italic;font-weight:400;margin:0;opacity:.9}.error-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.error-banner button{background:#fff3;border:none;border-radius:22px;color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;min-height:44px;min-width:44px;padding:10px 18px;transition:all .25s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}.error-banner button:first-child{background:#ffffff59}.error-banner button:hover{background:#ffffff73;transform:translateY(-2px)}.error-banner button:active{transform:translateY(0) scale(.97)}@media (max-width:1024px){.storybook{max-width:760px}.landing-content{max-width:560px}}@media (max-width:768px){.examples-grid{grid-template-columns:repeat(2,1fr)}.storybook{padding:20px 16px 40px}.page-content{padding:32px 28px}.companion-section{padding:0 8px}.landing-title{font-size:3.8rem}.landing-stats{gap:28px}.progress-header h2{font-size:1.5rem}.woman-reveal{padding:20px 22px}.woman-reveal strong{font-size:1.15rem}}@media (max-width:640px){.landing-title{font-size:3rem;letter-spacing:-1px}.landing-stats{flex-direction:column;gap:20px}.btn-cta{font-size:1.05rem;padding:16px 40px}.examples-grid,.form-row{grid-template-columns:1fr}.story-form{padding:24px}.page-content{padding:28px 24px}.page-text{font-size:1.1rem}.story-title{font-size:1.8rem}.storybook-nav{gap:10px}.nav-btn{font-size:.9rem;padding:12px 14px}.companion-card{padding:22px}.landing:after,.landing:before{display:none}.page-illustration{aspect-ratio:4/3}.error-banner button{flex:1 1;min-width:80px}.progress-step{gap:12px;padding:12px 16px}.step-label{font-size:.9rem}.step-icon{font-size:1.2rem;width:28px}.generation-progress{margin:40px auto;padding:24px 16px}.qa-badge{flex-direction:column;gap:8px;text-align:center}}@media (max-width:480px){.landing-title{font-size:2.6rem}.landing-subtitle{font-size:1.1rem}.landing-description{font-size:.95rem}.input-form-container{padding:24px 16px 40px}.input-form-header h2{font-size:1.6rem}.example-btn{font-size:.92rem;padding:10px 14px}.storybook{padding:16px 12px 36px}.story-title{font-size:1.6rem}.page-label{font-size:.9rem;padding:3px 12px}.nav-btn{font-size:.92rem;padding:14px 16px}}@media (max-width:375px){.landing-title{font-size:2.2rem}.landing-subtitle{font-size:1rem}.input-form-header h2{font-size:1.4rem}.page-content{padding:22px 18px}.story-title{font-size:1.4rem}.page-text{font-size:1rem;line-height:1.75}.companion-section h2{font-size:1.6rem}.companion-card h3{font-size:1.05rem}}
/*# sourceMappingURL=main.db9269be.css.map*/