*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.block{display:block}.flex{display:flex}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--color-primary-pink: #FF6B9D;--color-secondary-pink: #FFA5C3;--color-light-pink: #FFE5EE;--color-cream: #FFF9FB;--color-purple: #B4A7D6;--color-peach: #FFCBA4;--color-mint: #A8E6CF;--color-sky: #87CEEB;--color-gold: #FFD700;--color-orange: #FF8C42}*{margin:0;padding:0;box-sizing:border-box}body{background:linear-gradient(135deg,#fff0f5,#ffe5ee,#fff9fb);min-height:100vh;font-family:Fredoka,"Noto Serif SC",sans-serif;overflow-x:hidden}.intro-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#ff6b9d,#ffa5c3,#b4a7d6);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;cursor:pointer;transition:opacity .5s ease,transform .5s ease}.send-blessing-guide{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9998;background:linear-gradient(135deg,#ff6b9d,#ff8e53);color:#fff;border:none;padding:14px 32px;border-radius:50px;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 32px #ff6b9d66,0 4px 12px #ff6b9d4d,inset 0 2px 4px #ffffff4d;transition:all .3s ease;animation:pulse-glow 2s ease-in-out infinite;font-family:Fredoka,"Noto Serif SC",sans-serif}.send-blessing-guide:hover{transform:translate(-50%) translateY(-3px) scale(1.05);box-shadow:0 12px 40px #ff6b9d80,0 6px 16px #ff6b9d66,inset 0 2px 4px #ffffff4d}.send-blessing-guide:active{transform:translate(-50%) translateY(-1px) scale(1.02)}@keyframes pulse-glow{0%,to{box-shadow:0 8px 32px #ff6b9d66,0 4px 12px #ff6b9d4d,inset 0 2px 4px #ffffff4d}50%{box-shadow:0 8px 40px #ff6b9d99,0 4px 16px #ff6b9d80,inset 0 2px 4px #ffffff4d}}.meteor-greeting{pointer-events:none;opacity:0}.meteor-content{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fffffffa,#fffafcfa);padding:14px 20px;border-radius:20px;box-shadow:0 10px 40px #ff6b9d66,0 4px 15px #00000026,inset 0 2px 10px #fffc;border:3px solid rgba(255,107,157,.5);min-width:300px;max-width:400px;transform:rotate(-5deg)}.meteor-emoji{font-size:2.8rem;flex-shrink:0;animation:emoji-bounce .8s ease infinite alternate}@keyframes emoji-bounce{0%{transform:scale(1) rotate(-10deg)}to{transform:scale(1.1) rotate(10deg)}}.meteor-text{flex:1}.meteor-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.meteor-name{font-weight:700;font-size:1.1rem;color:#ff6b9d}.meteor-location{font-size:.8rem;color:#888}.meteor-message{font-size:.9rem;color:#555;line-height:1.5}@keyframes meteor-fly-top-left{0%{opacity:0;transform:translate(0) rotate(-15deg) scale(.7)}3%{opacity:1;transform:translate(5vw,5vh) rotate(-5deg) scale(1)}92%{opacity:1;transform:translate(65vw,55vh) rotate(-5deg) scale(1)}to{opacity:0;transform:translate(var(--end-x),var(--end-y)) rotate(-5deg) scale(.8)}}@keyframes meteor-fly-top-right{0%{opacity:0;transform:translate(0) rotate(15deg) scale(.7)}3%{opacity:1;transform:translate(-5vw,5vh) rotate(5deg) scale(1)}92%{opacity:1;transform:translate(-65vw,55vh) rotate(5deg) scale(1)}to{opacity:0;transform:translate(calc(var(--end-x) - 100vw),var(--end-y)) rotate(5deg) scale(.8)}}@keyframes meteor-fly-left{0%{opacity:0;transform:translate(0) rotate(-8deg) scale(.7)}3%{opacity:1;transform:translate(3vw) rotate(-3deg) scale(1)}92%{opacity:1;transform:translate(70vw,2vh) rotate(-3deg) scale(1)}to{opacity:0;transform:translate(var(--end-x),var(--end-y)) rotate(-3deg) scale(.8)}}@keyframes meteor-fly-right{0%{opacity:0;transform:translate(0) rotate(8deg) scale(.7)}3%{opacity:1;transform:translate(-3vw) rotate(3deg) scale(1)}92%{opacity:1;transform:translate(-70vw,2vh) rotate(3deg) scale(1)}to{opacity:0;transform:translate(-100vw,var(--end-y)) rotate(3deg) scale(.8)}}.meteor-content:before{content:"";position:absolute;top:50%;left:-30px;width:30px;height:2px;background:linear-gradient(to left,rgba(255,107,157,.6),transparent);transform:translateY(-50%)}.intro-screen.hidden{opacity:0;transform:scale(1.2);pointer-events:none}.intro-text{color:#fff;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:600;text-align:center;animation:pulse-glow 2s ease-in-out infinite;text-shadow:0 0 20px rgba(255,255,255,.8)}@keyframes pulse-glow{0%,to{transform:scale(1);text-shadow:0 0 20px rgba(255,255,255,.8)}50%{transform:scale(1.05);text-shadow:0 0 40px rgba(255,255,255,1)}}.intro-cake{font-size:120px;animation:bounce-cake 1s ease-in-out infinite;cursor:pointer;transition:transform .2s}.intro-cake:hover{transform:scale(1.2)}@keyframes bounce-cake{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-20px) rotate(5deg)}}.intro-hint{color:#fff;font-size:1.2rem;margin-top:2rem;animation:fade-in-out 2s ease-in-out infinite}.intro-music-hint{color:#ffffffb3;font-size:.9rem;margin-top:1rem;animation:fade-in-out 2s ease-in-out infinite .5s}@keyframes fade-in-out{0%,to{opacity:.5}50%{opacity:1}}.music-control{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-pink),var(--color-secondary-pink));border:none;font-size:1.5rem;cursor:pointer;z-index:9999;box-shadow:0 4px 15px #ff6b9d66,inset 0 2px 5px #ffffff4d;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.music-control:hover{transform:scale(1.1);box-shadow:0 6px 20px #ff6b9d80,inset 0 2px 5px #fff6}.music-control:active{transform:scale(.95)}.birthday-container{position:relative;min-height:100vh;padding:0;z-index:1;opacity:0;transition:opacity .8s ease}.birthday-container.visible{opacity:1}.main-content{max-width:1200px;margin:0 auto;padding:1rem}.particles-bg{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;animation:particle-float 8s ease-in-out infinite}@keyframes particle-float{0%,to{transform:translateY(0) rotate(0);opacity:.3}50%{transform:translateY(-30px) rotate(180deg);opacity:.6}}.falling-gifts{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:80;overflow:hidden}.falling-gift{position:absolute;top:-50px;font-size:2.5rem;animation:fall-down 5s linear forwards;pointer-events:auto;cursor:pointer;transition:transform .2s;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.falling-gift:hover{transform:scale(1.3) rotate(10deg)}.falling-gift.caught{animation:gift-caught .3s ease-out forwards}@keyframes fall-down{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(calc(100vh + 50px)) rotate(360deg);opacity:.8}}@keyframes gift-caught{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5)}to{transform:scale(0);opacity:0}}.achievement-toast{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.achievement-item{background:linear-gradient(135deg,#fffffffa,#fffafcfa);border-radius:16px;padding:16px 20px;min-width:250px;max-width:320px;box-shadow:0 10px 40px #ff6b9d4d,0 2px 10px #0000001a;border:2px solid rgba(255,182,193,.5);transform:translate(120%);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.achievement-item.show{transform:translate(0);opacity:1}.achievement-title{font-weight:700;font-size:1.1rem;color:var(--color-primary-pink);margin-bottom:4px}.achievement-message{font-size:.9rem;color:#666}.heart-rain,.money-rain{position:fixed;top:-30px;font-size:2rem;animation:rain-fall 3s linear forwards;pointer-events:none;z-index:9999}@keyframes rain-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:0}}.star-burst{position:fixed;font-size:1.5rem;animation:star-explode 1.5s ease-out forwards;pointer-events:none;z-index:9999}@keyframes star-explode{0%{transform:translate(-50%,-50%) rotate(0) scale(0);opacity:1}to{transform:translate(calc(-50% + cos(var(--angle)) * var(--distance)),calc(-50% + sin(var(--angle)) * var(--distance))) rotate(360deg) scale(1);opacity:0}}.floating-blessings{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50;overflow:hidden}.floating-blessing-card{position:absolute;pointer-events:auto;animation:float-1 var(--duration, 20s) ease-in-out infinite;animation-delay:var(--delay, 0s);opacity:.85;transition:opacity .3s ease,transform .3s ease}.floating-blessing-card:hover{opacity:1;z-index:100}.floating-card-inner{background:linear-gradient(135deg,#fffffff2,#fffafcf2);border-radius:16px;padding:12px 14px;min-width:200px;max-width:260px;box-shadow:0 8px 32px #ff6b9d33,0 2px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,182,193,.4)}.floating-card-avatar{position:absolute;top:-8px;left:-8px;width:32px;height:32px;background:linear-gradient(135deg,#ff6b9d,#ffa5c3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 8px #ff6b9d66}.floating-card-content{padding-left:4px}.floating-card-name{font-weight:700;font-size:.95rem;color:#333;margin-bottom:2px}.floating-card-meta{font-size:.7rem;color:#888;margin-bottom:6px}.floating-card-message{font-size:.8rem;color:#555;line-height:1.4;padding-left:8px;border-left:2px solid rgba(255,107,157,.3)}@keyframes float-1{0%,to{transform:translate(0) rotate(-2deg)}25%{transform:translate(var(--float-width, 30px),calc(var(--float-height, 40px) * -.5)) rotate(1deg)}50%{transform:translate(calc(var(--float-width, 30px) * -.5),calc(var(--float-height, 40px) * -1)) rotate(-1deg)}75%{transform:translate(calc(var(--float-width, 30px) * -1),calc(var(--float-height, 40px) * -.3)) rotate(2deg)}}@keyframes float-2{0%,to{transform:translate(0) rotate(1deg)}25%{transform:translate(calc(var(--float-width, 30px) * -1),calc(var(--float-height, 40px) * .5)) rotate(-2deg)}50%{transform:translate(calc(var(--float-width, 30px) * .5),calc(var(--float-height, 40px) * -.8)) rotate(2deg)}75%{transform:translate(var(--float-width, 30px),calc(var(--float-height, 40px) * .3)) rotate(-1deg)}}@keyframes float-3{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(calc(var(--float-width, 30px) * .8),calc(var(--float-height, 40px) * -.6)) rotate(2deg)}66%{transform:translate(calc(var(--float-width, 30px) * -.6),calc(var(--float-height, 40px) * -1)) rotate(-2deg)}}@keyframes float-4{0%,to{transform:translate(0) rotate(-1deg)}25%{transform:translate(calc(var(--float-width, 30px) * -.7),calc(var(--float-height, 40px) * -.4)) rotate(1deg)}50%{transform:translate(var(--float-width, 30px),calc(var(--float-height, 40px) * -.8)) rotate(-2deg)}75%{transform:translate(calc(var(--float-width, 30px) * .5),calc(var(--float-height, 40px) * -.2)) rotate(2deg)}}.blessing-banner{background:linear-gradient(135deg,#ff6b9deb,#ffa5c3eb,#b4a7d6eb 70%,#ffc8a4eb);padding:12px 0;position:relative;overflow:hidden;box-shadow:0 4px 20px #ff6b9d66,inset 0 1px #ffffff4d}.blessing-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}.blessing-rows{display:flex;flex-direction:column;gap:10px}.blessing-track{display:flex;gap:20px;animation:scroll-left 40s linear infinite}.blessing-track.reverse{animation:scroll-right 50s linear infinite}.blessing-track:nth-child(3){animation:scroll-left 60s linear infinite}.blessing-track:hover{animation-play-state:paused}@keyframes scroll-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scroll-right{0%{transform:translate(-50%)}to{transform:translate(0)}}.blessing-card{flex-shrink:0;display:flex;flex-direction:column;min-width:280px;max-width:320px;padding:12px 16px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 15px #0000001a,0 1px 3px #00000014;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:default}.blessing-card:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 25px #ff6b9d33,0 2px 6px #0000001a}.blessing-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.blessing-card-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffe5ee,#fff0f5);border-radius:50%;font-size:1.2rem}.blessing-card-user{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.blessing-card-name{font-weight:700;font-size:.95rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blessing-card-location{font-size:.75rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blessing-card-message{font-size:.85rem;color:#555;line-height:1.5;padding-left:4px;border-left:2px solid rgba(255,107,157,.3);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blessing-item{display:inline-flex;align-items:center;padding:6px 30px;background:#ffffff26;border-radius:20px;margin:0 15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease}.blessing-item:hover{background:#ffffff40;transform:scale(1.05)}.blessing-location{font-weight:700;color:gold;font-size:1rem;margin-right:6px;text-shadow:0 1px 3px rgba(0,0,0,.3)}.blessing-text{color:#ffffffe6;font-size:.95rem;margin:0 4px}.blessing-name{font-weight:700;color:#fff;font-size:1.05rem;margin:0 4px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.blessing-device{font-weight:600;color:#ffe5ee;font-size:.95rem;margin:0 4px;background:#fff3;padding:2px 8px;border-radius:10px}.blessing-item:after{content:"💖";margin-left:10px;font-size:1rem;animation:heart-beat 1s ease-in-out infinite}@keyframes heart-beat{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.hero-section{text-align:center;padding:3rem 1rem 2rem;position:relative}.name-title{font-family:Fredoka,sans-serif;font-size:clamp(4rem,12vw,8rem);font-weight:700;background:linear-gradient(135deg,var(--color-primary-pink),var(--color-purple),var(--color-orange),var(--color-gold),var(--color-primary-pink));background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;animation:gradient-text 4s ease infinite,float-name 3s ease-in-out infinite;text-shadow:none;position:relative}@keyframes gradient-text{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes float-name{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-15px) rotate(2deg)}}.subtitle{font-size:clamp(1.8rem,5vw,3rem);color:var(--color-primary-pink);font-weight:600;margin-bottom:1.5rem;animation:bounce-in .8s ease-out}@keyframes bounce-in{0%{transform:scale(0) rotate(-10deg);opacity:0}50%{transform:scale(1.2) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.age-badge{display:inline-block;font-family:Fredoka,sans-serif;font-size:clamp(2.5rem,6vw,4rem);font-weight:700;background:linear-gradient(135deg,var(--color-light-pink),white,var(--color-light-pink));padding:1rem 2.5rem;border-radius:50px;border:4px solid var(--color-primary-pink);box-shadow:0 8px 25px #ff6b9d4d,inset 0 2px 10px #fffc;color:var(--color-primary-pink);position:relative;animation:wiggle 2s ease-in-out infinite;cursor:pointer;transition:transform .2s}.age-badge:hover{transform:scale(1.1) rotate(-5deg)}.age-badge:before{content:"🎉";position:absolute;left:-20px;top:50%;transform:translateY(-50%);font-size:2rem;animation:swing 1s ease-in-out infinite}.age-badge:after{content:"🎊";position:absolute;right:-20px;top:50%;transform:translateY(-50%);font-size:2rem;animation:swing 1s ease-in-out infinite reverse}@keyframes wiggle{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes swing{0%,to{transform:translateY(-50%) rotate(-15deg)}50%{transform:translateY(-50%) rotate(15deg)}}.candles-game{text-align:center;margin:2rem 0;padding:2rem;background:linear-gradient(135deg,#ffffffe6,#fff5f8e6);border-radius:30px;border:4px solid rgba(255,107,157,.3);box-shadow:0 10px 30px #ff6b9d33}.candles-title{font-size:1.5rem;color:var(--color-primary-pink);margin-bottom:1.5rem;font-weight:600}.candles-container{display:flex;justify-content:center;gap:15px;flex-wrap:wrap;margin:2rem 0}.candle{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s}.candle:hover{transform:scale(1.1)}.candle-flame{font-size:2.5rem;animation:flicker .3s ease-in-out infinite alternate;filter:drop-shadow(0 0 10px #FFD700) drop-shadow(0 0 20px #FFA500)}.candle-flame.blown{animation:blow-out .5s ease-out forwards}@keyframes flicker{0%{transform:scale(1) rotate(-5deg)}to{transform:scale(1.1) rotate(5deg)}}@keyframes blow-out{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5) translateY(-10px)}to{opacity:0;transform:scale(0) translateY(-20px)}}.candle-body{width:20px;height:50px;background:linear-gradient(to right,#ffb6c1,pink,#ffb6c1);border-radius:3px 3px 8px 8px;box-shadow:inset -3px 0 5px #0000001a}.candle-base{width:30px;height:8px;background:linear-gradient(to bottom,gold,orange);border-radius:0 0 5px 5px}.candles-hint{font-size:1rem;color:#888;margin-top:1rem;animation:fade-in-out 2s ease-in-out infinite}.candles-complete{font-size:1.5rem;color:var(--color-gold);font-weight:700;animation:bounce-in .5s ease-out}.gifts-section{margin:3rem 0;text-align:center}.gifts-title{font-size:2rem;color:var(--color-primary-pink);margin-bottom:2rem;font-weight:700}.gifts-container{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.gift-box{width:120px;height:120px;position:relative;cursor:pointer;transition:transform .3s}.gift-box:hover{transform:scale(1.1) rotate(-5deg)}.gift-box.opened{animation:shake-open .5s ease-out}@keyframes shake-open{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.gift-emoji{font-size:80px;animation:bounce-gift 1s ease-in-out infinite}@keyframes bounce-gift{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.gift-surprise{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:60px;animation:pop-in .5s ease-out}@keyframes pop-in{0%{transform:translate(-50%,-50%) scale(0)}50%{transform:translate(-50%,-50%) scale(1.3)}to{transform:translate(-50%,-50%) scale(1)}}.gift-message{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);background:#fff;padding:8px 16px;border-radius:15px;font-size:.9rem;color:var(--color-primary-pink);white-space:nowrap;box-shadow:0 4px 15px #ff6b9d4d;animation:fade-in .5s ease-out}.floating-balloons{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100;overflow:hidden}.balloon{position:absolute;font-size:50px;cursor:pointer;pointer-events:auto;animation:float-balloon 8s ease-in-out infinite;transition:transform .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.balloon:hover{transform:scale(1.2)}.balloon.popped{animation:pop-balloon .3s ease-out forwards;pointer-events:none}@keyframes float-balloon{0%,to{transform:translateY(0) rotate(-10deg)}25%{transform:translateY(-30px) rotate(10deg)}50%{transform:translateY(-10px) rotate(-5deg)}75%{transform:translateY(-40px) rotate(5deg)}}@keyframes pop-balloon{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}to{transform:scale(0);opacity:0}}.poem-section{background:linear-gradient(135deg,#fffffff2,#fffafcf2);border-radius:30px;padding:2.5rem;margin:3rem 0;border:4px solid rgba(180,167,214,.3);box-shadow:0 15px 40px #b4a7d633,inset 0 2px 10px #fffc;position:relative;overflow:hidden}.poem-section:before{content:"📜";position:absolute;top:-30px;right:-20px;font-size:120px;opacity:.08;transform:rotate(15deg)}.poem-title{text-align:center;font-size:2rem;font-weight:700;color:var(--color-purple);margin-bottom:.5rem}.poem-subtitle{text-align:center;font-size:1rem;color:#888;margin-bottom:2rem}.poem-controls{max-width:500px;margin:0 auto}.poem-style-selector{margin-bottom:1.5rem}.style-buttons{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.8rem}.style-btn{padding:10px 18px;border-radius:20px;border:3px solid rgba(180,167,214,.3);background:#fffc;color:#666;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Nunito,sans-serif}.style-btn:hover{border-color:var(--color-purple);background:#b4a7d61a;transform:translateY(-2px)}.style-btn.active{background:linear-gradient(135deg,var(--color-purple),#9B8FC7);border-color:var(--color-purple);color:#fff;box-shadow:0 4px 15px #b4a7d666}.poem-type-selector{margin-bottom:1.5rem}.acrostic-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;padding:1rem 1.2rem;background:#fff5f8cc;border-radius:15px;border:2px solid rgba(255,182,193,.3);transition:all .3s ease}.acrostic-toggle:hover{border-color:var(--color-primary-pink);background:#fff5f8}.acrostic-toggle input[type=checkbox]{width:22px;height:22px;accent-color:var(--color-primary-pink);cursor:pointer}.toggle-text{font-size:1rem;color:#555;font-weight:500}.poem-generate-btn{width:100%;background:linear-gradient(135deg,var(--color-purple),#9B8FC7)!important;border-radius:20px!important;padding:16px 40px!important;font-size:1.2rem!important}.poem-generate-btn:hover:not(:disabled){box-shadow:0 12px 30px #b4a7d680,inset 0 2px 10px #fff6!important}.poem-result{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,#fffafcf2,#fff5f8f2);border-radius:20px;border:3px solid rgba(255,182,193,.4);box-shadow:0 10px 30px #ff6b9d26,inset 0 2px 8px #fffc;animation:poem-fade-in .5s ease-out}@keyframes poem-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.poem-content{font-size:1.2rem;line-height:2;color:#444;text-align:center;padding:1rem 0;font-style:italic}.poem-line{margin:.5rem 0;transition:transform .3s ease}.poem-line:hover{transform:scale(1.02)}.acrostic-line{display:flex;justify-content:center;align-items:baseline;gap:4px}.acrostic-line .first-char{font-size:1.5rem;font-weight:700;color:var(--color-primary-pink);text-shadow:0 0 10px rgba(255,107,157,.3);min-width:2rem;display:inline-block}.acrostic-line .rest-text{font-size:1.2rem;color:#555}.poem-actions{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:2px dashed rgba(255,182,193,.3)}.poem-action-btn{padding:10px 20px;border-radius:15px;border:2px solid rgba(180,167,214,.4);background:#ffffffe6;color:#666;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Nunito,sans-serif}.poem-action-btn:hover{border-color:var(--color-purple);background:#b4a7d61a;transform:translateY(-2px)}.message-board{margin:4rem 0}.message-form{background:linear-gradient(135deg,#fffffff2,#fff5f8f2);border-radius:30px;padding:2.5rem;border:4px solid rgba(255,107,157,.3);box-shadow:0 15px 40px #ff6b9d33,inset 0 2px 10px #fffc;margin-bottom:2rem;position:relative;overflow:hidden}.message-form:before{content:"💌";position:absolute;top:-20px;right:-20px;font-size:100px;opacity:.1;transform:rotate(15deg)}.form-title{text-align:center;font-size:1.8rem;color:var(--color-primary-pink);margin-bottom:2rem;font-weight:700}.clay-input{width:100%;background:#fffc;border-radius:20px;padding:15px 20px;border:3px solid rgba(255,182,193,.4);font-family:Nunito,sans-serif;font-size:1.1rem;color:#444;transition:all .3s ease;box-shadow:inset 3px 3px 6px #ff6b9d1a,inset -3px -3px 6px #ffffffe6}.clay-input:focus{outline:none;border-color:var(--color-primary-pink);box-shadow:inset 3px 3px 6px #ff6b9d26,inset -3px -3px 6px #fffffff2,0 0 0 4px #ff6b9d26}.clay-button{width:100%;background:linear-gradient(135deg,var(--color-primary-pink),var(--color-secondary-pink));border-radius:20px;padding:15px 40px;border:none;box-shadow:0 8px 20px #ff6b9d66,inset 0 2px 10px #ffffff4d;color:#fff;font-weight:700;font-size:1.3rem;cursor:pointer;transition:all .3s ease;font-family:Fredoka,sans-serif}.clay-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 30px #ff6b9d80,inset 0 2px 10px #fff6}.clay-button:active:not(:disabled){transform:translateY(1px)}.clay-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.clay-button.secondary{background:linear-gradient(135deg,#b4a7d6,#9b8fc7);font-size:1.1rem;padding:12px 30px}.clay-button.secondary:hover:not(:disabled){box-shadow:0 12px 30px #b4a7d680,inset 0 2px 10px #fff6}.message-list{display:grid;gap:1.2rem}.message-item{background:linear-gradient(135deg,#fffffff2,#fffafcf2);border-radius:25px;padding:1.5rem 2rem;border:3px solid rgba(255,182,193,.25);box-shadow:0 8px 20px #ff6b9d26,inset 0 2px 8px #ffffffe6;transition:all .3s ease;position:relative;overflow:hidden}.message-item:before{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(to bottom,var(--color-primary-pink),var(--color-purple))}.message-item:hover{transform:translate(10px);box-shadow:0 12px 30px #ff6b9d33,inset 0 2px 8px #fffffff2}.message-author{font-weight:700;color:var(--color-primary-pink);font-size:1.2rem;margin-bottom:.5rem;display:flex;align-items:center;gap:8px}.message-content{color:#555;line-height:1.7;font-size:1.05rem;padding-left:1.5rem;margin-bottom:.8rem}.message-meta{display:flex;flex-wrap:wrap;gap:12px;padding-left:1.5rem;border-top:1px dashed rgba(255,107,157,.2);padding-top:.8rem}.meta-item{display:inline-flex;align-items:center;gap:4px;font-size:.85rem}.meta-icon{font-size:.9rem}.meta-text{color:#888}.meta-item:first-child .meta-text{color:var(--color-purple);font-weight:600}.meta-item:nth-child(2) .meta-text{color:var(--color-primary-pink)}.message-time{font-size:.85rem;color:#999;margin-top:.8rem;text-align:right}.firework{position:fixed;pointer-events:none;z-index:9999}.firework-particle{position:absolute;width:8px;height:8px;border-radius:50%;animation:firework-explode 1s ease-out forwards}@keyframes firework-explode{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}.confetti-piece{position:fixed;pointer-events:none;z-index:1000;animation:confetti-fall 4s linear forwards}@keyframes confetti-fall{0%{transform:translateY(-100px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@media(max-width:768px){body{font-size:16px}.send-blessing-guide{top:12px;padding:12px 24px;font-size:1rem;border-radius:40px}.main-content{padding:.75rem;padding-top:70px}.intro-cake{font-size:80px}.intro-text{font-size:clamp(1.2rem,6vw,1.8rem);padding:0 1rem}.intro-hint{font-size:1rem;padding:0 1rem;text-align:center}.intro-music-hint{font-size:.85rem;padding:0 1rem;text-align:center}.hero-section{padding:1.5rem .5rem!important}.subtitle{font-size:clamp(1.5rem,8vw,2rem);margin-bottom:1rem}.age-badge{font-size:clamp(1.8rem,8vw,2.5rem);padding:.8rem 1.5rem;border-width:3px}.age-badge:before,.age-badge:after{font-size:1.5rem;position:static;display:inline-block;transform:none;animation:none}.age-badge:before{content:"🎉 ";margin-right:.3rem}.age-badge:after{content:" 🎊";margin-left:.3rem}.candles-game{padding:1.5rem 1rem;margin:1.5rem 0;border-radius:20px;border-width:3px}.candles-title{font-size:clamp(1.1rem,5vw,1.3rem);margin-bottom:1rem}.candles-container{gap:12px;margin:1.5rem 0}.candle{min-width:44px;min-height:44px;padding:5px}.candle-flame{font-size:2rem}.candle-body{width:12px;height:35px}.candle-base{width:22px;height:6px}.candles-hint{font-size:.9rem}.gifts-section{margin:2rem 0;padding:0 .5rem}.gifts-title{font-size:clamp(1.3rem,6vw,1.6rem);margin-bottom:1.5rem}.gifts-container{gap:1rem}.gift-box{width:80px;height:80px;min-width:60px;min-height:60px}.gift-emoji{font-size:50px}.gift-surprise{font-size:40px}.gift-message{font-size:.8rem;padding:6px 12px;bottom:-35px;white-space:normal;max-width:120px;text-align:center}.balloon{font-size:40px;min-width:44px;min-height:44px}.poem-section{padding:1.5rem 1rem;margin:2rem 0;border-radius:20px;border-width:3px}.poem-section:before{font-size:80px;top:-20px;right:-30px}.poem-title{font-size:clamp(1.3rem,6vw,1.6rem);margin-bottom:.3rem}.poem-subtitle{font-size:.9rem;margin-bottom:1.5rem}.style-buttons{gap:.6rem;justify-content:center}.style-btn{padding:10px 14px;font-size:.9rem;border-width:2px;min-height:44px}.acrostic-toggle{padding:.8rem 1rem;gap:10px}.acrostic-toggle input[type=checkbox]{width:20px;height:20px}.toggle-text{font-size:.9rem}.poem-generate-btn{padding:14px 30px!important;font-size:1rem!important;min-height:50px}.poem-result{padding:1.5rem 1rem;margin-top:1.5rem;border-radius:15px;border-width:2px}.poem-content{font-size:1rem;line-height:1.8}.poem-line{margin:.3rem 0}.acrostic-line .first-char{font-size:1.2rem;min-width:1.5rem}.acrostic-line .rest-text{font-size:1rem}.poem-actions{flex-wrap:wrap;gap:.8rem}.poem-action-btn{padding:10px 16px;font-size:.85rem;min-height:44px;flex:1;min-width:100px}.message-board{margin:2.5rem 0}.message-form{padding:1.5rem 1rem;border-radius:20px;border-width:3px;margin-bottom:1.5rem}.message-form:before{font-size:60px;top:-10px;right:-20px}.form-title{font-size:clamp(1.3rem,6vw,1.5rem);margin-bottom:1.5rem}.clay-input{padding:12px 16px;font-size:16px;border-radius:15px;border-width:2px;min-height:48px}.form-row{margin-bottom:1rem}.form-label{font-size:.95rem;margin-bottom:.5rem}.message-textarea{min-height:120px;font-size:16px;padding:12px 16px}.char-count{font-size:.8rem}.ai-generate-section{margin:1rem 0}.ai-generate-btn{width:100%;padding:12px 20px!important;font-size:.95rem!important;min-height:48px}.submit-btn{width:100%;padding:14px 24px!important;font-size:1.1rem!important;min-height:50px}.wishes-title{font-size:clamp(1.3rem,6vw,1.5rem);margin-bottom:1rem}.wishes-list{gap:.8rem}.message-item{padding:1rem;border-radius:15px;border-width:2px}.message-author{font-size:1rem;margin-bottom:.5rem}.message-content{font-size:.95rem;line-height:1.5}.message-meta{flex-wrap:wrap;gap:.5rem;margin-top:.8rem;font-size:.75rem}.meta-item{font-size:.75rem}.meta-icon{font-size:.85rem}.floating-blessing-card{opacity:.75!important}.floating-blessing-card:active{opacity:1!important}.floating-card-inner{min-width:150px!important;max-width:180px!important;padding:8px 10px!important;border-radius:12px!important}.floating-card-avatar{width:24px!important;height:24px!important;font-size:.8rem!important;top:-6px!important;left:-6px!important}.floating-card-name{font-size:.8rem!important}.floating-card-meta{font-size:.6rem!important}.floating-card-message{font-size:.7rem!important;line-height:1.3!important}.achievement-toast{top:10px;right:10px;left:10px}.achievement-item{min-width:auto;max-width:none;padding:12px 16px;border-radius:12px}.achievement-title{font-size:1rem}.achievement-message{font-size:.85rem}.music-control{width:48px;height:48px;bottom:15px;right:15px;font-size:1.3rem}.firework{transform:scale(.8)}.falling-gift{font-size:2rem;pointer-events:auto;min-width:44px;min-height:44px}.music-tip{font-size:.9rem;padding:10px 20px;bottom:70px;left:50%;transform:translate(-50%);white-space:nowrap}.meteor-content{min-width:200px!important;max-width:min(260px,85vw)!important;padding:8px 12px!important;border-radius:14px!important;gap:8px!important}.meteor-emoji{font-size:1.5rem!important}.meteor-name{font-size:.85rem!important;max-width:80px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.meteor-location{font-size:.65rem!important}.meteor-message{font-size:.75rem!important;line-height:1.4!important;max-height:2.8em!important;overflow:hidden!important;display:-webkit-box!important;-webkit-line-clamp:2!important;-webkit-box-orient:vertical!important}}@media(max-width:375px){.main-content{padding:.5rem;padding-top:65px}.meteor-content{min-width:180px!important;max-width:min(240px,90vw)!important;padding:6px 10px!important}.meteor-emoji{font-size:1.3rem!important}.meteor-name{font-size:.8rem!important}.meteor-location{font-size:.6rem!important}.meteor-message{font-size:.7rem!important}.intro-cake{font-size:60px}.subtitle{font-size:1.3rem}.age-badge{font-size:1.5rem;padding:.6rem 1rem}.candles-game,.message-form,.poem-section{padding:1rem .8rem;border-radius:15px}.gift-box{width:65px;height:65px}.gift-emoji{font-size:40px}.style-btn{padding:8px 12px;font-size:.85rem}.candle-flame{font-size:1.6rem}.candle-body{width:10px;height:28px}}@media(max-width:768px)and (orientation:landscape){.intro-screen{flex-direction:row;gap:2rem}.intro-cake{font-size:60px}.candles-container{flex-wrap:nowrap}.gifts-container{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:10px}}@media(hover:none)and (pointer:coarse){.candle,.gift-box,.balloon,.falling-gift,.style-btn,.poem-action-btn,.submit-btn,.ai-generate-btn,.poem-generate-btn{min-width:44px;min-height:44px}.gift-box:hover,.candle:hover,.balloon:hover{transform:none}.gift-box:active{transform:scale(1.1) rotate(-5deg)}.candle:active{transform:scale(1.1)}.balloon:active{transform:scale(1.2)}}@media(min-width:414px)and (max-width:768px){.gift-box{width:90px;height:90px}.gift-emoji{font-size:55px}.candle-flame{font-size:2.2rem}}.fade-in{animation:fade-in .6s ease-out forwards}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOutDown{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(20px)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
