.tribute-root{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;font-family:Peach Plum,cursive;position:fixed;inset:0;overflow:hidden}.lifafa-screen{z-index:100;cursor:pointer;background:0 0;position:fixed;inset:0;overflow:hidden}.lifafa-upper{z-index:102;width:100%;height:87dvh;transition:transform 1s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0;overflow:hidden}.lifafa-upper img{width:280%;max-width:none;height:auto;display:block;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.lifafa-lower{z-index:101;width:100%;height:100dvh;transition:transform 1s cubic-bezier(.4,0,.2,1);position:absolute;bottom:0;left:0;overflow:hidden}.lifafa-lower img{width:180%;max-width:none;height:auto;display:block;position:absolute;top:0;left:50%;transform:translate(-50%)}.lifafa-screen.opening .lifafa-upper,.lifafa-screen.opened .lifafa-upper{transform:translateY(-100vh)}.lifafa-screen.opening .lifafa-lower,.lifafa-screen.opened .lifafa-lower{transform:translateY(100vh)}.lifafa-screen.opened{pointer-events:none;opacity:0;transition:opacity .5s .8s}@media (width<=480px){.lifafa-upper img{width:460%}.lifafa-lower img{width:280%}}@media (width<=380px){.lifafa-upper img{width:520%}.lifafa-lower img{width:320%}}@media (aspect-ratio<=1/2){.lifafa-upper{height:90dvh}}.paper-bg{z-index:1;background:#e8e4de;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.paper-bg img{object-fit:cover;width:110%;height:110%;transform:scale(1.05)}.tribute-content{z-index:10;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:column;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden auto}.tribute-content::-webkit-scrollbar{display:none}.hfd-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100dvh;padding:40px 24px;display:flex}.hfd-heart{width:80px;height:auto;animation:2s ease-in-out infinite heartBeat}@keyframes heartBeat{0%,to{transform:scale(1)}25%{transform:scale(1.18)}40%{transform:scale(.96)}60%{transform:scale(1.12)}}.hfd-title{color:#1e3a5f;letter-spacing:-.01em;font-family:Peach Plum,cursive;font-size:clamp(4rem,18vw,7rem);font-weight:400;line-height:1.15}.hfd-tap-btn{color:#fff;cursor:pointer;opacity:0;letter-spacing:.02em;background:#1e3a5f;border:none;border-radius:50px;margin-top:60px;padding:18px 48px;font-family:Peach Plum,cursive;font-size:1.6rem;transition:all .25s;animation:.6s ease-out forwards btnFadeInPulse,2s ease-in-out .6s infinite gentlePulseBtn;box-shadow:0 4px 15px #1e3a5f4d}@keyframes btnFadeInPulse{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes gentlePulseBtn{0%,to{transform:scale(1);box-shadow:0 4px 15px #1e3a5f4d}50%{transform:scale(1.05);box-shadow:0 8px 25px #1e3a5f80}}.message-screen{flex-direction:column;justify-content:flex-start;width:100%;max-width:420px;min-height:100dvh;padding:60px 32px 56px;display:flex}.message-dear{color:#1e3a5f;margin-bottom:20px;font-family:Peach Plum,cursive;font-size:clamp(2.5rem,10vw,3.5rem);font-weight:400}.message-body{color:#4a5568;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:anywhere;margin-bottom:28px;font-family:Peach Plum,cursive;font-size:clamp(1.5rem,6vw,2.2rem);line-height:1.6}.typewriter-cursor{vertical-align:text-bottom;background:#1e3a5f;width:2px;height:1.2em;margin-left:2px;animation:.7s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.message-footer{justify-content:space-between;align-items:center;gap:16px;margin-top:auto;padding-top:16px;display:flex}.message-from{color:#1e3a5f;font-family:Peach Plum,cursive;font-size:1.3rem;font-weight:400}.btn-next{color:#fff;cursor:pointer;letter-spacing:.02em;background:#1e3a5f;border:none;border-radius:50px;justify-content:center;align-items:center;padding:18px 48px;font-family:Peach Plum,cursive;font-size:1.6rem;transition:all .25s;display:inline-flex;box-shadow:0 4px 15px #1e3a5f4d}.btn-next:hover{background:#15304f;transform:translateY(-2px)scale(1.02);box-shadow:0 6px 20px #1e3a5f66}.btn-next:active{transform:scale(.97)}.gift-screen{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:420px;height:100dvh;padding:20px 16px;display:flex;overflow:hidden}.gift-title{color:#1e3a5f;text-align:center;margin-bottom:4vh;font-family:Peach Plum,cursive;font-size:clamp(2.4rem,10vw,4rem);font-weight:400}.gift-grid{grid-template-columns:1fr 1fr;place-items:center;gap:3vh 6vw;width:100%;display:grid}.gift-grid.column{flex-direction:column;gap:30px;display:flex}.gift-box-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.gift-box-btn:hover{transform:scale(1.08)}.gift-box-btn:active{transform:scale(.95)}.gift-box-btn img{filter:drop-shadow(0 8px 20px #00000026);width:min(38vw,180px);height:auto;display:block}.gift-box-label{color:#1e3a5f;margin-top:10px;font-family:Inter,sans-serif;font-size:16px;font-weight:600;display:block}.gift-box-btn:first-child img{animation:3s ease-in-out infinite wiggle1}.gift-box-btn:nth-child(2) img{animation:3.2s ease-in-out .4s infinite wiggle2}.gift-box-btn:nth-child(3) img{animation:2.8s ease-in-out .8s infinite wiggle3}@keyframes wiggle1{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes wiggle2{0%,to{transform:rotate(1.5deg)}50%{transform:rotate(-1.5deg)}}@keyframes wiggle3{0%,to{transform:rotate(-1deg)translateY(0)}50%{transform:rotate(1deg)translateY(-4px)}}.memories-screen{flex-direction:column;align-items:center;width:100%;max-width:420px;min-height:100dvh;padding:50px 24px 60px;display:flex}.memories-title{color:#1e3a5f;text-align:center;margin-bottom:40px;font-family:Peach Plum,cursive;font-size:clamp(2.8rem,12vw,4.5rem);font-weight:400}.polaroid-stack{flex-direction:column;align-items:center;gap:48px;width:100%;padding-bottom:20px;display:flex}.polaroid-item{flex-direction:column;align-items:center;width:80%;max-width:300px;display:flex;position:relative}.polaroid-item:first-child{transform:rotate(-1.5deg)}.polaroid-item:nth-child(2){transform:rotate(1.2deg)}.polaroid-item:nth-child(3){transform:rotate(-.8deg)}.polaroid-item:nth-child(4){transform:rotate(1.8deg)}.polaroid-item:nth-child(5){transform:rotate(-1deg)}.polaroid-tape{z-index:5;pointer-events:none;width:90px;height:auto;position:absolute;top:-18px;left:50%;transform:translate(-50%)}.polaroid-item:first-child .polaroid-tape{transform:translate(-50%)rotate(-3deg)}.polaroid-item:nth-child(2) .polaroid-tape{transform:translate(-50%)rotate(5deg)}.polaroid-item:nth-child(3) .polaroid-tape{transform:translate(-50%)rotate(-2deg)}.polaroid-item:nth-child(4) .polaroid-tape{transform:translate(-50%)rotate(4deg)}.polaroid-item:nth-child(5) .polaroid-tape{transform:translate(-50%)rotate(-6deg)}.polaroid-frame{background:#fff;width:100%;padding:12px 12px 48px;box-shadow:0 2px 8px #0000001a,0 8px 25px #00000014}.polaroid-frame img{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.polaroid-caption{color:#1e3a5f;text-align:center;z-index:2;margin-top:-36px;padding:0 8px;font-family:Peach Plum,cursive;font-size:1.1rem;position:relative}.memories-back-container{justify-content:center;width:100%;margin-top:40px;display:flex}.cassette-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;max-width:420px;min-height:100dvh;padding:40px 24px;display:flex}.cassette-title{color:#1e3a5f;font-family:Peach Plum,cursive;font-size:clamp(2.4rem,10vw,4rem);font-weight:400}.cassette-wrapper{margin:10px 0;display:inline-block;position:relative}.float-icon{z-index:2;pointer-events:none;filter:drop-shadow(0 2px 8px #00000026);font-size:1.8rem;position:absolute}.float-1{animation:3s ease-in-out infinite floatAnim1;top:-10px;left:-20px}.float-2{font-size:2.2rem;animation:3.5s ease-in-out .5s infinite floatAnim2;top:35%;right:-30px}.float-3{font-size:1.5rem;animation:2.5s ease-in-out 1s infinite floatAnim1;bottom:10px;left:-35px}.float-4{font-size:1.6rem;animation:4s ease-in-out 1.5s infinite floatAnim2;bottom:-15px;right:-10px}.float-5{font-size:1.4rem;animation:3.2s ease-in-out .2s infinite floatAnim1;top:10%;left:-30px}@keyframes floatAnim1{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(-4px,-6px)rotate(-8deg)}66%{transform:translate(4px,4px)rotate(8deg)}}@keyframes floatAnim2{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(4px,-8px)rotate(10deg)}66%{transform:translate(-4px,5px)rotate(-5deg)}}.cassette-img-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:0;transition:transform .2s;position:relative}.cassette-img-btn:active{transform:scale(.95)}.cassette-img-btn img{filter:drop-shadow(0 8px 24px #0003);width:min(80vw,320px);height:auto;display:block}.cassette-playing{color:#1e3a5f;white-space:nowrap;font-family:Peach Plum,cursive;font-size:1.2rem;animation:.5s forwards fadeIn;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}.cassette-hint{color:#5a6e80;margin-top:8px;font-family:Peach Plum,cursive;font-size:1.4rem}.award-screen{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:420px;min-height:100dvh;padding:44px 24px 110px;display:flex}.award-back-fixed{bottom:18px;left:50%;bottom:calc(18px + env(safe-area-inset-bottom));z-index:30;padding:14px 40px;font-size:1.4rem;position:fixed;transform:translate(-50%);box-shadow:0 6px 20px #1e3a5f73}.award-title{color:#1e3a5f;margin-bottom:12px;font-family:Peach Plum,cursive;font-size:clamp(2.8rem,12vw,4.5rem);font-weight:400}.award-body{color:#5a6e80;max-width:320px;min-height:80px;margin-bottom:24px;font-family:Peach Plum,cursive;font-size:clamp(1.1rem,5vw,1.5rem);line-height:1.5}.award-images{flex-direction:column;align-items:center;gap:16px;width:100%;margin-bottom:32px;display:flex}.award-cert{filter:drop-shadow(0 4px 12px #0000001a);width:min(65vw,260px);height:auto;animation:3s ease-in-out infinite awardFloat}@keyframes awardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.award-row{justify-content:center;align-items:flex-end;gap:20px;display:flex}.award-trophy{filter:drop-shadow(0 4px 12px #0000001a);width:min(28vw,110px);height:auto;animation:3.2s ease-in-out .3s infinite awardFloat}.award-badge{filter:drop-shadow(0 4px 12px #0000001a);width:min(30vw,120px);height:auto;animation:2.8s ease-in-out .6s infinite awardFloat}.screen-enter{animation:.6s forwards screenFadeIn}.screen-exit{animation:.4s forwards screenFadeOut}@keyframes screenFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes screenFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-30px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tribute-loading{z-index:200;background:#e8e4de;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.tribute-loading-dots{gap:8px;display:flex}.tribute-loading-dots span{background:#1e3a5f;border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite dotPulse}.tribute-loading-dots span:nth-child(2){animation-delay:.2s}.tribute-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,to{opacity:.5;transform:scale(.7)}50%{opacity:1;transform:scale(1)}}.tribute-error{z-index:200;text-align:center;background:#e8e4de;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:24px;display:flex;position:fixed;inset:0}.tribute-error h2{color:#1e3a5f;font-family:Peach Plum,cursive;font-size:2rem}.tribute-error p{color:#5a6e80;font-family:Inter,sans-serif;font-size:14px}.cooking-screen{text-align:center;z-index:300;background:linear-gradient(160deg,#fff7ec 0%,#fde7c8 55%,#fcd9a8 100%);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:28px 22px;display:flex;position:fixed;inset:0;overflow:hidden}.cooking-pot{place-items:center;width:120px;height:120px;display:grid;position:relative}.cooking-emoji{filter:drop-shadow(0 6px 10px #c47f1740);font-size:72px;animation:1.8s ease-in-out infinite cookBob}@keyframes cookBob{0%,to{transform:translateY(0)rotate(-3deg)}50%{transform:translateY(-8px)rotate(3deg)}}.cooking-steam{color:#c47f17;opacity:0;font-size:22px;font-weight:700;animation:2.4s ease-in infinite steamRise;position:absolute;top:6px}.cooking-steam.s1{animation-delay:0s;left:34px}.cooking-steam.s2{animation-delay:.7s;left:56px}.cooking-steam.s3{animation-delay:1.4s;left:78px}@keyframes steamRise{0%{opacity:0;transform:translateY(10px)scale(.8)}30%{opacity:.7}to{opacity:0;transform:translateY(-34px)scale(1.2)}}.cooking-title{color:#7a4d0a;z-index:1;font-family:Peach Plum,cursive;font-size:2rem;line-height:1.1;position:relative}.cooking-line{color:#5b4423;z-index:1;max-width:300px;min-height:40px;font-family:Inter,sans-serif;font-size:15px;font-weight:600;animation:.5s cookLineIn;position:relative}@keyframes cookLineIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cooking-dots{z-index:1;gap:8px;display:flex;position:relative}.cooking-dots span{background:#c47f17;border-radius:50%;width:10px;height:10px;animation:1.3s ease-in-out infinite cookDot}.cooking-dots span:nth-child(2){animation-delay:.2s}.cooking-dots span:nth-child(3){animation-delay:.4s}@keyframes cookDot{0%,to{opacity:.4;transform:scale(.6)}50%{opacity:1;transform:scale(1)}}.cooking-note{color:#6b5535;z-index:1;background:#ffffff8c;border-radius:12px;max-width:300px;padding:10px 14px;font-family:Inter,sans-serif;font-size:12.5px;line-height:1.5;position:relative}.cooking-help{color:#fff;z-index:1;background:#25d366;border-radius:999px;align-items:center;gap:8px;margin-top:4px;padding:12px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:700;text-decoration:none;transition:transform .15s;display:inline-flex;position:relative;box-shadow:0 6px 16px #25d36666}.cooking-help:active{transform:scale(.96)}.cooking-floaties{pointer-events:none;z-index:0;position:absolute;inset:0}.cooking-floaties span{opacity:0;font-size:20px;animation:7s ease-in infinite cookFloat;position:absolute;bottom:-30px}.cooking-floaties span:first-child{animation-delay:0s;left:12%}.cooking-floaties span:nth-child(2){animation-delay:1.6s;left:32%}.cooking-floaties span:nth-child(3){animation-delay:3s;left:54%}.cooking-floaties span:nth-child(4){animation-delay:.9s;left:73%}.cooking-floaties span:nth-child(5){animation-delay:4s;left:88%}@keyframes cookFloat{0%{opacity:0;transform:translateY(0)scale(.8)}15%{opacity:.8}85%{opacity:.4}to{opacity:0;transform:translateY(-380px)scale(1.1)}}.gift-sub{color:#5a6e80;text-align:center;margin-top:6px;font-family:Inter,sans-serif;font-size:13px}.gift-grid.two{flex-wrap:wrap;justify-content:center;gap:22px;display:flex}.gift-grid.two .gift-box-btn{flex-direction:column;align-items:center;gap:8px;display:flex}.gift-box-label{color:#c47f17;font-family:Inter,sans-serif;font-size:13px;font-weight:700}.balloons-screen{text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;gap:10px;width:100%;min-height:100%;padding:30px 18px 24px;display:flex;position:relative}.balloons-title{color:#1e3a5f;font-family:Peach Plum,cursive;font-size:2rem;line-height:1.1}.balloons-sub{color:#5a6e80;max-width:280px;font-family:Inter,sans-serif;font-size:13.5px}.balloons-progress-container{flex-direction:column;align-items:center;gap:6px;width:100%;max-width:280px;margin:0 auto 16px;display:flex}.balloons-progress-text{color:#1e3a5f;letter-spacing:.5px;font-family:Inter,sans-serif;font-size:13px;font-weight:600}.balloons-progress-bar{background:#1e3a5f1a;border-radius:99px;width:100%;height:8px;overflow:hidden}.balloons-progress-fill{background:#ef476f;border-radius:99px;height:100%;transition:width .4s cubic-bezier(.34,1.56,.64,1)}.balloons-sky{pointer-events:none;z-index:5;background:0 0;position:fixed;inset:0;overflow:hidden}.floating-balloon-wrapper{pointer-events:auto;animation:6.5s ease-in-out infinite alternate balloonBob;position:absolute}.floating-balloon-wrapper.final-balloon{animation:7.5s ease-in-out infinite alternate finalBalloonBob}.floating-balloon-btn{cursor:pointer;filter:drop-shadow(0 6px 12px #0000002e);background:0 0;border:none;padding:0;transition:transform .2s;animation:4.5s ease-out backwards floatUpEnter;display:block}.floating-balloon-btn:active{transform:scale(.9)}.floating-balloon-emoji{font-size:5.5rem;line-height:1;display:block}.floating-balloon-burst{pointer-events:none;justify-content:center;align-items:center;font-size:5.5rem;animation:.5s cubic-bezier(.18,.89,.32,1.28) forwards burst;display:flex;position:absolute;inset:0}.is-popped .floating-balloon-btn{opacity:0;pointer-events:none}@keyframes floatUpEnter{0%{opacity:0;transform:translateY(100vh)}to{opacity:1;transform:translateY(0)}}@keyframes balloonBob{0%{transform:translateY(0)rotate(-2deg)}to{transform:translateY(-10px)rotate(2deg)}}@keyframes finalBalloonBob{0%{transform:translateY(0)rotate(-3deg)}to{transform:translateY(-14px)rotate(3deg)}}@keyframes burst{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.4)}to{opacity:0;transform:scale(1)}}.final-surprise-wrapper{z-index:10;pointer-events:auto;justify-content:center;display:flex;position:absolute;bottom:10%;left:0;right:0}.final-surprise-btn{color:#fff;cursor:pointer;background:#1e3a5f;border:none;border-radius:50px;padding:14px 28px;font-family:Peach Plum,cursive;font-size:1.3rem;transition:transform .2s,background .2s;animation:2s ease-in-out infinite floatBounce;box-shadow:0 4px 15px #1e3a5f4d}.final-surprise-btn:active{background:#152b47;transform:scale(.95)}@keyframes floatBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.balloon-reveal{-webkit-backdrop-filter:blur(8px);z-index:250;cursor:pointer;background:#ffffff59;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;animation:.25s fadeReveal;display:flex;position:fixed;inset:0}@keyframes fadeReveal{0%{opacity:0}to{opacity:1}}.reveal-polaroid{background:#fff;border-radius:6px;max-width:78vw;padding:12px 12px 18px;animation:.4s cubic-bezier(.18,.89,.32,1.28) popIn;transform:rotate(-2deg);box-shadow:0 10px 30px #00000026}@keyframes popIn{0%{opacity:0;transform:rotate(-2deg)scale(.5)}to{opacity:1;transform:rotate(-2deg)scale(1)}}.reveal-polaroid img{object-fit:cover;border-radius:3px;width:100%;max-height:56vh;display:block}.reveal-caption{color:#2c1e16;text-align:center;margin-top:10px;font-family:Peach Plum,cursive;font-size:1.3rem}.reveal-tap{color:#fffc;font-family:Inter,sans-serif;font-size:12px}.award-certificate{background:linear-gradient(160deg,#fffdf6,#fdf3df);border:2px solid #e3c98a;border-radius:14px;max-width:340px;margin:10px auto;padding:20px 16px 18px;position:relative;box-shadow:0 10px 30px #785a142e}.award-cert-ribbon{color:#fff;letter-spacing:1px;background:#c47f17;border-radius:999px;margin-bottom:8px;padding:5px 14px;font-family:Inter,sans-serif;font-size:11px;font-weight:800;display:inline-block}.award-cert-name{color:#7a4d0a;margin:6px 0 8px;font-family:Peach Plum,cursive;font-size:1.6rem}.award-sign{color:#6b5535;margin-top:12px;font-family:Inter,sans-serif;font-size:13px;line-height:1.6}.award-sign-name{color:#c47f17;font-family:Peach Plum,cursive;font-size:1.3rem}.climax-screen{z-index:500;touch-action:none;overscroll-behavior-y:none;background:#0a0a0a;flex-direction:column;justify-content:flex-start;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.climax-magical-btn-container{z-index:501;position:absolute;top:40%;left:50%;transform:translate(-50%,-50%)}.climax-magical-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,gold,#ff8c00);border:none;border-radius:50px;padding:16px 36px;font-family:Peach Plum,cursive;font-size:2rem;transition:transform .2s;animation:2s infinite alternate pulseGlow;box-shadow:0 0 25px #ffd70099}.climax-magical-btn:active{transform:scale(.9)}@keyframes pulseGlow{0%{transform:scale(1);box-shadow:0 0 20px #ffd70080}to{transform:scale(1.05);box-shadow:0 0 40px #ffd700cc}}.climax-screen.is-pulled .climax-magical-btn-container{opacity:0;transition:opacity .5s}.climax-flash{opacity:0;pointer-events:none;z-index:502;background:#fff;position:absolute;inset:0}.climax-screen.is-pulled .climax-flash{animation:2s ease-out forwards climaxFlashAnim}@keyframes climaxFlashAnim{0%{opacity:0}15%{opacity:1}to{opacity:0}}.climax-photo-reveal{z-index:503;background:#000;justify-content:center;align-items:center;animation:1s cubic-bezier(.18,.89,.32,1.28) forwards photoRevealFadeIn;display:flex;position:absolute;inset:0}@keyframes photoRevealFadeIn{0%{opacity:0;filter:brightness(2);transform:scale(1.1)}to{opacity:1;filter:brightness();transform:scale(1)}}.climax-photo-reveal img{object-fit:cover;width:100%;height:100%}.climax-text-overlay{text-align:center;color:#fff;opacity:0;white-space:nowrap;background:#1e3a5f;border-radius:50px;padding:12px 30px;font-family:Peach Plum,cursive;font-size:clamp(1.5rem,6vw,2.5rem);animation:1.5s 1.2s forwards textOverlayFade;position:absolute;bottom:15%;left:50%;transform:translate(-50%)translateY(20px);box-shadow:0 4px 15px #1e3a5f80}@keyframes textOverlayFade{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.tribute-splash{z-index:400;background:linear-gradient(160deg,#fff7ec 0%,#f3e7d0 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tribute-splash:after{content:"";border:3px solid #c47f1740;border-top-color:#c47f17;border-radius:50%;width:34px;height:34px;animation:.8s linear infinite splitspin}.lifafa-cover{z-index:110;background:linear-gradient(160deg,#fff7ec 0%,#f3e7d0 100%);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.lifafa-cover-spinner{border:3px solid #c47f1740;border-top-color:#c47f17;border-radius:50%;width:34px;height:34px;animation:.8s linear infinite splitspin}@keyframes splitspin{to{transform:rotate(360deg)}}@font-face{font-family:Peach Plum;src:url(/fathers-day/assets/PeachPlum-Dk1IehVP.otf)format("opentype"),url(/fathers-day/assets/PeachPlum-ChDxnNRK.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--bg-page:#0f172a;--card-bg:#fef9f0;--text-main:#2c1e16;--text-muted:#8a7a6d;--accent:#c47f17;--accent-hover:#a66b10;--accent-light:#fdf4e7;--accent-glow:#c47f1740;--border:#d4c5b2;--border-focus:#c47f17;--input-bg:#fff8ee;--skeleton-base:#e8ddd0;--skeleton-shimmer:#f5ede0;--radius:16px;--radius-sm:10px;--font-display:"Peach Plum", cursive;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--shadow-soft:0 4px 20px #2c1e160f;--shadow-btn:0 4px 14px #c47f1759;--transition:.25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-page);color:var(--text-main);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app-shell{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.phone-frame{background:var(--card-bg);border-radius:40px;flex-direction:column;width:100%;max-width:420px;height:820px;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 4px #1e293b,0 25px 80px -15px #0009,0 0 120px #c47f1714}@media (width<=480px){.app-shell{align-items:stretch;padding:0}.phone-frame{max-width:100%;height:100dvh;box-shadow:none;border-radius:0}body{background:var(--card-bg)}}.app-header{background:var(--card-bg);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 8px;display:flex}.back-btn{color:var(--text-muted);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;opacity:0;pointer-events:none;transition:opacity var(--transition);background:0 0;border:none;align-items:center;gap:4px;display:flex}.back-btn.visible{opacity:1;pointer-events:auto}.brand-tag{text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-size:11px;font-weight:700;font-family:var(--font-body)}.progress-bar-track{background:#ece3d5;border-radius:2px;flex-shrink:0;height:3px;margin:0 24px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), #e6a73a);border-radius:2px;height:100%;transition:width .6s cubic-bezier(.16,1,.3,1)}.content-area{flex:1;position:relative;overflow:hidden}.step-view{background:var(--card-bg);-webkit-overflow-scrolling:touch;flex-direction:column;padding:24px 24px 20px;display:none;position:absolute;inset:0;overflow:hidden auto}.step-view::-webkit-scrollbar{display:none}.step-view.active{z-index:2;display:flex}.step-view.animate-enter-up{z-index:3;animation:.55s cubic-bezier(.16,1,.3,1) forwards slideInFromBottom;display:flex!important}.step-view.animate-exit-up{z-index:1;animation:.5s cubic-bezier(.16,1,.3,1) forwards slideOutToTop;display:flex!important}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOutToTop{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100px)}}.skeleton-overlay{background:var(--card-bg);z-index:20;flex-direction:column;gap:16px;padding:24px;display:none;position:absolute;inset:0}.skeleton-overlay.animate-enter-up{z-index:25;animation:.55s cubic-bezier(.16,1,.3,1) forwards slideInFromBottom;display:flex!important}.skeleton-overlay.animate-exit-up{z-index:19;animation:.5s cubic-bezier(.16,1,.3,1) forwards slideOutToTop;display:flex!important}.sk-bar{background:linear-gradient(90deg, var(--skeleton-base) 25%, var(--skeleton-shimmer) 50%, var(--skeleton-base) 75%);border-radius:var(--radius);background-size:200% 100%;width:100%;animation:1.2s linear infinite shimmer}.sk-bar.hero{border-radius:20px;height:100px}.sk-bar.field{height:56px}.sk-bar.small{width:60%;height:36px}.sk-status{background:var(--accent-light);border:2px dashed var(--border);border-radius:var(--radius);height:56px;color:var(--accent);justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.step-heading{font-family:var(--font-display);color:var(--text-main);letter-spacing:-.01em;margin-bottom:8px;font-size:2.4rem;font-weight:400;line-height:1.15}.step-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px;line-height:1.5}.question-label{color:var(--text-main);letter-spacing:.01em;margin-bottom:10px;font-size:13px;font-weight:600;display:block}.field-hint{color:var(--text-muted);background:var(--accent-light);border-radius:var(--radius-sm);margin-top:8px;padding:8px 11px;font-size:11.5px;line-height:1.45}.form-group{margin-bottom:20px}.input-field{border:2px solid var(--border);border-radius:var(--radius);width:100%;font-size:15px;font-family:var(--font-body);color:var(--text-main);background:var(--input-bg);transition:all var(--transition);outline:none;padding:14px 16px}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#fff}.input-field::placeholder{color:#b8a998}.textarea-field{border:2px solid var(--border);border-radius:var(--radius);width:100%;font-size:15px;font-family:var(--font-body);color:var(--text-main);background:var(--input-bg);resize:none;height:140px;transition:all var(--transition);outline:none;padding:14px 16px;line-height:1.6}.textarea-field:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#fff}.textarea-field::placeholder{color:#b8a998}.word-counter{text-align:right;color:var(--text-muted);margin-top:6px;font-size:12px;font-weight:500}.word-counter.over{color:#dc2626;font-weight:600}.chips-container{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.chip{background:var(--input-bg);border:2px solid var(--border);font-size:14px;font-weight:600;font-family:var(--font-body);color:#5c4a3a;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border-radius:50px;padding:12px 20px;transition:all .2s}.chip:active{transform:scale(.96)}.chip.selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.action-container{flex-shrink:0;margin-top:auto;padding-top:16px}.btn-primary{background:linear-gradient(135deg, var(--accent), #d4952a);color:#fff;border-radius:var(--radius);width:100%;font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;box-shadow:var(--shadow-btn);letter-spacing:.02em;border:none;padding:16px;transition:all .2s}.btn-primary:hover{background:linear-gradient(135deg, var(--accent-hover), #c48520);transform:translateY(-1px);box-shadow:0 6px 20px #c47f1766}.btn-primary:active{transform:scale(.98)translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.photo-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.photo-grid .photo-slot:last-child:nth-child(odd){grid-column:1/-1;justify-self:center;max-width:calc(50% - 6px)}.photo-slot{flex-direction:column;gap:8px;display:flex}.photo-upload-area{aspect-ratio:1;border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:var(--input-bg);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:relative;overflow:hidden}.photo-upload-area:hover{border-color:var(--accent);background:var(--accent-light)}.photo-upload-area .upload-icon{color:var(--border);transition:color var(--transition);font-size:24px}.photo-upload-area:hover .upload-icon{color:var(--accent)}.photo-upload-area .upload-text{color:var(--text-muted);font-size:11px;font-weight:500}.photo-preview{object-fit:cover;border-radius:calc(var(--radius) - 2px);width:100%;height:100%;position:absolute;inset:0}.photo-remove{color:#fff;cursor:pointer;z-index:2;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;transition:background .2s;display:flex;position:absolute;top:6px;right:6px}.photo-remove:hover{background:#dc2626cc}.photo-uploading{z-index:3;border-radius:calc(var(--radius) - 2px);background:#fef9f0d9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.photo-uploading .spinner{border:3px solid var(--skeleton-base);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.caption-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:12px;font-family:var(--font-body);color:var(--text-main);background:var(--input-bg);transition:all var(--transition);outline:none;padding:8px 12px}.caption-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.caption-input::placeholder{color:#b8a998}.diy-cta{border-radius:var(--radius);cursor:pointer;transition:all var(--transition);color:inherit;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:1.5px solid #a7f3d0;align-items:center;gap:12px;margin-top:12px;padding:14px 16px;text-decoration:none;display:flex}.diy-cta:hover{border-color:#34d399;transform:translateY(-1px);box-shadow:0 4px 15px #34d39926}.diy-cta-icon{flex-shrink:0;font-size:20px}.diy-cta-text{flex:1}.diy-cta-title{color:#065f46;margin-bottom:2px;font-size:13px;font-weight:700}.diy-cta-sub{color:#6b7280;font-size:11px;line-height:1.4}.diy-cta-arrow{color:#34d399;font-size:18px;font-weight:700}.creating-container{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;padding:32px 20px;display:flex;position:relative;overflow:hidden}.creating-ring{place-items:center;width:150px;height:150px;display:grid;position:relative}.creating-ring-svg{width:150px;height:150px;transform:rotate(-90deg)}.creating-ring-svg .ring-track{fill:none;stroke:var(--skeleton-base);stroke-width:8px}.creating-ring-svg .ring-progress{fill:none;stroke:var(--accent);stroke-width:8px;stroke-linecap:round;filter:drop-shadow(0 0 6px var(--accent-glow));transition:stroke-dashoffset 1s linear}.creating-ring-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.creating-heart{font-size:38px;animation:1.3s ease-in-out infinite heartBeat}.creating-count{font-family:var(--font-body);color:var(--accent);letter-spacing:.5px;font-size:15px;font-weight:700}.creating-title{font-family:var(--font-display);margin-top:4px;font-size:1.85rem;line-height:1.15}.gradient-text{background:linear-gradient(90deg,#c47f17,#f0a93a,#c47f17) 0 0/200%;-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text;animation:3s linear infinite shimmerText}@keyframes shimmerText{to{background-position:200%}}.creating-line{color:var(--text-main);max-width:280px;min-height:42px;font-size:14.5px;font-weight:500;line-height:1.5;animation:.5s lineSwap}@keyframes lineSwap{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.creating-status{color:var(--text-muted);background:var(--accent-light);border:1px solid var(--border);border-radius:999px;align-items:center;gap:8px;padding:7px 14px;font-size:12.5px;font-weight:600;display:inline-flex}.creating-status-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite dotPulse}.creating-floaties{pointer-events:none;z-index:0;position:absolute;inset:0}.creating-floaties span{opacity:0;font-size:20px;animation:6s ease-in infinite floatUp;position:absolute;bottom:-30px}.creating-floaties span:first-child{animation-delay:0s;left:12%}.creating-floaties span:nth-child(2){animation-delay:1.4s;left:30%}.creating-floaties span:nth-child(3){animation-delay:2.6s;left:52%}.creating-floaties span:nth-child(4){animation-delay:.8s;left:71%}.creating-floaties span:nth-child(5){animation-delay:3.4s;left:86%}@keyframes floatUp{0%{opacity:0;transform:translateY(0)scale(.8)}15%{opacity:.85}85%{opacity:.5}to{opacity:0;transform:translateY(-360px)scale(1.1)}}.creating-ring,.creating-title,.creating-line,.creating-status{z-index:1;position:relative}.success-container{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:20px;display:flex}.success-check{background:linear-gradient(135deg, var(--accent), #d4952a);width:72px;height:72px;box-shadow:0 8px 30px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;animation:.6s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.success-check svg{stroke-dasharray:24;stroke-dashoffset:0;animation:.5s .3s backwards drawCheck}@keyframes drawCheck{0%{stroke-dashoffset:24px}to{stroke-dashoffset:0}}.success-title{font-family:var(--font-display);color:var(--text-main);font-size:2.5rem}.success-subtitle{color:var(--text-muted);max-width:280px;font-size:14px;line-height:1.5}.success-card{color:#fff;text-align:left;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);border:1px solid #334155;border-radius:20px;width:100%;margin-top:8px;padding:24px;box-shadow:0 10px 25px #0f172a33}.success-card-tag{color:#fbbf24;text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px;font-size:10px;font-weight:700}.success-card-heading{font-family:var(--font-display);color:#f1f5f9;margin-bottom:10px;font-size:1.3rem}.success-card-message{color:#94a3b8;border-left:3px solid var(--accent);padding-left:12px;font-size:13px;font-style:italic;line-height:1.6}.btn-secondary{width:100%;color:var(--accent);border:2px solid var(--accent);border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;background:0 0;margin-top:8px;padding:14px;transition:all .2s}.btn-secondary:hover{background:var(--accent-light)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.5s forwards fadeIn}.fade-in-up{animation:.5s forwards fadeInUp}*{scrollbar-width:none}::-webkit-scrollbar{display:none}.pay-screen{flex-direction:column;padding:4px 2px 8px;display:flex}.pay-badge{background:var(--accent-light);color:var(--accent);border:1px solid var(--border);letter-spacing:.4px;text-transform:uppercase;border-radius:999px;align-self:flex-start;margin-bottom:10px;padding:5px 12px;font-size:11px;font-weight:800}.pay-card{border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft);background:linear-gradient(160deg,#fffdf8 0%,#fdf4e7 100%);margin-top:16px;padding:18px;position:relative;overflow:hidden}.pay-card:before{content:"";background:radial-gradient(circle, var(--accent-glow), transparent 70%);pointer-events:none;width:120px;height:120px;position:absolute;top:-40px;right:-40px}.pay-card-top{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;gap:12px;padding-bottom:14px;display:flex}.pay-card-label{font-family:var(--font-display);color:var(--text-main);font-size:1.3rem;line-height:1.1}.pay-card-sub{color:var(--text-muted);margin-top:3px;font-size:11.5px}.pay-price{color:var(--accent);white-space:nowrap;font-size:2.4rem;font-weight:800;line-height:1}.pay-price-cur{vertical-align:super;margin-right:1px;font-size:1.3rem;font-weight:700}.pay-features{flex-direction:column;gap:10px;margin:14px 0 0;padding:0;list-style:none;display:flex}.pay-features li{color:var(--text-main);align-items:center;gap:10px;font-size:13.5px;font-weight:500;display:flex}.pay-feat-icon{text-align:center;flex-shrink:0;width:22px;font-size:16px}.pay-feat-check{color:#16a34a;margin-left:auto;font-size:13px;font-weight:800}.pay-recover{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);text-align:center;background:#fff8ee;margin-top:14px;padding:10px 12px;font-size:12.5px;font-weight:600}.pay-error{color:#b91c1c;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;margin-top:14px;padding:10px 12px;font-size:12.5px;font-weight:600;line-height:1.4}.pay-btn{margin-top:18px;font-size:16px}.pay-btn-loading{align-items:center;gap:10px;display:inline-flex}.pay-btn-loading .spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.pay-trust{text-align:center;margin-top:14px}.pay-trust-row{color:var(--text-muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;font-size:11.5px;font-weight:600;display:flex}.pay-trust-powered{color:var(--text-muted);margin-top:6px;font-size:11px}.pay-trust-powered strong{color:#0c2451}.pay-reassure{color:var(--text-muted);text-align:center;background:var(--accent-light);border-radius:var(--radius-sm);margin-top:14px;padding:10px 12px;font-size:11.5px;line-height:1.55}.pay-screen .diy-cta,.success-container .diy-cta{margin-top:14px}.creating-help{z-index:1;width:100%;max-width:320px;margin-top:20px;position:relative}.creating-help .diy-cta{margin-top:0}
