*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--accent-glow: rgba(168, 85, 247, .25);--bg-glass: rgba(255, 255, 255, .03);--bg-card: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(0, 0, 0, .08);--border: rgba(0, 0, 0, .1);--border-focus: rgba(168, 85, 247, .5);--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-watermark: rgba(0, 0, 0, .1);--accent-1: #a855f7;--accent-2: #ec4899;--accent-3: #f97316;--gradient-main: linear-gradient(135deg, #a855f7, #ec4899, #f97316);--gradient-glow: linear-gradient(135deg, rgba(168, 85, 247, .3), rgba(236, 72, 153, .3), rgba(249, 115, 22, .3));--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-glow: 0 0 40px rgba(168, 85, 247, .15);--font-heading: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--transition: .3s cubic-bezier(.4, 0, .2, 1)}html,body{overflow-x:hidden}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:var(--accent-1);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-2)}.hero{position:relative;min-height:auto;display:flex;align-items:flex-start;justify-content:center;text-align:center;overflow:visible}.logo-link-center{display:block;margin-bottom:.5rem;transition:transform var(--transition)}.logo-link-center:hover{transform:scale(1.02)}.app-logo-large{height:auto;width:100%;max-width:560px;max-height:480px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(168,85,247,.4))}.nav-logo{display:block;margin-bottom:1rem}.nav-logo__img{width:120px;height:auto;object-fit:contain;filter:drop-shadow(0 0 10px rgba(168,85,247,.3));transition:transform .2s ease;cursor:pointer}.nav-logo__img:hover{transform:scale(1.05)}@media(max-width:600px){.app-logo-large{max-width:260px}}.hero__layout{position:relative;z-index:2;display:flex;align-items:stretch;width:100%;min-height:auto}.hero__center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:1.5rem 1rem 1rem;z-index:2}.top-nav{position:fixed;top:0;left:0;width:100%;z-index:500;background:transparent;border-bottom:none;box-shadow:none;height:64px;display:flex;align-items:center;pointer-events:none}.top-nav__container{max-width:1200px;margin:0 auto;width:100%;padding:0 1.5rem;display:flex;justify-content:flex-end;align-items:center}.top-nav__logo{display:none}.top-nav__actions,.top-nav__user{display:flex;align-items:center;gap:.75rem;pointer-events:auto}.top-nav__credits{font-size:.85rem;font-weight:600;color:var(--primary);background:#9061ff26;padding:.35rem .75rem;border-radius:99px}.top-nav__dropdown-container{position:relative;display:inline-block}.top-nav__avatar-btn{display:flex;align-items:center;gap:.5rem;background:#9061ff26;color:var(--primary);border:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;padding:.35rem 1rem;border-radius:99px;font-weight:600;transition:all .2s ease}.top-nav__avatar-btn:hover{background:#9061ff40;transform:translateY(-1px)}.top-nav__user-name{font-size:.95rem;font-weight:500;color:var(--text-primary)}.dropdown-chevron{color:var(--text-muted);transition:transform .2s ease,color .2s ease}.top-nav__avatar-btn:hover .dropdown-chevron{color:var(--text-primary)}.top-nav__dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-md);box-shadow:0 10px 40px -10px #00000026,0 0 20px #a855f70d;min-width:210px;padding:.4rem;opacity:0;visibility:hidden;transform:translateY(10px);transition:all .2s cubic-bezier(.16,1,.3,1);z-index:600}.top-nav__dropdown-container:hover .top-nav__dropdown-menu,.top-nav__dropdown-container:focus-within .top-nav__dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .8rem;margin-bottom:.2rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;text-align:left;transition:all .2s ease}.dropdown-item:last-child{margin-bottom:0}.dropdown-item:hover{background:#0000000a;color:var(--accent-1);transform:translate(3px)}.dropdown-item svg{color:var(--text-secondary);transition:color .2s ease}.dropdown-item:hover svg{color:var(--accent-1)}.auth-providers{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.btn--social{background:var(--surface);color:var(--text-base);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem;font-weight:500}.btn--social:hover{background:#ffffff0d;border-color:#fff3}.btn--social img{width:18px;height:18px}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:99999;display:none;align-items:center;justify-content:center;padding:1.5rem}.modal.active{display:flex}.modal__backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffff26;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.modal__content{position:relative;z-index:100000;background:#18181b;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem;width:100%;max-width:440px;box-shadow:0 25px 50px -12px #00000080;animation:modalPop .3s cubic-bezier(.34,1.56,.64,1)}.modal__close{position:absolute;top:1.25rem;right:1.25rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal__close:hover{background:#ffffff0d;color:#fff}@keyframes modalPop{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.marquee-col{position:absolute;top:0;width:290px;height:1500px;overflow:hidden;z-index:10;mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%)}.marquee-col__track{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.marquee-col__track--up{animation:scrollUp 25s linear infinite}.marquee-col__track--down{animation:scrollDown 25s linear infinite}.marquee-col:hover .marquee-col__track{animation-play-state:paused}@keyframes scrollUp{0%{transform:translateY(0)}to{transform:translateY(-50%)}}@keyframes scrollDown{0%{transform:translateY(-50%)}to{transform:translateY(0)}}.marquee-card{width:260px;height:360px;margin:0 auto;border-radius:var(--radius-md);border:3px solid rgba(255,255,255,.7);box-shadow:0 8px 24px #00000040;overflow:hidden;flex-shrink:0;background:var(--bg-secondary);position:relative;transition:transform .3s ease,box-shadow .3s ease;cursor:pointer}.marquee-card:hover{transform:scale(1.06)!important;z-index:5;box-shadow:0 12px 36px #a855f766}.marquee-card.landscape{width:260px;height:190px}.marquee-card img{width:100%;height:100%;object-fit:cover;display:block}@media(max-width:900px){.marquee-col{display:none}}.marquee-col--left{left:0}.marquee-col--right{right:0}.mobile-marquee{display:none;position:relative;left:50%;transform:translate(-50%);width:100vw;overflow:hidden;margin-top:1.5rem;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%)}.mobile-marquee__track{display:flex;gap:.75rem;animation:scrollLeft 20s linear infinite;width:max-content;will-change:transform}.mobile-marquee__img{height:130px;width:auto;border-radius:10px;object-fit:cover;flex-shrink:0}@keyframes scrollLeft{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(max-width:900px){.mobile-marquee{display:block}}.marquee-lightbox{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.marquee-lightbox.active{opacity:1;visibility:visible}.marquee-lightbox__backdrop{position:absolute;inset:0;background:#000000b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.marquee-lightbox__img{position:relative;max-width:90vw;max-height:85vh;border-radius:var(--radius-lg);box-shadow:0 30px 80px #00000080;object-fit:contain;transform:scale(.9);transition:transform .3s ease}.marquee-lightbox.active .marquee-lightbox__img{transform:scale(1)}.marquee-lightbox__close{position:absolute;top:1.5rem;right:1.5rem;z-index:10;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:2rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;line-height:1}.marquee-lightbox__close:hover{background:#ffffff4d;transform:scale(1.1)}.photo-mode-btn.active{border-color:var(--primary)!important;background:#a855f71a!important;color:var(--primary)!important;font-weight:600}.history-section{padding:3rem 0;background:linear-gradient(to bottom,transparent,rgba(168,85,247,.05));border-top:1px solid var(--border);width:100%;position:relative;overflow:hidden;cursor:grab}.history-section:active{cursor:grabbing}.history-gallery{display:flex;flex-wrap:nowrap;gap:2rem;padding:1rem;margin-top:1.5rem;width:max-content;will-change:transform;animation:marquee-scroll 25s linear infinite}.history-gallery:hover,.history-section.paused .history-gallery{animation-play-state:paused}@keyframes marquee-scroll{0%{transform:translate(100vw)}to{transform:translate(-100%)}}.history-card{width:140px;height:190px;border-radius:var(--radius-md);border:3px solid #fff;box-shadow:0 8px 20px #0003;overflow:hidden;position:relative;transition:transform .3s var(--transition);cursor:pointer;background:var(--bg-secondary)}.history-card img{width:100%;height:100%;object-fit:cover}.history-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 12px 30px #a855f74d}.history-card.landscape{width:190px;height:140px;margin-top:25px}.card-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem;color:#fff;position:relative}.card-emoji{font-size:3.75rem;margin-bottom:.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.marquee-card:hover .card-emoji{transform:scale(1.2) rotate(10deg)}.card-details{z-index:2}.card-title{font-family:var(--font-heading);font-weight:800;font-size:1.2rem;line-height:1.2;margin-bottom:.4rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.card-date{font-family:var(--font-body);font-size:.8rem;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.05em}.card-superhero .card-inner{background:linear-gradient(135deg,#ef4444,#3b82f6)}.card-fairy .card-inner{background:linear-gradient(135deg,#f472b6,#4ade80)}.card-space .card-inner{background:linear-gradient(135deg,#1e3a8a,#6366f1)}.card-pool .card-inner{background:linear-gradient(135deg,#0ea5e9,#facc15)}.card-dino .card-inner{background:linear-gradient(135deg,#16a34a,#d97706)}.hero__badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:50px;background:var(--bg-glass);border:1px solid var(--border);color:var(--text-secondary);font-size:.85rem;font-weight:500;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeInUp .8s ease-out}.hero__title{font-family:var(--font-heading);font-size:clamp(3rem,8vw,5.5rem);font-weight:900;line-height:1.05;letter-spacing:-.03em;margin-bottom:1.5rem;animation:fadeInUp .8s ease-out .15s both}.gradient-text{background:var(--gradient-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__subtitle{font-size:1.35rem;font-weight:600;color:var(--text-secondary);max-width:520px;margin:0 auto 1.25rem;line-height:1.7;animation:fadeInUp .8s ease-out .3s both}.hero__cta{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;border-radius:50px;background:var(--gradient-main);color:#fff;font-family:var(--font-heading);font-weight:600;font-size:1.05rem;text-decoration:none;transition:transform var(--transition),box-shadow var(--transition);box-shadow:0 4px 25px #a855f759;animation:fadeInUp .8s ease-out .45s both;margin-bottom:.5rem}.hero__cta:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 40px #a855f780;color:#fff}.hero__glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:var(--gradient-glow);filter:blur(120px);opacity:.4;pointer-events:none}.hero__particles{position:absolute;inset:0;z-index:1;pointer-events:none}.particle{position:absolute;bottom:-10px;border-radius:50%;background:var(--accent-1);animation:float-up linear infinite;opacity:0}@keyframes float-up{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:var(--opacity, .4)}90%{opacity:var(--opacity, .4)}to{transform:translateY(-100vh) scale(.3);opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.app{max-width:800px;margin:0 auto;padding:0 1.5rem 4rem}.app:has(#step1.active),.app:has(#step5.active){max-width:min(95vw,1400px)}.section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color var(--transition),box-shadow var(--transition);animation:fadeInUp .6s ease-out both}.section:hover{border-color:#ffffff1f;box-shadow:var(--shadow-glow)}.section__header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.section__number{width:40px;height:40px;min-width:40px;border-radius:12px;background:var(--gradient-main);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:1rem;color:#fff}.section__title{font-family:var(--font-heading);font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.section__desc{color:var(--text-secondary);font-size:.9rem;margin-top:.15rem}.section--generate{background:transparent;border:none;text-align:center;-webkit-backdrop-filter:none;backdrop-filter:none;padding:1.5rem 2rem}.section--generate:hover{box-shadow:none}.section--preview{border:2px solid transparent;background-image:linear-gradient(var(--bg-secondary),var(--bg-secondary)),var(--gradient-main);background-origin:border-box;background-clip:padding-box,border-box}.api-section .section__header{cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:0;transition:margin-bottom var(--transition)}.api-section .section__header:has(+.api-body:not(.collapsed)){margin-bottom:1.5rem}.chevron{margin-left:auto;transition:transform var(--transition);color:var(--text-muted);align-self:center}.api-body.collapsed+.chevron,.collapsed~.chevron{transform:rotate(0)}.api-body:not(.collapsed)~.chevron{transform:rotate(180deg)}.api-body{overflow:hidden;max-height:300px;transition:max-height .4s ease,opacity .3s ease,margin-top .3s ease;opacity:1;margin-top:1.5rem}.api-body.collapsed{max-height:0;opacity:0;margin-top:0}.api-input-row{display:flex;gap:.75rem}.api-input-row input{flex:1}.api-status{margin-top:.75rem;font-size:.85rem}.status-ok{color:#4ade80}.status-err{color:#ff6b6b}.status-loading{color:var(--text-secondary)}.input-group{margin-bottom:1rem}.input-group--full{grid-column:1 / -1}.input-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.4rem}.input-group input,.input-group textarea,.input-group select{width:100%;padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-glass);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);outline:none;appearance:auto}.input-group input:focus,.input-group textarea:focus,.input-group select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #a855f726;background:var(--bg-glass-hover)}.input-group textarea{resize:vertical;min-height:60px}.input-hint{font-size:.8rem;color:var(--text-muted);margin-top:.35rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1.25rem}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.upload-zone{position:relative;border:3px dashed rgba(168,85,247,.3);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition);overflow:hidden;min-height:220px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#a855f70d,#0a0a0f00 70%)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent-2);background:radial-gradient(circle at center,#ec48991a,#0a0a0f00 70%);transform:scale(1.02);box-shadow:0 10px 40px #a855f726}.upload-zone__content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-zone__icon{color:var(--text-muted);margin-bottom:.5rem;transition:color var(--transition);animation:float 3s ease-in-out infinite}.upload-zone:hover .upload-zone__icon{color:var(--accent-2)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.upload-zone__label{font-family:var(--font-heading);font-size:1.1rem;font-weight:600}.upload-zone__sublabel{color:var(--text-secondary);font-size:.9rem}.upload-zone__formats{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.upload-zone__preview{display:none;max-width:100%;max-height:300px;border-radius:var(--radius-md);object-fit:contain}.upload-zone__remove{display:none;position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;border-radius:50%;background:#ff3c3cd9;color:#fff;border:none;cursor:pointer;font-size:1rem;align-items:center;justify-content:center;transition:transform var(--transition),background var(--transition);z-index:5}.upload-zone__remove:hover{transform:scale(1.1);background:#ff4757;color:#fff}.upload-zone.has-photo{border-style:solid;border-color:var(--border);padding:1rem}.party-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem;width:100%;max-width:1400px;margin-left:auto;margin-right:auto;padding:0 2rem}@media(max-width:600px){.party-type-grid{gap:.85rem;padding:0 .75rem}}.party-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;background:var(--bg-secondary);border:2.5px solid var(--border);border-radius:18px;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;color:var(--text-primary);overflow:hidden;position:relative;aspect-ratio:3 / 4}.party-type-btn:hover{border-color:var(--accent-1);transform:translateY(-8px) scale(1.03);box-shadow:0 16px 40px #a855f740,0 4px 12px #0003}.party-type-btn.selected{border-color:var(--accent-1);box-shadow:0 0 0 3px var(--accent-1),0 8px 32px #a855f759;transform:scale(1.04)}.party-type-btn__img{width:100%;height:100%;position:absolute;top:0;left:0;z-index:1}.party-type-btn__img .slide{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}@keyframes cel-slide-5{0%{opacity:1;transform:scale(1.04)}16%{opacity:1;transform:scale(1.04)}20%{opacity:0;transform:scale(1)}96%{opacity:0;transform:scale(1)}to{opacity:1;transform:scale(1.04)}}@keyframes cel-slide-a{0%,40%{opacity:1;transform:scale(1.07)}50%,90%{opacity:0;transform:scale(1)}to{opacity:1;transform:scale(1.07)}}@keyframes cel-slide-b{0%,40%{opacity:0;transform:scale(1)}50%,90%{opacity:1;transform:scale(1.07)}to{opacity:0;transform:scale(1)}}.party-type-btn__img .slide--1{animation:cel-slide-a 9s ease-in-out infinite;animation-delay:var(--slide-delay, 0s)}.party-type-btn__img .slide--2{animation:cel-slide-b 9s ease-in-out infinite;animation-delay:var(--slide-delay, 0s);opacity:0}.party-type-btn__img .slide--3,.party-type-btn__img .slide--4,.party-type-btn__img .slide--5{opacity:0}.party-type-btn__img:has(.slide--5) .slide--1{animation:cel-slide-5 50s ease-in-out infinite;animation-delay:calc(var(--slide-delay, 0s) + 0s)}.party-type-btn__img:has(.slide--5) .slide--2{animation:cel-slide-5 50s ease-in-out infinite;animation-delay:calc(var(--slide-delay, 0s) - 40s)}.party-type-btn__img:has(.slide--5) .slide--3{animation:cel-slide-5 50s ease-in-out infinite;animation-delay:calc(var(--slide-delay, 0s) - 30s)}.party-type-btn__img:has(.slide--5) .slide--4{animation:cel-slide-5 50s ease-in-out infinite;animation-delay:calc(var(--slide-delay, 0s) - 20s)}.party-type-btn__img:has(.slide--5) .slide--5{animation:cel-slide-5 50s ease-in-out infinite;animation-delay:calc(var(--slide-delay, 0s) - 10s)}.party-type-btn__label{position:absolute;bottom:0;left:0;width:100%;padding:1.1rem .6rem .85rem;font-size:1rem;font-weight:700;letter-spacing:.03em;color:#fff;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.3) 60%,transparent 100%);text-shadow:0 1px 4px rgba(0,0,0,.9);text-align:center}@media(max-width:600px){.party-type-btn__label{font-size:.72rem;padding:.7rem .3rem .55rem}}.theme-container{position:relative;min-height:400px}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;animation:fadeIn .4s ease-out;max-width:1400px;margin-left:auto;margin-right:auto;padding:0 2rem}@media(max-width:900px){.category-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}@media(max-width:600px){.category-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:0 .75rem}}.category-card{position:relative;aspect-ratio:3 / 4;overflow:hidden;border-radius:18px;border:2.5px solid var(--border);cursor:pointer;background:var(--bg-secondary);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;padding:0;display:block}.category-card:hover{border-color:var(--accent-1);transform:translateY(-8px) scale(1.03);box-shadow:0 16px 40px #a855f740,0 4px 12px #0003}.category-card__emoji{display:none}.category-card__name{position:absolute;bottom:0;left:0;width:100%;padding:1.1rem .6rem .85rem;font-size:1rem;font-weight:700;letter-spacing:.03em;color:#fff;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.3) 60%,transparent 100%);text-shadow:0 1px 4px rgba(0,0,0,.9);text-align:center;font-family:var(--font-heading)}.theme-selection-view{animation:slideUpFade .4s cubic-bezier(.16,1,.3,1)}.theme-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;animation:fadeIn .4s ease-out}.btn--back{padding:.6rem 1.2rem;font-size:.9rem;border-radius:50px;background:var(--bg-glass);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:var(--transition);font-weight:600}.btn--back:hover{background:var(--bg-glass-hover);color:var(--text-primary);transform:translate(-3px);border-color:var(--accent-1)}.theme-header__title{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:1400px;margin-left:auto;margin-right:auto;padding:0 2rem}@media(max-width:900px){.theme-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}@media(max-width:600px){.theme-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:0 .75rem}}.theme-card{position:relative;aspect-ratio:3 / 4;overflow:hidden;border-radius:18px;border:2.5px solid var(--border);cursor:pointer;background:var(--bg-secondary);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;padding:0;display:block;text-align:left}.theme-card:hover{border-color:var(--accent-1);transform:translateY(-8px) scale(1.03);box-shadow:0 16px 40px #a855f740,0 4px 12px #0003}.theme-card.selected{border-color:var(--accent-1);box-shadow:0 0 0 3px var(--accent-1),0 8px 32px #a855f759;transform:scale(1.04)}.theme-card__gradient{position:absolute;inset:0;opacity:.9;transition:opacity .3s ease}.theme-card:hover .theme-card__gradient{opacity:1}.theme-card__info,.theme-card__emoji{display:none}.theme-card__name{position:absolute;bottom:0;left:0;width:100%;padding:1.1rem .6rem .85rem;font-size:1rem;font-weight:700;letter-spacing:.03em;color:#fff;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.3) 60%,transparent 100%);text-shadow:0 1px 4px rgba(0,0,0,.9);text-align:center;font-family:var(--font-heading)}.theme-card__check{position:absolute;top:.75rem;right:.75rem;width:26px;height:26px;border-radius:50%;background:var(--accent-1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;opacity:0;transform:scale(.5);transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 10px #0003;z-index:2}.theme-card.selected .theme-card__check{opacity:1;transform:scale(1)}.orientation-toggle{display:flex;gap:1rem}.orientation-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 1rem;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg-glass);cursor:pointer;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition),background var(--transition);font-family:var(--font-body);color:var(--text-primary)}.orientation-btn:hover{border-color:#fff3;transform:translateY(-2px);background:var(--bg-glass-hover)}.orientation-btn.selected{border-color:var(--accent-1);box-shadow:0 0 20px #a855f740;background:#a855f714}.orientation-btn__icon{color:var(--text-muted);transition:color var(--transition)}.orientation-btn.selected .orientation-btn__icon{color:var(--accent-1)}.orientation-btn__label{font-family:var(--font-heading);font-weight:600;font-size:.95rem}.orientation-btn__ratio{font-size:.75rem;color:var(--text-muted);background:var(--bg-glass);padding:.15rem .6rem;border-radius:50px;border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.75rem 1.5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-glass);color:var(--text-primary);font-family:var(--font-heading);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition)}.btn:hover:not(:disabled){background:var(--bg-glass-hover);border-color:#fff3}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--sm{padding:.55rem 1.1rem;font-size:.85rem}.btn--primary{background:var(--gradient-main);border:none;color:#fff;box-shadow:0 4px 15px #a855f740}.btn--primary:hover:not(:disabled){box-shadow:0 8px 30px #a855f766;transform:translateY(-1px)}.btn--secondary{border-color:var(--accent-1);color:var(--accent-1)}.btn--secondary:hover:not(:disabled){background:#a855f71a}.btn--ghost:hover:not(:disabled){color:var(--text-primary)}.btn--generate{padding:1.1rem 3rem;font-size:1.1rem;border-radius:50px;background:var(--gradient-main);border:none;color:#fff;box-shadow:0 6px 30px #a855f759}.btn--generate:hover:not(:disabled){box-shadow:0 10px 50px #a855f78c;transform:translateY(-3px) scale(1.02)}.btn--generate:disabled{background:var(--bg-glass);border:1px solid var(--border);box-shadow:none}.btn__icon{flex-shrink:0}.generate-hint{font-size:.85rem;color:var(--text-muted);margin-top:.75rem;transition:color var(--transition)}.generate-hint.ready{color:#4ade80}.card-protection-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;background:transparent;cursor:default;display:none}.card-preview img,.marquee-card img,.thumbnail img,.history-card img,.history-modal-card img,.template-card img,.template-lightbox__img{-webkit-user-select:none!important;user-select:none!important;-webkit-user-drag:none!important;pointer-events:none!important;-webkit-touch-callout:none!important}.card-protection-layer,#historyPreviewLightbox img,#historyPreviewLightbox,#templateLightbox,.template-lightbox__img-wrap{-webkit-touch-callout:none!important;-webkit-user-select:none!important;user-select:none!important}.step5-template-header{display:none}#step5.template-mode .step-header{display:none!important}#step5.template-mode>div:nth-of-type(1){display:none!important}#step5.template-mode .theme-container{display:none!important}#step5.template-mode .step5-template-header{display:block!important;margin-bottom:1.5rem}#step5.template-mode .step5-template-header h2{font-size:1.4rem;font-weight:700;margin-bottom:.4rem}#step5.template-mode .step5-template-header p{color:var(--text-muted);font-size:.95rem}.recursive-watermark-layer{position:absolute;inset:0;z-index:15;pointer-events:none;opacity:.75;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Ctext x='50%25' y='50%25' font-size='11' font-family='Outfit, sans-serif' font-weight='900' fill='black' opacity='1' text-anchor='middle' dominant-baseline='middle' transform='rotate(-45 60 60)'%3EPREVIEW SAMPLE%3C/text%3E%3C/svg%3E");background-repeat:repeat;background-size:120px 120px;display:none}.history-card .recursive-watermark-layer{opacity:.8;display:block!important}.card-preview{width:100%;border-radius:var(--radius-md);overflow:hidden;position:relative;background:transparent;display:flex;align-items:center;justify-content:center}.card-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;background:#00000085;border:2px solid rgba(255,255,255,.4);color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:110;transition:background .2s,border-color .2s,box-shadow .2s,transform .18s;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);line-height:1;padding:0;box-shadow:0 4px 16px #0006}.card-nav-arrow:hover{background:#ffffff2e;border-color:#ffffffd9;box-shadow:0 0 0 4px #ffffff1f,0 6px 24px #00000080;transform:translateY(-50%) scale(1.18)}.card-nav-arrow:active{transform:translateY(-50%) scale(.93);background:#ffffff14}.card-nav-arrow--prev{left:14px}.card-nav-arrow--next{right:14px}.watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-15deg);font-family:var(--font-heading);font-size:2rem;font-weight:900;color:#ffffff80;background:#0006;padding:1rem 3rem;border:4px dashed rgba(255,255,255,.3);border-radius:var(--radius-md);pointer-events:none;z-index:10;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;display:none}.thumbnail-grid{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.thumbnail{width:70px;height:93px;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s ease;opacity:.6;background:var(--bg-secondary);position:relative}.thumbnail-watermark{position:absolute;inset:0;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.75;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Ctext x='50%25' y='50%25' font-size='5' font-family='sans-serif' font-weight='700' fill='black' opacity='1' text-anchor='middle' dominant-baseline='middle' transform='rotate(-45 20 20)'%3EPREVIEW SAMPLE%3C/text%3E%3C/svg%3E");background-repeat:repeat;background-size:40px 40px}.thumbnail:hover{opacity:1;transform:translateY(-2px)}.thumbnail-label{position:absolute;bottom:4px;right:5px;background:#0000008c;color:#fff;font-size:.65rem;font-weight:700;border-radius:3px;padding:1px 4px;pointer-events:none}.thumbnail.selected{border-color:var(--accent-primary);opacity:1;box-shadow:0 0 15px #fbbf2466}.thumbnail img{width:100%;height:100%;object-fit:cover}.card-preview__loading{min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;text-align:center;position:relative;overflow:hidden}.card-preview__loading p{font-family:var(--font-heading);font-weight:600;font-size:1.1rem}.loading-subtext{font-size:.85rem!important;font-weight:400!important;color:var(--text-muted)}.confetti-piece{position:absolute;border-radius:2px;animation:confettiFall linear infinite;opacity:0;pointer-events:none}@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(360px) rotate(720deg);opacity:0}}.party-loader__orbit{position:relative;width:110px;height:110px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.party-loader__icon{font-size:3.2rem;animation:partyBounce .65s ease-in-out infinite alternate;display:block;line-height:1;z-index:1}@keyframes partyBounce{0%{transform:scale(1) translateY(0);filter:drop-shadow(0 4px 8px rgba(168,85,247,.3))}to{transform:scale(1.18) translateY(-10px);filter:drop-shadow(0 12px 20px rgba(168,85,247,.5))}}.party-loader__orbit-ring{position:absolute;inset:0;border-radius:50%;animation:orbitSpin 3.2s linear infinite}.party-loader__spark{position:absolute;font-size:1.3rem;line-height:1}@keyframes orbitSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.party-loader__title{font-family:var(--font-heading);font-weight:700;font-size:1.15rem;color:var(--text-primary);animation:msgPop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes msgPop{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.party-loader__dots{display:flex;gap:7px;align-items:center;justify-content:center}.party-loader__dot{width:9px;height:9px;border-radius:50%;animation:dotBounce 1.1s ease-in-out infinite}.party-loader__dot:nth-child(1){background:#a855f7;animation-delay:0s}.party-loader__dot:nth-child(2){background:#ec4899;animation-delay:.18s}.party-loader__dot:nth-child(3){background:#f97316;animation-delay:.36s}@keyframes dotBounce{0%,80%,to{transform:scale(1) translateY(0)}40%{transform:scale(1.4) translateY(-9px)}}.party-loader__warn{font-size:.78rem!important;font-weight:600!important;color:#e11d48!important}.party-loader__cancel{display:inline-flex;align-items:center;gap:.4rem;margin-top:.5rem;padding:.55rem 1.25rem;border:1.5px solid rgba(220,38,127,.35);border-radius:999px;background:#dc267f12;color:#be185d;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .18s,border-color .18s,transform .12s}.party-loader__cancel:hover{background:#dc267f24;border-color:#dc267f99;transform:scale(1.03)}.party-loader__cancel:active{transform:scale(.97)}.magic-text-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .85rem;border-radius:999px;border:1.5px solid transparent;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;letter-spacing:.02em;transition:opacity .15s,transform .12s;white-space:nowrap;font-family:Outfit,sans-serif}.magic-text-btn:hover{opacity:.88;transform:scale(1.04)}.magic-text-btn:active{transform:scale(.96)}.magic-text-btn.magic-btn--reset{background:transparent;border-color:#a855f773;color:#c084fc}.magic-text-btn.magic-btn--reset:hover{background:#a855f71a}.magic-btn__icon{font-size:.95em}.card-preview__image{display:none;width:100%;height:auto;border-radius:var(--radius-md)}.card-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.actions-group{display:flex;gap:1rem}.btn--unlock{background:linear-gradient(135deg,#fbbf24,#d97706);color:#fff;box-shadow:0 4px 15px #d977064d}.btn--unlock:hover{box-shadow:0 8px 30px #d9770680;transform:translateY(-1px)}.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent-1);border-radius:50%;animation:spin .8s linear infinite}.spinner--sm{width:22px;height:22px;border-width:2px}.error-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;text-align:center}.error-title{font-family:var(--font-heading);font-weight:700;font-size:1.2rem;color:#ff6b6b}.error-message{font-size:.9rem;color:var(--text-secondary);max-width:400px}.footer{text-align:center;padding:1.5rem 1rem 1rem;color:var(--text-muted);font-size:.85rem;border-top:1px solid var(--border)}.footer strong{background:var(--gradient-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.hero{min-height:70vh}.hero__title{font-size:clamp(2.4rem,10vw,3.5rem)}.app{padding:0 1rem 3rem}.section{padding:1.5rem}.card-actions{flex-direction:column;align-items:stretch}.card-actions .btn{justify-content:center}}.balloon-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.app{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%}.section{width:100%;max-width:600px;margin:0 auto 2rem;padding:2.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm);position:relative}.balloon{position:absolute;bottom:-100px;width:40px;height:50px;border-radius:50%;background:currentColor;opacity:.9;box-shadow:inset -5px -5px 10px #0000001a,inset 5px 5px 10px #ffffff4d}.balloon:before{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:6px;height:8px;background:inherit;clip-path:polygon(50% 0%,0% 100%,100% 100%)}.balloon:after{content:"";position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:1px;height:20px;background:#ffffff80}.wizard-container{position:relative;width:100%;max-width:600px;margin:0 auto;min-height:60vh}.wizard-container:has(#stepEntry.active){max-width:80vw;padding-top:3rem}.wizard-container:has(#step1.active),.wizard-container:has(#step5.active){max-width:min(95vw,1400px)}.wizard-step{display:none;animation:fadeIn .4s ease}.wizard-step.active{display:block}.step-header{text-align:center;margin-bottom:2rem}.step-header h2{font-size:1.75rem;margin-bottom:.5rem;background:var(--gradient-main);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.step-header p{color:var(--text-secondary)}.subsection-title{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary);border-left:3px solid var(--accent-1);padding-left:.75rem}.wizard-nav{position:relative;width:100%;margin-top:2rem;padding:1rem 0;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:10}.wizard-nav__inner{width:100%;max-width:600px;display:flex;justify-content:space-between;align-items:center}.wizard-dots{display:flex;gap:.5rem}.dot{width:8px;height:8px;border-radius:50%;background:var(--bg-glass-hover);transition:var(--transition)}.dot.active{background:var(--accent-1);transform:scale(1.2)}.dot.completed{background:var(--accent-2)}.app{padding-bottom:80px}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:.9}90%{opacity:.9}to{transform:translateY(-120vh) rotate(15deg);opacity:0}}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{background:#fff;color:#1a1a1a;padding:14px 20px;border-radius:12px;box-shadow:0 8px 24px #0000001f;display:flex;align-items:center;gap:12px;min-width:280px;max-width:400px;animation:slideInRight .3s cubic-bezier(.16,1,.3,1) forwards;pointer-events:auto;border:1px solid rgba(0,0,0,.05);font-family:Inter,sans-serif;font-size:.95rem;font-weight:500}.toast.error{border-left:4px solid #FF6B6B}.toast.success{border-left:4px solid #4ECDC4}.toast.info{border-left:4px solid #45B7D1}.toast__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{to{transform:translate(100%);opacity:0}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.watermark{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));align-items:center;justify-items:center;overflow:hidden;gap:1rem;padding:1rem;background:transparent}.watermark__text{font-family:Inter,sans-serif;font-weight:800;font-size:1.1rem;color:var(--text-watermark);text-transform:uppercase;transform:rotate(-25deg);white-space:nowrap;-webkit-user-select:none;user-select:none}.credit-badge{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;color:#fbbf24;margin-right:1rem;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffff26;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:1000;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition)}.modal.active{display:flex;opacity:1}.modal__content{background:var(--bg-secondary);border:1px solid var(--border);padding:2rem;border-radius:var(--radius-lg);width:90%;max-width:500px;position:relative;transform:translateY(20px);transition:transform var(--transition);box-shadow:var(--shadow-lg)}.modal.active .modal__content{transform:translateY(0)}#checkoutModal{align-items:flex-start;overflow-y:auto;padding:1rem}#checkoutModal .modal__content{max-height:none;width:100%;margin:auto}@media(max-width:600px){#checkoutModal{padding:0;align-items:flex-start}#checkoutModal .modal__content{width:100%;min-height:100%;border-radius:0}}.modal__close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition)}.modal__close:hover{color:var(--text-primary)}.modal__title{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:.5rem;background:var(--gradient-main);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal__desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}#legalModalBody{font-size:.9rem;line-height:1.6;color:var(--text-primary);padding:0 1rem 1rem}#legalModalBody .legal-nav{display:flex;gap:.75rem;border-bottom:2px solid var(--border);padding-bottom:1rem;margin-bottom:1.5rem;overflow-x:auto;position:sticky;top:0;background:var(--bg-secondary);z-index:10;padding-top:1rem;margin-top:-1rem}#legalModalBody .legal-nav button{background:var(--bg-glass);border:1px solid var(--border);font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--text-secondary);cursor:pointer;padding:.5rem 1rem;border-radius:50px;transition:all var(--transition);white-space:nowrap}#legalModalBody .legal-nav button:hover{background:var(--bg-glass-hover);color:var(--text-primary)}#legalModalBody .legal-nav button.active{color:#fff;background:var(--gradient-main);border-color:transparent;box-shadow:0 4px 12px #a855f733}#legalModalBody .legal-section{animation:fadeIn .4s ease forwards}#legalModalBody h1{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;margin-bottom:.5rem;color:var(--text-primary)}#legalModalBody p:first-of-type{font-size:.8rem;color:var(--text-muted);margin-bottom:2rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}#legalModalBody h2{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;margin-top:2rem;margin-bottom:.75rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}#legalModalBody p,#legalModalBody li{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem}#legalModalBody ul{padding-left:1.5rem;margin-bottom:1.5rem}#legalModalBody li{margin-bottom:.5rem;position:relative}#legalModalBody h3{font-family:var(--font-heading);font-size:1rem;margin-top:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.modal__price{display:flex;justify-content:space-between;align-items:center;margin:1.5rem 0;padding:1rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border)}.price-tag{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--accent-2)}.btn--full{width:100%;justify-content:center}.btn--accent:hover{box-shadow:0 0 15px #fff6;transform:translateY(-2px)}.stripe-badge{font-size:.75rem;font-weight:400;opacity:.9;margin-bottom:.25rem;color:#fffc}.stripe-badge strong{color:#fff;font-weight:700}.premium-button{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:1rem 2rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;align-items:center}.premium-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.btn--sm{padding:.4rem .8rem;font-size:.85rem}.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn--ghost:hover{background:#ffffff0d;color:var(--text-primary);border-color:var(--text-muted)}.customize-options{margin-top:2.5rem;padding:2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);animation:fadeInScale .4s ease-out}.customize-options .subsection-title{font-size:1.15rem;margin-bottom:.35rem}.subsection-description{color:var(--text-secondary);font-size:.88rem;margin-bottom:1.75rem}.customization-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 3rem}@media(max-width:700px){.customization-grid{grid-template-columns:1fr}}.custom-item{display:flex;flex-direction:column;gap:.85rem}.custom-item__label{font-weight:700;font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.character-list{display:flex;flex-wrap:wrap;gap:.6rem}.char-chip{padding:.55rem 1.1rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:50px;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem;color:var(--text-secondary)}.char-chip:before{content:"+";font-size:1rem;font-weight:700;line-height:1;color:var(--text-muted);transition:all .2s ease}.char-chip:hover{border-color:var(--accent-1);background:#a855f714;color:var(--text-primary)}.char-chip.selected{background:#a855f71f;color:var(--accent-1);border-color:var(--accent-1);box-shadow:0 0 0 3px #a855f726}.char-chip.selected:before{content:"✓";color:var(--accent-1)}.role-select{display:flex;flex-direction:column;gap:.6rem}.role-option{padding:.75rem 1rem .75rem 1.1rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.85rem;color:var(--text-secondary)}.role-option:before{content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;border:2px solid var(--border);transition:all .2s ease;background:transparent}.role-option:hover{border-color:var(--accent-1);background:#a855f70d;color:var(--text-primary)}.role-option:hover:before{border-color:var(--accent-1)}.role-option.selected{border-color:var(--accent-1);background:#a855f714;color:var(--text-primary);font-weight:600}.role-option.selected:before{background:var(--accent-1);border-color:var(--accent-1);box-shadow:0 0 0 3px #a855f733}.history-header{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto 2rem;padding:0 1rem}.history-header .section-title{margin:0}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.animate-tilt{animation:tiltEffect 2.5s ease-in-out infinite alternate!important;transform-style:preserve-3d;perspective:1000px}@keyframes tiltEffect{0%{transform:rotateY(-8deg) rotateX(2deg) scale(1.02)}to{transform:rotateY(8deg) rotateX(-2deg) scale(1.02)}}.celebrate-shimmer{position:relative;overflow:hidden}.celebrate-shimmer:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 0%,rgba(255,255,255,.1) 45%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.1) 55%,transparent 100%);transform:rotate(45deg);animation:shimmerSwipe 3s infinite;pointer-events:none;z-index:100}@keyframes shimmerSwipe{0%{transform:translate(-100%,-100%) rotate(45deg)}to{transform:translate(100%,100%) rotate(45deg)}}#animateBtn,#downloadVideoBtn{background:linear-gradient(135deg,#6366f1,#8b5cf6,#d946ef);color:#fff;font-weight:700;border:none;filter:drop-shadow(0 4px 12px rgba(139,92,246,.35));transition:all .3s cubic-bezier(.175,.885,.32,1.275)}#downloadVideoBtn:hover:not(:disabled){transform:scale(1.05) translateY(-2px);filter:drop-shadow(0 8px 20px rgba(139,92,246,.5)) brightness(1.1)}#downloadVideoBtn:disabled{opacity:.7;cursor:wait}.video-progress{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;margin-top:1rem;background:linear-gradient(135deg,#6366f114,#8b5cf614);border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-lg);animation:fadeInScale .4s ease-out}.video-progress__spinner{width:40px;height:40px;min-width:40px;border:3px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.video-progress__title{font-weight:700;font-size:1rem;color:var(--text-primary);margin:0 0 .25rem}.video-progress__detail{font-size:.85rem;color:var(--text-secondary);margin:0}.video-player-container{margin-top:1.5rem;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);padding:1rem;animation:fadeInScale .5s ease-out;text-align:center}.video-player{width:100%;max-width:480px;border-radius:var(--radius-md);box-shadow:0 10px 30px #00000026}.speech-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.speech-modal__backdrop{position:absolute;inset:0;background:#f0ebff8c;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.speech-modal__content{position:relative;background:#fff;border:1px solid rgba(168,85,247,.18);border-radius:var(--radius-lg);padding:2rem;max-width:520px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 2px #a855f70f,0 8px 24px #a855f71a,0 32px 64px #0000001f;animation:modalSpring .35s cubic-bezier(.34,1.56,.64,1) forwards}.speech-modal__title{font-size:1.3rem;font-weight:700;margin:0 0 .25rem;color:#0f0b1e}.speech-modal__subtitle{font-size:.85rem;color:var(--text-secondary);margin:0 0 1.25rem}.speech-modal__options{display:flex;flex-direction:column;gap:.5rem}.speech-option{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;border-radius:var(--radius-sm);border:1.5px solid #e2e8f0;cursor:pointer;transition:all .2s ease;font-size:.9rem;color:#334155;background:#f8fafc}.speech-option:hover{border-color:#a855f766;background:#a855f70a}.speech-option input[type=radio]{accent-color:var(--purple);width:16px;height:16px;flex-shrink:0}.speech-option:has(input:checked){border-color:var(--purple);background:#a855f714;box-shadow:0 0 0 1px var(--purple)}.speech-option span{flex:1}.speech-option--custom{flex-wrap:wrap}.speech-custom-input{width:100%;margin-top:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid #e2e8f0;background:#f8fafc;color:#1e293b;font-size:.85rem;font-family:inherit;outline:none;transition:border-color .2s}.speech-custom-input::placeholder{color:#94a3b8}.speech-custom-input:focus{border-color:var(--accent-1)}.speech-custom-input:disabled{opacity:.45;cursor:not-allowed}.speech-modal__actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.confirm-modal{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.confirm-modal.active{opacity:1;visibility:visible}.confirm-modal__backdrop{position:absolute;inset:0;background:#f0ebff8c;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.confirm-modal__box{position:relative;background:#fff;border:1px solid rgba(168,85,247,.18);border-radius:var(--radius-lg);padding:2rem 2.5rem;max-width:400px;width:90%;text-align:center;box-shadow:0 2px #a855f70f,0 8px 24px #a855f71a,0 32px 64px #0000001f;animation:modalSpring .35s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes modalSpring{0%{opacity:0;transform:scale(.88);filter:blur(3px)}65%{opacity:1;transform:scale(1.02);filter:blur(0)}to{opacity:1;transform:scale(1);filter:blur(0)}}.confirm-modal__icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;flex-shrink:0}.confirm-modal--warning .confirm-modal__icon{background:#fbbf241f;border:1.5px solid rgba(251,191,36,.35);color:#d97706}.confirm-modal--error .confirm-modal__icon{background:#f43f5e1a;border:1.5px solid rgba(244,63,94,.3);color:#e11d48}.confirm-modal--success .confirm-modal__icon{background:#10b9811a;border:1.5px solid rgba(16,185,129,.3);color:#059669}.confirm-modal--info .confirm-modal__icon{background:#a855f71a;border:1.5px solid rgba(168,85,247,.3);color:#9333ea}.confirm-modal--email .confirm-modal__icon{background:#6366f11a;border:1.5px solid rgba(99,102,241,.28);color:#6366f1}.confirm-modal__title{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:#0f0b1e;margin:0 0 .45rem;letter-spacing:-.01em}.confirm-modal__msg{font-size:.9rem;color:#64748b;margin:0 0 1.75rem;line-height:1.6}.confirm-modal__msg strong{color:#1e293b;font-weight:600}.confirm-modal__actions{display:flex;gap:.75rem;justify-content:center}.confirm-modal__box button[aria-label=Close]{color:#94a3b8!important}.confirm-modal__box button[aria-label=Close]:hover{color:#475569!important}#_alertDialog .confirm-modal__box{border-top-width:3px}#_alertDialog.confirm-modal--error .confirm-modal__box{border-top-color:#f43f5e}#_alertDialog.confirm-modal--success .confirm-modal__box{border-top-color:#10b981}#_alertDialog.confirm-modal--info .confirm-modal__box{border-top-color:#a855f7}.suggest-type-btn{display:flex;align-items:center;justify-content:center;padding:.55rem .75rem;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:.88rem;font-weight:600;color:#64748b;background:#f8fafc;transition:all .15s;-webkit-user-select:none;user-select:none}.suggest-type-btn:has(input:checked){border-color:#a855f7;background:#a855f714;color:#7c3aed}.suggest-type-btn:hover:not(:has(input:checked)){border-color:#a855f759;background:#a855f70a}.category-card__thumb{position:absolute;inset:0;width:100%;height:100%;border-radius:0;overflow:hidden;background:var(--bg-secondary)}.category-card__img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.category-card:hover .category-card__img{transform:scale(1.08)}.theme-card__thumb{position:absolute;inset:0;width:100%;height:100%;border-radius:0;overflow:hidden;background:var(--bg-secondary)}.theme-card__img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.theme-card:hover .theme-card__img{transform:scale(1.08)}.theme-card__check{position:absolute;top:.5rem;right:.5rem}.prompt-details{margin-top:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.prompt-details summary{padding:.6rem 1rem;cursor:pointer;font-size:.85rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.prompt-details summary:hover{color:var(--text-primary)}.prompt-text{padding:1rem;margin:0;font-size:.75rem;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;border-top:1px solid var(--border);max-height:200px;overflow-y:auto}.inv-text-item{position:absolute;box-sizing:border-box}.inv-text-item:hover{outline:1.5px dashed rgba(168,85,247,.55);outline-offset:3px;border-radius:2px}.inv-resize-handle{opacity:0;transition:opacity .18s ease}.inv-text-item:hover .inv-resize-handle,.inv-text-item:focus-within .inv-resize-handle{opacity:1}@media(hover:none){.inv-resize-handle{opacity:1}}.card-preview__canvas-wrapper{position:relative;width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary)}.text-overlay-container{position:absolute;inset:0;pointer-events:none;z-index:10}.text-layer{position:absolute;pointer-events:auto;cursor:move;padding:2px 4px;border:1px solid transparent;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:border-color .2s ease,background .2s ease;border-radius:4px;background:#ffffff1a}.text-layer:hover{border-color:#ffffff4d}.text-layer.active{border-color:var(--primary);background:#fff3;box-shadow:0 0 0 2px #6c5ce733}.text-layer:focus{outline:none}.text-toolbar{margin-top:1rem;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:100}.text-tools{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.tool-divider{width:1px;height:20px;background:var(--border);margin:0 .25rem}.tool-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.tool-btn:hover{border-color:var(--primary);color:var(--primary)}.tool-btn.btn--danger:hover{border-color:#ff7675;color:#ff7675}.tool-select{padding:.25rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem}.tool-input{width:50px;padding:.25rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary)}.tool-color{width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:6px;background:none;cursor:pointer}.pricing-grid{display:flex;justify-content:center;gap:2rem;align-items:stretch}@media(max-width:850px){.pricing-grid{flex-direction:column;align-items:center}}.pricing-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;display:flex;flex-direction:column;text-align:left;transition:transform var(--transition),box-shadow var(--transition);position:relative;flex:0 1 33%;max-width:400px}.pricing-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}.pricing-card--featured{border:2px solid var(--primary);box-shadow:0 10px 30px #9061ff26;transform:scale(1.05);z-index:10}.pricing-card--featured:hover{transform:scale(1.05) translateY(-5px)}.pricing-card__badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--gradient-main);color:#fff;padding:.25rem 1rem;border-radius:99px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.pricing-card__title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.pricing-card__desc{color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem;min-height:40px}.pricing-card__price{margin-bottom:2rem;display:flex;align-items:flex-start}.pricing-card__price .currency{font-size:1.5rem;font-weight:600;margin-top:.25rem}.pricing-card__price .amount{font-size:3rem;font-weight:800;line-height:1;font-family:var(--font-heading);letter-spacing:-1px}.pricing-card__price .period{color:var(--text-muted);font-size:1rem;margin-top:auto;margin-bottom:.5rem;margin-left:.25rem}.pricing-card__features{list-style:none;padding:0;margin:0 0 2.5rem;flex-grow:1}.pricing-card__features li{padding:.5rem 0;color:var(--text-base);font-size:.95rem;border-bottom:1px solid var(--border-light)}.pricing-card__features li:last-child{border-bottom:none}
