html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background:#0a0a1a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%;overflow:hidden}::selection{background:#c0392b4d;color:inherit}*{margin:0;padding:0;box-sizing:border-box}.app{width:100vw;height:100vh;overflow:hidden;position:relative;background:linear-gradient(180deg,#0a0a1a,#1a1a3e 40%,#2d1b4e,#1a0a2e);display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif}.moon{position:fixed;top:6%;right:12%;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff8e7,#f0d890,#c9a84c);box-shadow:0 0 40px 10px #fff8dc4d,0 0 80px 30px #fff8dc26,0 0 120px 60px #fff8dc0d;z-index:1;animation:moonGlow 6s ease-in-out infinite}@keyframes moonGlow{0%,to{box-shadow:0 0 40px 10px #fff8dc4d,0 0 80px 30px #fff8dc26}50%{box-shadow:0 0 50px 15px #fff8dc66,0 0 100px 40px #fff8dc33}}.stars-container{position:fixed;inset:0;z-index:0;pointer-events:none}.star{position:absolute;background:#fff;border-radius:50%;animation:twinkle var(--duration, 3s) ease-in-out infinite}@keyframes twinkle{0%,to{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.fireflies-container{position:fixed;inset:0;z-index:2;pointer-events:none}.firefly{position:absolute;background:radial-gradient(circle,#ffe696e6,#ffc86400 70%);border-radius:50%;animation:fireflyFloat var(--duration, 8s) ease-in-out infinite;filter:blur(.5px)}@keyframes fireflyFloat{0%{opacity:0;transform:translate(0)}20%{opacity:.8}50%{opacity:.4;transform:translate(var(--drift-x, 50px),var(--drift-y, -30px))}80%{opacity:.9}to{opacity:0;transform:translate(0)}}.shooting-star{position:fixed;width:3px;height:3px;background:#fff;border-radius:50;z-index:1;animation:shoot var(--duration, .8s) linear forwards}.shooting-star:after{content:"";position:absolute;top:50%;right:100%;width:80px;height:1.5px;background:linear-gradient(to left,rgba(255,255,255,.8),transparent);transform:translateY(-50%) rotate(var(--angle, 30deg));transform-origin:right center}@keyframes shoot{0%{opacity:1;transform:translate(0) rotate(var(--angle, 30deg))}to{opacity:0;transform:translate(300px,200px) rotate(var(--angle, 30deg))}}.petals-container{position:fixed;inset:0;z-index:3;pointer-events:none;overflow:hidden}.petal{position:absolute;top:-20px;background:radial-gradient(ellipse at 30% 30%,#ffb6c1cc,#ff698c66);border-radius:50% 0 50% 50%;animation:petalFall var(--duration, 8s) ease-in-out infinite;opacity:0}@keyframes petalFall{0%{opacity:0;transform:translateY(-10px) translate(0) rotate(0)}10%{opacity:.7}to{opacity:0;transform:translateY(100vh) translate(var(--sway, 50px)) rotate(calc(var(--rotation, 180deg) + 360deg))}}.envelope-scene{display:flex;flex-direction:column;align-items:center;gap:20px;z-index:10;animation:fadeInFloat 1.5s ease-out}@keyframes fadeInFloat{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.envelope-prompt{font-size:1.1rem;color:#ffffffb3;letter-spacing:.5px;font-weight:300;animation:softPulse 3s ease-in-out infinite;min-height:28px;text-align:center}@keyframes softPulse{0%,to{opacity:.7}50%{opacity:1}}.envelope{width:220px;height:150px;cursor:pointer;perspective:800px;transition:transform .4s ease;position:relative}.envelope-hover{transform:translateY(-8px) scale(1.05)}.envelope-body{position:relative;width:100%;height:100%}.envelope-front{width:100%;height:100%;background:linear-gradient(135deg,#f5e6d0,#e8d5b7,#d4c4a0);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff4d;position:relative;overflow:hidden}.envelope-front:before{content:"";position:absolute;inset:6px;border:1px dashed rgba(139,119,90,.3);border-radius:2px;pointer-events:none}.envelope-flap{position:absolute;top:0;left:0;width:100%;height:75px;background:linear-gradient(180deg,#e0d0b5,#d4c4a0);clip-path:polygon(0 0,50% 100%,100% 0);z-index:2;transform-origin:top center;transition:transform .6s ease;box-shadow:0 2px 8px #0000001a}.envelope-heart{font-size:28px;color:#c0392b;filter:drop-shadow(0 2px 4px rgba(192,57,43,.3));animation:heartbeat 1.5s ease-in-out infinite;z-index:1}@keyframes heartbeat{0%,to{transform:scale(1)}15%{transform:scale(1.15)}30%{transform:scale(1)}45%{transform:scale(1.1)}}.envelope-label{font-family:Caveat,cursive;font-size:1.2rem;color:#6b5b4a;z-index:1}.tap-hint{font-size:.8rem;color:#ffffff59;letter-spacing:1px;animation:hintFade 2s ease-in-out infinite}@keyframes hintFade{0%,to{opacity:.3}50%{opacity:.6}}.envelope-opening{z-index:10;display:flex;align-items:center;justify-content:center}.envelope-open-anim{animation:envelopeRise 1.2s ease-in-out forwards}.envelope-flap-open{animation:flapOpen .6s ease-out .2s forwards}@keyframes flapOpen{0%{transform:rotateX(0)}to{transform:rotateX(180deg)}}@keyframes envelopeRise{0%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:1}to{transform:scale(.5) translateY(-80px);opacity:0}}.letter-entrance{z-index:10;animation:letterSlideIn 1s ease-out;width:100%;max-height:100%;display:flex;justify-content:center;padding:24px 20px 40px;overflow:hidden}@keyframes letterSlideIn{0%{opacity:0;transform:translateY(60px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.letter-scene{width:100%;max-width:600px;max-height:100%;display:flex;flex-direction:column}.letter-paper{background:linear-gradient(180deg,#fdf8f0,#f8f0e3,#f5ead5);border-radius:8px;padding:36px 40px;box-shadow:0 4px 6px #0000000d,0 20px 60px #00000026,inset 0 1px #fffc;position:relative;opacity:0;transition:opacity .6s ease;max-height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:hidden}.letter-paper:before{content:"";position:absolute;inset:90px 36px 36px;background-image:repeating-linear-gradient(transparent,transparent 31px,rgba(176,160,140,.15) 31px,rgba(176,160,140,.15) 32px);pointer-events:none}.letter-paper:after{content:"";position:absolute;left:32px;top:0;bottom:0;width:1px;background:#c8505026;pointer-events:none}.letter-visible{opacity:1}.letter-header{text-align:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(176,160,140,.2)}.letter-date{font-family:Caveat,cursive;font-size:1rem;color:#9b8b7a}.letter-decoration{font-size:.9rem;color:#b08c7866;margin-top:6px;letter-spacing:8px}.letter-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:8px;scrollbar-width:thin;scrollbar-color:rgba(176,160,140,.3) transparent;-webkit-overflow-scrolling:touch}.letter-body::-webkit-scrollbar{width:4px}.letter-body::-webkit-scrollbar-track{background:transparent}.letter-body::-webkit-scrollbar-thumb{background:#b0a08c4d;border-radius:2px}.letter-greeting{font-family:Caveat,cursive;font-size:1.6rem;color:#5a4a3a;margin-bottom:20px}.letter-content{font-family:Caveat,cursive;font-size:1.35rem;line-height:2;color:#4a3f35;white-space:pre-wrap;word-wrap:break-word}.cursor-blink{font-family:Inter,sans-serif;font-weight:300;color:#8b7b6a;animation:blink .8s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.letter-signature{margin-top:32px;padding-top:20px;border-top:1px solid rgba(176,160,140,.2);text-align:right}.signature-line{font-family:Caveat,cursive;font-size:1.2rem;color:#7a6a5a}.signature-name{font-family:Caveat,cursive;font-size:1.8rem;color:#5a4a3a;margin-top:4px}.signature-hearts{font-size:1.1rem;margin-top:8px;animation:heartFloat 3s ease-in-out infinite}@keyframes heartFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.read-letter-btn{display:inline-flex;align-items:center;justify-content:center;position:relative;padding:14px 36px;border:none;border-radius:50px;background:linear-gradient(135deg,#c0392b,#e74c3c,#c0392b);background-size:200% 200%;color:#fff;font-family:Caveat,cursive;font-size:1.3rem;cursor:pointer;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 15px #c0392b4d;animation:btnGradient 3s ease infinite;margin-top:20px}@keyframes btnGradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.read-letter-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 25px #c0392b73}.btn-text{position:relative;z-index:1}.btn-glow{position:absolute;inset:-2px;border-radius:50px;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity .3s ease}.read-letter-btn:hover .btn-glow{opacity:1}.fade-in-up{animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.letter-entrance{padding:20px 16px 36px}.letter-paper{padding:28px 30px;max-height:calc(100vh - 72px)}.letter-paper:before{inset:85px 30px 28px}.letter-paper:after{left:26px}.letter-content{font-size:1.25rem}.letter-greeting{font-size:1.45rem}.moon{width:60px;height:60px;top:5%;right:8%}}@media(max-width:480px){.letter-entrance{padding:16px 12px 32px}.letter-paper{padding:20px 18px;border-radius:6px;max-height:calc(100vh - 64px)}.letter-paper:before{inset:72px 18px 20px}.letter-paper:after{left:14px}.letter-header{margin-bottom:16px;padding-bottom:12px}.letter-date{font-size:.9rem}.letter-decoration{font-size:.75rem;letter-spacing:6px}.letter-greeting{font-size:1.3rem;margin-bottom:14px}.letter-content{font-size:1.1rem;line-height:1.85}.letter-signature{margin-top:24px;padding-top:14px}.signature-line{font-size:1.05rem}.signature-name{font-size:1.5rem}.envelope{width:180px;height:120px}.envelope-flap{height:60px}.envelope-prompt{font-size:.95rem}.tap-hint{font-size:.7rem}.read-letter-btn{padding:12px 28px;font-size:1.15rem}.moon{width:45px;height:45px;top:3%;right:6%}}@media(max-width:360px){.letter-paper{padding:16px 14px;max-height:calc(100vh - 48px)}.letter-content{font-size:1rem;line-height:1.75}.letter-greeting{font-size:1.2rem}.envelope{width:160px;height:105px}.envelope-flap{height:52px}}@media(max-height:500px){.letter-entrance{padding:10px 16px 20px}.letter-paper{padding:16px 24px;max-height:calc(100vh - 40px)}.letter-header{margin-bottom:10px;padding-bottom:8px}.moon{width:35px;height:35px}}
