*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;font-family:Fredoka One,cursive;background:linear-gradient(160deg,#ff69b4,#e8b4e8)}#root{height:100%;display:flex;align-items:center;justify-content:center}.app-container{width:100%;height:100%;position:relative;overflow:hidden}@media(min-width:600px){body{overflow:hidden}.app-container{width:430px;height:min(932px,100vh);border-radius:32px;box-shadow:0 24px 80px #96005059}}.home{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,#ff69b4,#e8b4e8);gap:24px;position:relative;overflow:hidden}.home__sparkles{position:absolute;inset:0;pointer-events:none}.home__sparkles span{position:absolute;font-size:1.5rem}.home__sparkles span:nth-child(1){top:10%;left:15%}.home__sparkles span:nth-child(2){top:20%;right:20%}.home__sparkles span:nth-child(3){top:40%;left:8%}.home__sparkles span:nth-child(4){bottom:30%;right:12%}.home__sparkles span:nth-child(5){bottom:15%;left:25%}.home__sparkles span:nth-child(6){bottom:20%;right:30%}.home__title{font-family:Fredoka One,cursive;font-size:clamp(1.6rem,5vw,2.8rem);color:#fff;text-shadow:0 4px 12px rgba(255,105,180,.4);text-align:center;padding:0 24px;position:relative;z-index:1;line-height:1.2}.home__btn{font-family:Fredoka One,cursive;font-size:1.4rem;color:#ff69b4;background:#fff;border:none;border-radius:999px;padding:16px 36px;cursor:pointer;box-shadow:0 4px 24px #ff69b44d;position:relative;z-index:1;transition:transform .15s ease}.home__btn:active{transform:scale(.97)}.home__tagline{font-family:Fredoka One,cursive;color:#ffffffd9;font-size:1rem;position:relative;z-index:1}.home__input{display:none}.bubble{position:absolute;min-width:120px;max-width:200px;background:#fff;border:3px solid #FF69B4;border-radius:20px;padding:12px 14px 20px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.bubble--selected{box-shadow:0 0 0 3px #ff69b466}.bubble--speech:after{content:"";position:absolute;bottom:-16px;left:20px;width:0;height:0;border-left:10px solid transparent;border-right:6px solid transparent;border-top:16px solid #FF69B4}.bubble--speech:before{content:"";position:absolute;bottom:-12px;left:22px;width:0;height:0;border-left:8px solid transparent;border-right:4px solid transparent;border-top:13px solid white;z-index:1}.bubble--think:after{content:"";position:absolute;bottom:-12px;left:18px;width:8px;height:8px;background:#fff;border:2px solid #FF69B4;border-radius:50%;box-shadow:14px 7px 0 -1px #fff,14px 7px 0 1px #ff69b4,24px 13px 0 -2px #fff,24px 13px #ff69b4}.bubble__close{position:absolute;top:-10px;right:-10px;width:22px;height:22px;border-radius:50%;background:#ff69b4;color:#fff;border:none;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;line-height:1}.bubble__flip{position:absolute;top:-10px;left:-10px;width:22px;height:22px;border-radius:50%;background:#ff69b4;color:#fff;border:none;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;line-height:1}.bubble__text{font-family:Fredoka One,cursive;font-size:1rem;color:#333;background:transparent;border:none;outline:none;resize:none;width:100%;min-height:1.5em}.bubble__text::placeholder{color:#ff69b480}.bubble--speech.bubble--right:after{left:auto;right:20px;border-left:6px solid transparent;border-right:10px solid transparent;border-top:16px solid #FF69B4}.bubble--speech.bubble--right:before{left:auto;right:22px;border-left:4px solid transparent;border-right:8px solid transparent;border-top:13px solid white}.bubble--think.bubble--right:after{left:auto;right:18px;box-shadow:-14px 7px 0 -1px #fff,-14px 7px 0 1px #ff69b4,-24px 13px 0 -2px #fff,-24px 13px #ff69b4}.toolbar{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:10px 16px;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:999px;box-shadow:0 4px 20px #0000001f;z-index:10}.toolbar__btn{font-family:Fredoka One,cursive;font-size:.9rem;background:#fff;color:#ff69b4;border:2px solid #FF69B4;border-radius:999px;padding:8px 16px;cursor:pointer;white-space:nowrap}.toolbar__btn--disabled{opacity:.4;cursor:default}.editor{height:100%;width:100%;position:relative;background:#000}.editor__canvas{position:relative;height:100%;width:100%;overflow:hidden}.editor__photo{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.editor__actions{position:absolute;top:16px;right:16px;z-index:20;display:flex;gap:8px}.editor__action-btn{font-family:Fredoka One,cursive;font-size:.85rem;background:#ffffffbf;color:#ff69b4;border:2px solid rgba(255,105,180,.5);border-radius:999px;padding:8px 16px;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.editor__error{position:absolute;bottom:96px;left:50%;transform:translate(-50%);background:#fff;color:#ff69b4;font-family:Fredoka One,cursive;font-size:.9rem;border:2px solid #FF69B4;border-radius:16px;padding:12px 20px;text-align:center;max-width:280px;z-index:30;box-shadow:0 4px 16px #ff69b440;cursor:pointer}.editor__canvas.exporting .bubble__close{display:none!important}.editor__canvas.exporting .bubble--selected{box-shadow:none!important}.editor__canvas.exporting .toolbar{display:none!important}.confirm{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#ff69b4,#e8b4e8);position:relative;overflow:hidden}.confirm__card{background:#fff;border-radius:24px;padding:40px 32px;text-align:center;box-shadow:0 0 0 4px #ff69b44d,0 8px 32px #ff69b433;z-index:1;display:flex;flex-direction:column;gap:24px;align-items:center}.confirm__message{font-family:Fredoka One,cursive;font-size:2rem;color:#ff69b4}.confirm__btn{font-family:Fredoka One,cursive;font-size:1.2rem;color:#fff;background:#ff69b4;border:none;border-radius:999px;padding:14px 32px;cursor:pointer}.confirm__confetti{position:absolute;inset:0;pointer-events:none}.confirm__piece{position:absolute;width:8px;height:8px;border-radius:2px;top:-10px;left:calc(var(--i) * 5.26%);background:hsl(calc(var(--i) * 18),80%,60%);animation:confetti-fall 1.5s ease-out calc(var(--i) * .07s) forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}
