.cake-section{background:linear-gradient(180deg,#2c1810,#1a0f08);position:relative}.aurora{position:absolute;width:60vw;height:60vw;border-radius:50%;filter:blur(80px);opacity:.35;pointer-events:none;animation:drift 12s ease-in-out infinite alternate}.aurora-1{background:#ff6b9d;top:-20%;left:-10%}.aurora-2{background:#c77dff;bottom:-25%;right:-15%;animation-duration:16s}@keyframes drift{to{transform:translate(40px,-30px) scale(1.1)}}.name-shine{background:linear-gradient(135deg,#ffd166,#ff6b9d,#c77dff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}.cake-sub{opacity:.9;margin-bottom:26px}.cake-stage{position:relative;margin:16px auto 24px;cursor:pointer;-webkit-user-select:none;user-select:none}.candles{display:flex;justify-content:center;gap:14px;margin-bottom:-4px;position:relative;z-index:3}.candle{width:10px;height:50px;background:linear-gradient(180deg,#ffd166,#ff6b9d);border-radius:3px;position:relative;cursor:pointer;transition:transform .15s}.candle:hover:not(.out){transform:translateY(-3px)}.flame{position:absolute;top:-22px;left:50%;transform:translate(-50%);width:14px;height:22px;background:radial-gradient(ellipse at 50% 80%,#fff5d1 0%,#ffaa00 40%,#ff4500 70%,transparent 100%);border-radius:50%/80% 80% 20% 20%;animation:flicker .3s infinite alternate;filter:drop-shadow(0 0 6px #ffaa00)}@keyframes flicker{0%{transform:translate(-50%) scale(1) rotate(-2deg);opacity:1}to{transform:translate(-50%) scale(1.08) rotate(3deg);opacity:.9}}.smoke{position:absolute;top:-16px;left:50%;width:3px;height:18px;background:linear-gradient(to top,rgba(180,180,180,.7),transparent);animation:smoke 2s ease-out forwards;transform:translate(-50%)}@keyframes smoke{0%{opacity:.7;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-30px)}}.cake-body{width:clamp(240px,70vw,340px);margin:0 auto;position:relative;z-index:2}.tier{height:60px;border-radius:8px;position:relative;box-shadow:0 8px 20px #00000080;transition:transform .4s}.tier-1{background:linear-gradient(180deg,#ff9ec4,#ff6b9d)}.tier-1:after{content:"";position:absolute;top:0;left:0;right:0;height:18px;background:repeating-linear-gradient(90deg,#fff8e7 0,#fff8e7 18px,#ffe4f1 18px,#ffe4f1 36px);border-radius:8px 8px 0 0;border-bottom:3px solid #fff}.tier-2{width:85%;margin:0 auto;background:linear-gradient(180deg,#c77dff,#9d4edd);height:50px}.tier-2:after{content:"";position:absolute;top:0;left:0;right:0;height:14px;background:repeating-linear-gradient(90deg,#fff8e7 0,#fff8e7 14px,#f3d9ff 14px,#f3d9ff 28px);border-radius:8px 8px 0 0;border-bottom:3px solid #fff}.tier.sliced{clip-path:polygon(0 0,70% 0,60% 100%,0 100%)}.plate{width:110%;height:14px;margin:-4px -5% 0;background:linear-gradient(180deg,#ddd,#999);border-radius:50%;box-shadow:0 10px 20px #0009}.slice-msg{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:16px;background:linear-gradient(135deg,#ffd166,#ff6b9d);color:#fff;padding:10px 18px;border-radius:30px;font-weight:600;white-space:nowrap;box-shadow:0 8px 20px #0006}.blow-controls{margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:3}.mic-status{margin-top:12px;font-size:.85rem;opacity:.9;min-height:1.2em;width:200px;height:6px;background:#ffffff26;border-radius:3px;overflow:hidden}.mic-meter{height:100%;background:linear-gradient(90deg,#4cc9f0,#ff6b9d);border-radius:3px;transition:width .1s}.final-msg{margin-top:22px;font-size:clamp(1.1rem,3vw,1.5rem);font-style:italic;color:#ffd166;text-shadow:0 0 20px rgba(255,209,102,.5);text-align:center}.final-msg .hint{margin-top:8px;font-size:.8rem;opacity:.7;font-style:normal;color:#fff}.lantern-section{background:radial-gradient(ellipse at bottom,#1a0f3a,#0a0a1f 60%,#000010);position:relative}.lantern-stars{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 12% 18%,rgba(255,255,255,.9) .6px,transparent 1px),radial-gradient(circle at 68% 22%,rgba(255,255,255,.7) .6px,transparent 1px),radial-gradient(circle at 42% 8%,rgba(255,255,255,.8) .6px,transparent 1px),radial-gradient(circle at 82% 12%,rgba(255,255,255,.6) .6px,transparent 1px),radial-gradient(circle at 24% 28%,rgba(255,255,255,.5) .5px,transparent 1px),radial-gradient(circle at 56% 14%,rgba(255,255,255,.9) .6px,transparent 1px);background-size:100% 100%;animation:twinkle 4s ease-in-out infinite alternate;pointer-events:none}@keyframes twinkle{to{opacity:.6}}.lantern-title{color:#fff;z-index:2}.lantern-sub{color:#fffc;margin-bottom:18px;z-index:2}.lantern-stage{position:relative;flex:1;width:100%;max-width:700px;z-index:2}.lantern{position:absolute;bottom:30px;width:56px;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.lantern:active{cursor:grabbing}.lantern-body{width:56px;height:68px;background:linear-gradient(180deg,#ff8a3d,#ff4d6d 60%,#b8002e);border-radius:50% 50% 38% 38%/60% 60% 40% 40%;position:relative;box-shadow:inset -4px -8px 14px #0000004d,0 0 30px #ff8a3db3,0 0 60px #ff4d6d66;display:flex;align-items:center;justify-content:center}.lantern-glow{position:absolute;top:8px;right:8px;bottom:8px;left:8px;background:radial-gradient(circle,#fff5d1 0%,#ffaa00 40%,transparent 70%);border-radius:50%;animation:lantern-flame 1.5s ease-in-out infinite alternate}@keyframes lantern-flame{0%{opacity:.85;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.lantern-wish{position:absolute;top:-34px;left:50%;transform:translate(-50%);font-size:.7rem;color:#ffd166;white-space:nowrap;background:#0000008c;padding:3px 10px;border-radius:20px;border:1px solid rgba(255,209,102,.4);z-index:3}.lantern-string{width:1px;height:12px;margin:0 auto;background:#ffffff80}.lantern-tassel{width:6px;height:8px;margin:0 auto;background:#ffd166;border-radius:0 0 50% 50%}.jar-section{background:radial-gradient(ellipse at bottom,#143b5e,#0a1929 60%,#050d18);position:relative}.jar-stars{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 14% 22%,rgba(255,255,255,.7) .6px,transparent 1px),radial-gradient(circle at 78% 16%,rgba(255,255,255,.6) .6px,transparent 1px),radial-gradient(circle at 48% 12%,rgba(255,255,255,.7) .6px,transparent 1px),radial-gradient(circle at 30% 30%,rgba(255,255,255,.5) .6px,transparent 1px);pointer-events:none;animation:twinkle 5s ease-in-out infinite alternate}.jar-title{color:#fff;z-index:2}.jar-sub{color:#fffc;margin-bottom:18px;z-index:2}.jar-stage{position:relative;width:100%;flex:1;z-index:2;display:flex;align-items:flex-end;justify-content:center;padding-bottom:30px}.jar{position:relative;width:130px;background:none;border:none;cursor:pointer;z-index:3;padding:0}.jar-lid{height:14px;background:linear-gradient(180deg,#c4923a,#8a6320);border-radius:8px 8px 0 0;margin:0 12px;position:relative;z-index:4}.jar-body{height:150px;background:linear-gradient(180deg,#b4dcff2e,#78b4ff40);border:2px solid rgba(255,255,255,.4);border-radius:8px 8px 28px 28px;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:inset 8px -10px 30px #ffd16626,0 12px 30px #0006,0 0 50px #ffd1664d}.jar-fill{position:absolute;top:8px;right:6px;bottom:6px;left:6px;background:radial-gradient(circle at 30% 30%,rgba(255,209,102,.4) 6px,transparent 8px),radial-gradient(circle at 70% 50%,rgba(255,255,255,.3) 4px,transparent 6px),radial-gradient(circle at 50% 70%,rgba(255,209,102,.35) 5px,transparent 7px),radial-gradient(circle at 20% 80%,rgba(255,255,255,.25) 3px,transparent 5px);border-radius:6px 6px 22px 22px;animation:jar-shimmer 3s ease-in-out infinite alternate}@keyframes jar-shimmer{0%{transform:translateY(2px)}to{transform:translateY(-2px)}}.jar-shine{position:absolute;top:10%;left:14%;width:14%;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.55),transparent);border-radius:50%;filter:blur(1px)}.jar-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.6rem;filter:drop-shadow(0 0 8px rgba(255,209,102,.8))}.jar-base{height:6px;background:#0006;border-radius:50%;margin:-3px 18px 0;filter:blur(4px)}.wish-bubble{position:absolute;bottom:80px;width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.7) 0%,rgba(255,209,102,.25) 40%,transparent 70%),#b4dcff26;cursor:pointer;z-index:4;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 0 18px #ffd16680,inset 0 0 12px #ffffff4d}.wish-bubble:hover{transform:scale(1.1)}.jar-popup{position:absolute;top:38%;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#ffd166,#ff6b9d);color:#fff;padding:14px 22px;border-radius:20px;font-weight:700;font-size:.95rem;max-width:80vw;text-align:center;box-shadow:0 14px 35px #0006;z-index:10}.pinata-section{background:linear-gradient(180deg,#5a189a,#7209b7,#4a0072);position:relative}.pinata-title{color:#fff;z-index:2}.pinata-sub{color:#ffd166;margin-bottom:12px;font-weight:700;z-index:2}.pinata-stage{position:relative;flex:1;width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:2}.pinata-rope{width:2px;height:60px;background:linear-gradient(180deg,#b89464,#6e4f25)}.pinata{width:160px;height:200px;position:relative;transform-origin:top center;-webkit-user-select:none;user-select:none}.pinata.shaking{animation:pinata-shake .24s ease-in-out}@keyframes pinata-shake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-12px) rotate(-8deg)}75%{transform:translate(12px) rotate(8deg)}}.pinata-body{width:160px;height:160px;margin-top:18px;background:linear-gradient(135deg,#ff6b9d,#ff4081 60%,#d6336c);border-radius:50% 50% 40% 40%/60% 60% 40% 40%;position:relative;box-shadow:inset -8px -16px 30px #0000004d,0 16px 35px #0006;display:flex;align-items:center;justify-content:center}.pinata-face{font-size:2.4rem;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}.pinata-fringe,.pinata-fringe.two,.pinata-fringe.three{position:absolute;left:0;right:0;height:10px;background:repeating-linear-gradient(90deg,#ffd166 0,#ffd166 8px,#4cc9f0 8px,#4cc9f0 16px,#06d6a0 16px,#06d6a0 24px)}.pinata-fringe{bottom:8px}.pinata-fringe.two{bottom:26px;opacity:.85}.pinata-fringe.three{bottom:44px;opacity:.7}.pinata-hp{width:220px;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin:6px 0 18px;z-index:2}.hp-fill{height:100%;background:linear-gradient(90deg,#06d6a0,#ffd166,#ff6b9d);transition:width .25s}.fortunes-wrap{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;pointer-events:none;z-index:5}.fortune{position:absolute;top:50%;left:50%;background:#fff;color:#6a1b3e;font-weight:700;padding:8px 14px;border-radius:16px;font-size:.85rem;white-space:nowrap;box-shadow:0 8px 24px #0006}.decorate-section{background:linear-gradient(135deg,#ffe4f1,#fbc2eb,#f3d9ff);color:#6a1b3e}.decorate-title{color:#d6336c;z-index:2}.decorate-sub{color:#6a1b3e;margin-bottom:14px;z-index:2;font-weight:600}.decorate-stage{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%;max-width:420px;z-index:2;flex:1;justify-content:center}.cake-canvas{position:relative;width:240px;height:200px;cursor:crosshair;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 14px 30px rgba(214,51,108,.35))}.cake-top{position:absolute;top:0;left:30px;right:30px;height:50px;background:linear-gradient(180deg,#fff5d1,#ffe2bf);border-radius:8px 8px 0 0}.cake-top:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:14px;background:repeating-linear-gradient(90deg,#fff 0,#fff 12px,#fbc2eb 12px,#fbc2eb 24px);border-radius:0 0 4px 4px}.cake-middle{position:absolute;top:56px;left:18px;right:18px;height:60px;background:linear-gradient(180deg,#ff9ec4,#ff6b9d)}.cake-middle:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:14px;background:repeating-linear-gradient(90deg,#fff8e7 0,#fff8e7 14px,#ffe4f1 14px,#ffe4f1 28px)}.cake-bottom{position:absolute;top:122px;left:8px;right:8px;height:60px;background:linear-gradient(180deg,#c77dff,#9d4edd)}.cake-plate{position:absolute;bottom:-6px;left:0;right:0;height:14px;background:linear-gradient(180deg,#ddd,#999);border-radius:50%;box-shadow:0 14px 20px #0000004d}.placed-topping{position:absolute;font-size:1.4rem;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));animation:pop-in .4s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:translate(-50%,-50%) scale(0)}to{transform:translate(-50%,-50%) scale(1)}}.bake-shine{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(255,255,255,.7),transparent 60%);border-radius:50%;animation:bake-pulse 1.4s ease-in-out infinite alternate;pointer-events:none}@keyframes bake-pulse{to{opacity:.4;transform:scale(1.1)}}.topping-palette{background:#ffffffb3;border-radius:18px;padding:10px 14px;box-shadow:0 8px 20px #d6336c2e;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.palette-label{font-size:.75rem;color:#6a1b3e;font-weight:700;text-align:center;margin-bottom:6px;letter-spacing:.5px}.palette-grid{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.palette-btn{width:38px;height:38px;font-size:1.2rem;background:#fff;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s}.palette-btn:hover{transform:scale(1.1)}.palette-btn.active{border-color:#ff6b9d;box-shadow:0 0 0 3px #ff6b9d40;transform:scale(1.05)}.decorate-controls{margin-top:14px;margin-bottom:60px;z-index:3}.wheel-section{background:linear-gradient(180deg,#2e1a3a,#1a0033,#0d0020);position:relative;color:#fff}.wheel-title{color:#fff;z-index:2}.wheel-sub{color:#ffd166;margin-bottom:18px;z-index:2;font-weight:700}.wheel-stage{position:relative;width:260px;height:260px;margin:8px auto 18px;z-index:2}.wheel-pointer{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:28px solid #ffd166;z-index:5;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}.wheel{position:relative;width:100%;height:100%;border-radius:50%;border:6px solid #ffd166;background:#1a0033;overflow:hidden;box-shadow:0 0 0 4px #ffffff26,0 20px 50px #0009,0 0 60px #ffd16666}.wheel-slice{position:absolute;top:0;left:0;width:100%;height:100%;transform-origin:50% 50%}.wheel-label{position:absolute;top:50%;left:50%;transform-origin:50% 50%;color:#fff;font-size:.62rem;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap;letter-spacing:.2px}.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffd166,#c8910f);box-shadow:0 0 0 5px #fff,0 0 12px #0006;z-index:4}.wheel-spin-btn{font-size:1rem;margin-bottom:12px;z-index:3}.wheel-result{margin-top:8px;font-size:1.15rem;font-weight:800;background:linear-gradient(135deg,#ffd166,#ff6b9d);color:#fff;padding:12px 22px;border-radius:30px;box-shadow:0 14px 30px #ff6b9d66;z-index:3}.match-section{background:linear-gradient(135deg,#143b5e,#1e3a5f,#0a1929)}.match-title{color:#fff;z-index:2}.match-sub{color:#ffd166;margin-bottom:14px;font-weight:700;z-index:2}.match-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:min(360px,92vw);z-index:2}.match-card{aspect-ratio:3 / 4;background:none;border:none;padding:0;perspective:800px;cursor:pointer}.card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .5s}.match-card.flipped .card-inner{transform:rotateY(180deg)}.match-card.matched .card-inner{animation:matched-pop .4s ease-out}@keyframes matched-pop{0%{transform:rotateY(180deg) scale(1)}40%{transform:rotateY(180deg) scale(1.12)}to{transform:rotateY(180deg) scale(1)}}.card-back,.card-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:10px;box-shadow:0 4px 14px #00000073;display:flex;align-items:center;justify-content:center;overflow:hidden}.card-back{background:linear-gradient(135deg,#ff6b9d,#c77dff);color:#fff;font-size:1.8rem;border:2px solid rgba(255,255,255,.4)}.card-face{background:#fff;transform:rotateY(180deg);border:2px solid #ffd166}.card-face img{width:100%;height:100%;object-fit:cover}.match-card.matched .card-face{border-color:#06d6a0;box-shadow:0 0 0 2px #06d6a0,0 4px 14px #00000073}.scratch-section{background:linear-gradient(135deg,#ff9a9e,#fad0c4,#fbc2eb);color:#6a1b3e;position:relative}.streamer{position:absolute;width:80vw;height:80vw;border:6px dashed rgba(255,255,255,.4);border-radius:50%;pointer-events:none}.streamer-1{top:-40%;left:-20%}.streamer-2{bottom:-45%;right:-25%;border-color:#ffd16680;border-style:dotted}.scratch-title{color:#d6336c;z-index:2}.scratch-sub{color:#6a1b3e;margin-bottom:22px;z-index:2}.card-stack{position:relative;width:min(340px,88vw);height:460px;margin:8px auto 0;z-index:2}.stack-slot{position:absolute;top:0;right:0;bottom:0;left:0;will-change:transform}.scratch-card-wrap{position:relative;width:100%;height:100%;margin:0 auto;border-radius:24px;box-shadow:0 24px 50px #0000004d}.stack-actions{margin-top:22px;min-height:50px;z-index:3;position:relative}.reveal-layer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#fff8e7,#ffe4f1);border-radius:24px;box-shadow:0 20px 50px #00000040;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 24px;color:#d6336c;text-align:center}.reveal-layer h2{color:#d6336c;margin-bottom:8px}.reveal-layer p{color:#6a1b3e;font-size:.95rem;margin-bottom:8px}.reveal-layer .emphasis{font-weight:700;margin-top:6px;background:linear-gradient(135deg,#d6336c,#9d4edd);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gift-photo{width:130px;height:130px;border-radius:50%;overflow:hidden;border:4px solid #ff6b9d;margin-bottom:14px;box-shadow:0 8px 20px #d6336c4d;flex-shrink:0}.gift-photo img{width:100%;height:100%;object-fit:cover}.scratch-canvas{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:24px;touch-action:none;cursor:grab}.scratch-canvas:active{cursor:grabbing}.sparkle-canvas{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:24px}.progress-bar{position:absolute;bottom:-28px;left:10%;right:10%;height:6px;background:#fff6;border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background:linear-gradient(90deg,#ffd166,#ff6b9d);transition:width .2s}.party-section{background:linear-gradient(180deg,#0a0a1f,#1a0033,#0d0020);position:relative;-webkit-user-select:none;user-select:none;cursor:pointer}.disco-lights{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,#ff6b9d 0%,transparent 20%),radial-gradient(circle at 80% 65%,#4cc9f0 0%,transparent 22%),radial-gradient(circle at 65% 18%,#ffd166 0%,transparent 18%),radial-gradient(circle at 35% 78%,#c77dff 0%,transparent 22%),radial-gradient(circle at 50% 50%,#06d6a0 0%,transparent 14%);filter:blur(60px);opacity:.55;animation:disco-pulse 1.4s ease-in-out infinite alternate;pointer-events:none}@keyframes disco-pulse{0%{opacity:.35;transform:scale(1) rotate(0)}to{opacity:.7;transform:scale(1.1) rotate(8deg)}}.disco-checker{position:absolute;top:50%;right:0;bottom:0;left:0;background:linear-gradient(90deg,rgba(255,107,157,.18) 1px,transparent 1px) 0 0 / 40px 40px,linear-gradient(0deg,rgba(76,201,240,.18) 1px,transparent 1px) 0 0 / 40px 40px;transform-origin:50% 0;transform:perspective(400px) rotateX(60deg) scale(1.4);opacity:.6;pointer-events:none;z-index:1}.disco-ball-wrap{position:absolute;top:26px;left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;align-items:center}.disco-string{width:1px;height:24px;background:#ffffff80;margin-top:-2px}.disco-ball{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#ccc 25%,#555 70%,#222),repeating-conic-gradient(#aaa,#aaa 10deg,#fff 10deg,#fff 20deg);background-blend-mode:multiply;box-shadow:0 0 20px #ffffff80,0 0 50px #ff6b9d80,0 0 80px #4cc9f066;order:2}.disco-ball:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-linear-gradient(45deg,transparent 0 4px,rgba(0,0,0,.2) 4px 6px),repeating-linear-gradient(-45deg,transparent 0 4px,rgba(0,0,0,.2) 4px 6px);mix-blend-mode:multiply}.party-title{color:#fff;z-index:3;margin-top:96px;font-size:clamp(1.8rem,6vw,2.6rem);font-weight:900;letter-spacing:2px;text-shadow:0 0 18px rgba(255,107,157,.9),0 0 40px rgba(255,209,102,.4)}.party-sub{color:#ffd166;z-index:3;margin-bottom:18px;font-weight:700;letter-spacing:.5px}.dance-floor{display:flex;gap:14px;margin:12px 0 22px;z-index:3;flex-wrap:wrap;justify-content:center;position:relative}.dancer{font-size:clamp(2rem,7vw,3.2rem);filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}.vibe-meter{width:min(280px,86vw);z-index:3;position:relative}.vibe-label{font-size:.7rem;font-weight:800;letter-spacing:2.5px;color:#ffd166;margin-bottom:6px;text-align:center}.vibe-bar{height:14px;background:#ffffff1f;border-radius:8px;overflow:hidden;border:1.5px solid rgba(255,255,255,.35);box-shadow:inset 0 2px 6px #00000080}.vibe-fill{height:100%;background:linear-gradient(90deg,#ff6b9d,#ffd166,#4cc9f0,#c77dff,#06d6a0);background-size:250% 100%;animation:rainbow-shift 1.4s linear infinite;border-radius:8px;transition:width .25s cubic-bezier(.34,1.56,.64,1)}@keyframes rainbow-shift{0%{background-position:0% 50%}to{background-position:250% 50%}}.vibe-count{font-size:.85rem;color:#fff;text-align:center;margin-top:6px;font-weight:700;opacity:.9}.letter-section{background:radial-gradient(ellipse at center,#4a2c14,#2b1808 60%,#1a0f08);color:#fff5d1}.letter-title{color:#ffd166;z-index:2}.letter-sub{color:#fff5d1d9;margin-bottom:14px;z-index:2}.letter-stage{position:relative;width:min(420px,90vw);flex:1;z-index:2;display:flex;align-items:center;justify-content:center}.envelope{position:relative;width:200px;height:140px;background:none;border:none;cursor:pointer;padding:0}.env-body{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#f4e2c4,#d9b97a);border-radius:6px;box-shadow:0 16px 40px #00000073,inset 0 0 14px #0000001a}.env-flap{position:absolute;top:0;left:0;right:0;height:70px;background:linear-gradient(180deg,#e6d29f,#c8a36e);clip-path:polygon(0 0,100% 0,50% 100%);z-index:2}.env-seal{position:absolute;top:56px;left:50%;transform:translate(-50%);width:36px;height:36px;background:radial-gradient(circle at 30% 30%,#ff6b9d,#a01045);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;z-index:3;box-shadow:0 4px 10px #00000080}.letter-paper{width:100%;max-height:56dvh;overflow-y:auto;padding:22px;background:linear-gradient(180deg,#fff8e7,#fdecc7);color:#4a2c14;font-family:Caveat,cursive;font-size:1.15rem;line-height:1.45;border-radius:6px;box-shadow:0 20px 50px #00000080;border:1px solid rgba(74,44,20,.2);position:relative}.letter-paper:before,.letter-paper:after{content:"";position:absolute;width:30px;height:6px;background:#ffc86499;border-left:1px dashed rgba(0,0,0,.1);border-right:1px dashed rgba(0,0,0,.1)}.letter-paper:before{top:-3px;left:50%;transform:translate(-50%) rotate(-3deg)}.letter-paper:after{bottom:-3px;right:12px;transform:rotate(8deg)}.letter-paper p{margin-bottom:4px}.letter-paper p.gap{height:.5em}.polaroid-section{background:#b89464;position:relative;padding:40px 20px}.cork-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.04) 1px,transparent 2px),radial-gradient(circle at 70% 60%,rgba(0,0,0,.06) 1px,transparent 2px),radial-gradient(circle at 40% 80%,rgba(255,255,255,.04) 1px,transparent 2px),repeating-linear-gradient(45deg,#c8a274 0,#c8a274 6px,#b89464 6px,#b89464 12px);background-size:30px 30px,40px 40px,35px 35px,auto;opacity:1;pointer-events:none}.polaroid-section h2{color:#fff8e7;text-shadow:2px 2px 4px rgba(0,0,0,.4);position:relative;z-index:2}.polaroid-sub{color:#fff8e7;position:relative;z-index:2;margin-bottom:20px;opacity:.95}.polaroid-wall{position:relative;width:100%;max-width:720px;flex:1 1 auto;min-height:0;max-height:70dvh;margin:6px auto 0;z-index:2}.polaroid{position:absolute;width:clamp(105px,22vw,145px);background:#fff;padding:8px 8px 26px;box-shadow:0 12px 30px #00000073;cursor:grab;touch-action:none;perspective:1000px}.polaroid:active{cursor:grabbing}.polaroid-inner{position:relative;width:100%;aspect-ratio:1;transform-style:preserve-3d;transition:transform .6s}.polaroid-inner.flipped{transform:rotateY(180deg)}.polaroid-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden}.polaroid-face.back{transform:rotateY(180deg);background:#fff8e7;display:flex;align-items:center;justify-content:center;padding:12px;border:1px dashed #c8a274}.photo{width:100%;height:100%;overflow:hidden}.photo img{width:100%;height:100%;object-fit:cover;display:block}.caption{position:absolute;bottom:-28px;left:0;right:0;text-align:center;font-family:Caveat,cursive;color:#333;font-size:1.15rem;font-style:italic}.back-msg{font-family:Caveat,cursive;font-size:1.05rem;color:#5a3a1f;text-align:center;line-height:1.3}.pin{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ff6b9d,#a01045);box-shadow:0 2px 4px #00000080;z-index:3;pointer-events:none}.tape{position:absolute;top:-6px;right:14px;width:38px;height:18px;background:#ffffc899;border-left:1px dashed rgba(0,0,0,.15);border-right:1px dashed rgba(0,0,0,.15);transform:rotate(15deg);pointer-events:none}.finale-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.finale-card{background:#fff;width:min(360px,90vw);padding:16px 16px 40px;border-radius:4px;box-shadow:0 30px 80px #000000b3;position:relative}.finale-pin{position:absolute;top:-10px;left:50%;transform:translate(-50%);width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffd166,#c8910f);box-shadow:0 3px 6px #00000080}.finale-content{text-align:center;padding:20px 10px}.finale-caption{font-family:Caveat,cursive;font-size:1.4rem;color:#d6336c;margin-bottom:12px}.finale-msg{font-family:Caveat,cursive;font-size:1.6rem;color:#333;line-height:1.35;padding:0 10px}.finale-close{margin-top:24px}.thankyou-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,rgba(255,209,102,.25) 0%,transparent 60%),radial-gradient(ellipse at bottom,rgba(199,125,255,.25) 0%,transparent 60%),linear-gradient(180deg,#1a0033,#0a0010);text-align:center;padding:30px 24px;overflow:hidden}.thankyou-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 14% 22%,rgba(255,255,255,.85) .7px,transparent 1.4px),radial-gradient(circle at 78% 16%,rgba(255,255,255,.7) .6px,transparent 1.2px),radial-gradient(circle at 48% 12%,rgba(255,255,255,.8) .6px,transparent 1.2px),radial-gradient(circle at 30% 60%,rgba(255,255,255,.5) .6px,transparent 1.2px),radial-gradient(circle at 80% 70%,rgba(255,255,255,.6) .6px,transparent 1.2px),radial-gradient(circle at 56% 84%,rgba(255,255,255,.5) .6px,transparent 1.2px);animation:twinkle 5s ease-in-out infinite alternate;pointer-events:none}.thankyou-content{position:relative;z-index:2;max-width:480px}.thankyou-sparkle{font-size:clamp(3.2rem,9vw,4.5rem);margin-bottom:18px;filter:drop-shadow(0 0 20px rgba(255,209,102,.7))}.thankyou-title{font-family:Caveat,cursive;font-size:clamp(3.5rem,11vw,6rem);font-weight:700;line-height:1;background:linear-gradient(135deg,#ffd166,#ff6b9d,#c77dff);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 60px rgba(255,209,102,.35);animation:gradient-pan 4s ease-in-out infinite;margin-bottom:8px}@keyframes gradient-pan{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.thankyou-name{font-family:Caveat,cursive;font-size:clamp(2rem,6vw,2.6rem);color:#ffd166;font-weight:700;margin-bottom:24px;letter-spacing:1px}.thankyou-message{color:#ffffffeb;font-size:clamp(.95rem,2.5vw,1.1rem);line-height:1.7;margin-bottom:22px;font-style:italic}.thankyou-message p{margin-bottom:4px}.thankyou-hearts{font-size:clamp(1.2rem,3.5vw,1.6rem);letter-spacing:6px;animation:hearts-float 2.4s ease-in-out infinite alternate}@keyframes hearts-float{0%{transform:translateY(0)}to{transform:translateY(-6px)}}.balloons-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50;overflow:hidden}.balloon{position:absolute;bottom:-120px;border-radius:50%;animation:balloon-rise linear forwards;filter:drop-shadow(0 4px 10px rgba(0,0,0,.2))}.balloon:after{content:"";position:absolute;bottom:-8px;left:50%;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid currentColor;transform:translate(-50%);color:inherit;opacity:.5}.string{position:absolute;bottom:-50px;left:50%;width:1px;height:50px;background:#fff9;transform-origin:top center;animation:string-sway 3s ease-in-out infinite alternate}@keyframes balloon-rise{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:1}to{transform:translateY(-130vh) translate(40px);opacity:.6}}@keyframes string-sway{0%{transform:translate(-50%) rotate(-4deg)}to{transform:translate(-50%) rotate(4deg)}}.sparkles-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:150}.sparkle{position:absolute;font-size:22px;transform:translate(-50%,-50%);animation:sparkle-burst .9s ease-out forwards;pointer-events:none;will-change:transform,opacity}@keyframes sparkle-burst{0%{transform:translate(-50%,-50%) scale(.4) rotate(0);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(1) rotate(var(--rot));opacity:0}}.music-toggle{position:fixed;top:16px;right:16px;z-index:110;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#ffffff26;border:1px solid rgba(255,255,255,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;color:#fff;font-size:.85rem;font-weight:600;transition:all .25s}.music-toggle:hover{background:#ffffff40;transform:translateY(-2px)}.music-toggle.on{background:linear-gradient(135deg,#ffd166,#ff6b9d);border-color:transparent;animation:pulse 1.2s ease-in-out infinite}.music-toggle .label{font-size:.75rem}@keyframes pulse{0%,to{box-shadow:0 0 #ff6b9d99}50%{box-shadow:0 0 0 10px #ff6b9d00}}.intro-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,#1a0033,#000010);z-index:500;display:flex;align-items:center;justify-content:center;overflow:hidden}.intro-inner{text-align:center;padding:20px}.intro-line{font-size:clamp(1.2rem,3.5vw,1.8rem);color:#fff;letter-spacing:1px;opacity:.9}.intro-name{font-family:Caveat,cursive;font-size:clamp(3.5rem,10vw,6rem);font-weight:700;background:linear-gradient(135deg,#ffd166,#ff6b9d,#c77dff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 60px rgba(255,209,102,.4)}.intro-overlay.is-tappable{cursor:pointer}.intro-tap-btn{margin-top:28px;padding:12px 26px;background:linear-gradient(135deg,#ffd166,#ff6b9d,#c77dff);background-size:200% 200%;color:#fff;font-family:inherit;font-weight:800;font-size:.95rem;border-radius:40px;border:none;box-shadow:0 12px 30px #ff6b9d8c,0 0 #ffd166b3;cursor:pointer;animation:tap-btn-shine 2.4s ease-in-out infinite,tap-btn-glow 1.4s ease-in-out infinite;letter-spacing:.4px}@keyframes tap-btn-shine{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes tap-btn-glow{0%,to{box-shadow:0 12px 30px #ff6b9d8c,0 0 #ffd166b3}50%{box-shadow:0 14px 36px #ff6b9db3,0 0 0 16px #ffd16600}}.warning-toast{position:fixed;top:70px;left:50%;transform:translate(-50%);z-index:300;padding:14px 22px;border-radius:30px;background:linear-gradient(135deg,#ffd166,#ff6b9d);color:#fff;font-weight:700;font-size:.95rem;box-shadow:0 14px 35px #00000059;max-width:86vw;text-align:center;border:2px solid rgba(255,255,255,.4)}.nav-dots{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column;gap:12px}.nav-dots a{width:12px;height:12px;border-radius:50%;background:#fff6;border:1.5px solid rgba(255,255,255,.7);transition:all .3s;display:block}.nav-dots a:hover{background:#fff;transform:scale(1.3)}.nav-dots a.locked{background:transparent;border-style:dashed;border-color:#ffffff59;cursor:not-allowed}.nav-dots a.locked:hover{transform:scale(1);background:transparent}*{margin:0;padding:0;box-sizing:border-box}html{scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;overflow-anchor:none;height:100%;overflow-x:hidden;overflow-y:scroll;background:#1a0f08;transition:background .35s ease}body{margin:0;min-height:100%;font-family:Poppins,system-ui,-apple-system,sans-serif;color:#fff;-webkit-tap-highlight-color:transparent;background:transparent}#root{min-height:100%}button{font-family:inherit;cursor:pointer;border:none;outline:none}img{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}::selection{background:#ff6b9d;color:#fff}.btn{padding:12px 26px;background:linear-gradient(135deg,#ffd166,#ff6b9d);color:#fff;font-weight:700;border-radius:50px;font-size:.95rem;box-shadow:0 6px 20px #ff6b9d66;transition:transform .25s ease,box-shadow .25s ease}.btn:hover{transform:translateY(-3px);box-shadow:0 10px 25px #ff6b9d99}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.secondary{background:linear-gradient(135deg,#4cc9f0,#7209b7)}.scroll-hint{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:.8rem;opacity:.7;animation:bounce 2s infinite;z-index:5;pointer-events:none}.locked-hint{position:absolute;bottom:22px;left:50%;transform:translate(-50%);z-index:5;padding:6px 14px;background:#00000059;border:1px solid rgba(255,255,255,.25);border-radius:30px;font-size:.78rem;color:#ffffffd9;white-space:nowrap;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.locked-hint.dark{background:#d6336c2e;color:#6a1b3e;border-color:#d6336c4d}.scroll-text{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:6;padding:10px 22px;border:none;border-radius:30px;font-family:inherit;font-size:.95rem;font-weight:700;letter-spacing:.5px;color:#fff;background:linear-gradient(135deg,#ffd166,#ff6b9d,#c77dff);background-size:200% 200%;box-shadow:0 10px 25px #ff6b9d73;animation:scroll-text-shine 3s ease-in-out infinite;white-space:nowrap;cursor:pointer;transition:filter .2s,box-shadow .2s}.scroll-text:hover{filter:brightness(1.08)}.scroll-text:active{filter:brightness(.95)}.scroll-text.dark{background:linear-gradient(135deg,#d6336c,#9d4edd,#ffd166);background-size:200% 200%;color:#fff;box-shadow:0 10px 25px #d6336c73}@keyframes scroll-text-shine{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}section.is-bouncing{animation:screen-bounce 1.3s ease-in-out 1;will-change:transform}@keyframes screen-bounce{0%{transform:translateY(0)}28%{transform:translateY(-32px)}48%{transform:translateY(0)}62%{transform:translateY(-14px)}78%{transform:translateY(0)}90%{transform:translateY(-5px)}to{transform:translateY(0)}}.orientation-block{display:none}@media (orientation: landscape) and (pointer: coarse){.orientation-block{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:linear-gradient(180deg,#1a0033,#0a0010);color:#fff;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px;font-family:Poppins,system-ui,sans-serif}.orientation-block .orientation-icon{font-size:4rem;margin-bottom:18px;animation:rotate-hint 2.4s ease-in-out infinite}.orientation-block p{font-size:1.1rem;font-weight:700;color:#ffd166;letter-spacing:.4px}nav.nav-dots,.music-toggle,section,.balloons-layer,.sparkles-layer,.intro-overlay,.thankyou-overlay{display:none!important}}@keyframes rotate-hint{0%,to{transform:rotate(-90deg)}50%{transform:rotate(0)}}@keyframes bounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,-10px)}}section{height:100vh;height:100dvh;width:100%;scroll-snap-align:start;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px;text-align:center;flex-shrink:0}h1{font-size:clamp(1.8rem,5vw,3rem);margin-bottom:10px}h2{font-size:clamp(1.3rem,3.5vw,2rem);margin-bottom:14px}p{font-size:clamp(.9rem,2.2vw,1.1rem);line-height:1.6}
