@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Dancing+Script:wght@400;600&display=swap";:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#000;overflow-x:hidden}#root{width:100%;min-height:100vh}a{font-weight:500;color:#fff;text-decoration:none;transition:color .3s ease}a:hover{color:#ccc}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:all .3s ease}button:hover{border-color:#fff;background-color:#2a2a2a}button:focus,button:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1a1a1a);position:relative;overflow:hidden;cursor:pointer;transition:background .3s ease}.hero:active{background:linear-gradient(135deg,#1a1a1a,#3d2d3d,#1a1a1a)}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.08) 0%,transparent 50%),radial-gradient(circle at 50% 20%,rgba(255,200,200,.05) 0%,transparent 60%);animation:shimmer 8s infinite}@keyframes shimmer{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.hearts-container,.sparkles-container,.particles-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.particle{position:absolute;background:radial-gradient(circle,rgba(255,200,220,.8),transparent);border-radius:50%;animation:particleFloat infinite ease-in-out;opacity:0}@keyframes particleFloat{0%,to{transform:translateY(0) translate(0) scale(1);opacity:0}10%{opacity:1}50%{transform:translateY(-100vh) translate(20px) scale(1.5);opacity:.8}90%{opacity:.3}}.parallax-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;transition:transform .3s ease-out}.glow-orb{position:absolute;border-radius:50%;filter:blur(60px);animation:orbPulse 8s ease-in-out infinite}.orb-1{width:300px;height:300px;top:20%;left:10%;background:radial-gradient(circle,rgba(255,200,220,.3),transparent);animation-delay:0s}.orb-2{width:400px;height:400px;top:60%;right:10%;background:radial-gradient(circle,rgba(200,220,255,.2),transparent);animation-delay:2s}.orb-3{width:250px;height:250px;bottom:10%;left:50%;background:radial-gradient(circle,rgba(255,220,200,.25),transparent);animation-delay:4s}@keyframes orbPulse{0%,to{transform:scale(1) translateY(0);opacity:.5}50%{transform:scale(1.2) translateY(-30px);opacity:.8}}.sparkle{position:absolute;font-size:16px;animation:sparkleFloat 3s ease-in-out forwards;opacity:0}@keyframes sparkleFloat{0%{transform:translateY(0) scale(0) rotate(0);opacity:0}20%{opacity:1}80%{opacity:1}to{transform:translateY(-50px) scale(1.5) rotate(180deg);opacity:0}}.floating-heart{position:absolute;bottom:-50px;animation:floatUp 10s ease-in-out forwards;opacity:0;filter:drop-shadow(0 0 8px rgba(255,100,150,.6))}@keyframes floatUp{0%{transform:translateY(0) translate(0) rotate(0) scale(.5);opacity:0}10%{opacity:1;transform:translateY(-10vh) translate(0) rotate(20deg) scale(1)}30%{transform:translateY(-30vh) translate(20px) rotate(-15deg) scale(1.1)}50%{transform:translateY(-50vh) translate(-15px) rotate(25deg) scale(.9)}70%{transform:translateY(-70vh) translate(25px) rotate(-20deg) scale(1.2)}90%{opacity:1}to{transform:translateY(-110vh) translate(0) rotate(360deg) scale(.3);opacity:0}}.hero-content{text-align:center;z-index:2;padding:2rem;transition:transform .3s ease}.hero-content.hovered{transform:scale(1.02)}.click-hearts-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:3}.click-heart{position:absolute;font-size:24px;animation:burstHeart 2s ease-out forwards;opacity:0;pointer-events:none;filter:drop-shadow(0 0 10px rgba(255,100,150,.8))}@keyframes burstHeart{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}10%{opacity:1}to{transform:translate(calc(-50% + cos(var(--angle))*150px),calc(-50% + sin(var(--angle))*150px)) scale(1.5) rotate(360deg);opacity:0}}.title-animation{display:flex;flex-direction:column;gap:1rem;animation:fadeInUp 1.5s ease-out}.for-my{font-size:2rem;color:#fff;font-weight:300;letter-spacing:.3em;text-transform:uppercase;opacity:.9}.name{font-size:6rem;font-weight:700;background:linear-gradient(45deg,#fff,#fcd,#fff,#ddf,#fff);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s ease infinite,textGlow 2s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(255,255,255,.4));position:relative;cursor:pointer;transition:transform .3s ease}.name:hover{transform:scale(1.05);animation:gradientShift 2s ease infinite,textGlow 1s ease-in-out infinite}.name:before{content:attr(data-text);position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%);-webkit-background-clip:text;background-clip:text;animation:shimmerMove 3s ease-in-out infinite}@keyframes shimmerMove{0%{transform:translate(-100%);opacity:0}50%{opacity:1}to{transform:translate(100%);opacity:0}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes textGlow{0%,to{filter:drop-shadow(0 0 10px rgba(255,255,255,.3))}50%{filter:drop-shadow(0 0 30px rgba(255,200,220,.8))}}.subtitle{font-size:1.8rem;color:#e0e0e0;font-weight:300;font-style:italic;animation:fadeIn 2s ease-out .3s both,float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.tagline{font-size:1.5rem;color:#ccc;margin-top:2rem;font-weight:300;animation:fadeIn 2s ease-out .5s both,pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.scroll-indicator{margin-top:4rem;color:#999;animation:fadeIn 2s ease-out 1s both}.scroll-indicator span{display:block;margin-bottom:1rem;font-size:.9rem;letter-spacing:.1em}.scroll-arrow{font-size:2rem;animation:bounce 2s infinite}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media(max-width:768px){.hero{padding-bottom:4rem}.hero-content{padding:1.5rem}.for-my{font-size:1rem;letter-spacing:.2em}.name{font-size:3rem}.subtitle{font-size:1rem}.tagline{font-size:1rem;margin-top:1.5rem}.scroll-indicator{margin-top:3rem}.scroll-indicator span{font-size:.8rem}}.love-letter{min-height:100vh;background:linear-gradient(180deg,#2d2d2d,#1a1a1a,#0a0a0a);padding:6rem 2rem;display:flex;align-items:center;justify-content:center}.letter-container{max-width:900px;margin:0 auto}.section-title{font-size:3rem;text-align:center;color:#fff;margin-bottom:3rem;font-weight:300;letter-spacing:.1em;animation:fadeInDown 1s ease-out}.envelope-container{display:flex;flex-direction:column;align-items:center;margin-bottom:3rem}.envelope{position:relative;width:300px;height:200px;transition:all .8s ease}.envelope-body{position:absolute;bottom:0;width:100%;height:150px;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border:2px solid #cccccc;box-shadow:0 10px 40px #0000004d;animation:envelopeGlow 3s ease-in-out infinite}@keyframes envelopeGlow{0%,to{box-shadow:0 10px 40px #0000004d}50%{box-shadow:0 10px 50px #ffc8dc66,0 0 30px #ffc8dc4d}}.envelope-flap{position:absolute;top:0;width:100%;height:100px;background:linear-gradient(135deg,#fff,#f0f0f0);border:2px solid #cccccc;border-bottom:none;clip-path:polygon(0 0,50% 100%,100% 0);transform-origin:top center;transition:transform 1s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 5px 20px #0003;z-index:2;animation:flapWiggle 2s ease-in-out infinite}@keyframes flapWiggle{0%,to{transform:rotateX(0)}50%{transform:rotateX(-5deg)}}.envelope.open .envelope-flap{transform:rotateX(180deg);animation:none}.envelope.open{transform:translateY(-20px) scale(1.05);transition:transform .8s ease}.reveal-button{margin-top:2rem;padding:1rem 2.5rem;font-size:1.1rem;color:#fff;background:linear-gradient(135deg,#333,#1a1a1a);border:2px solid #666666;border-radius:50px;cursor:pointer;transition:all .3s ease;animation:buttonPulse 2s ease-in-out infinite;position:relative;overflow:hidden}.reveal-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.reveal-button:hover:before{width:300px;height:300px}.reveal-button:hover{transform:scale(1.08);box-shadow:0 5px 40px #ffc8dc66;background:linear-gradient(135deg,#1a1a1a,#000);border-color:#fff}@keyframes buttonPulse{0%,to{box-shadow:0 0 #fff6;transform:scale(1)}50%{box-shadow:0 0 30px 15px #ffc8dc00;transform:scale(1.03)}}.letter-content{opacity:0;transform:translateY(50px) scale(.95);transition:all 1.2s cubic-bezier(.68,-.55,.265,1.55) .5s;pointer-events:none}.letter-content.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:all;animation:letterFloat 4s ease-in-out infinite}@keyframes letterFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1)}}.letter-paper{background:linear-gradient(135deg,#fff,#fff5f8,#f8f8f8);padding:3rem;border-radius:10px;box-shadow:0 20px 60px #0000004d,inset 0 0 100px #ffc8dc1a,0 0 50px #ffc8dc33;position:relative;color:#1a1a1a;line-height:1.8;border:1px solid rgba(255,200,220,.3)}.letter-paper:before{content:"";position:absolute;top:0;left:50px;right:50px;height:1px;background:repeating-linear-gradient(90deg,transparent,transparent 5px,rgba(0,0,0,.1) 5px,rgba(0,0,0,.1) 10px)}.letter-paper h3{font-size:2rem;margin-bottom:1.5rem;color:#000;font-family:Dancing Script,cursive;font-weight:600}.letter-paper p{margin-bottom:1.5rem;font-size:1.15rem;text-align:justify;font-family:Cormorant Garamond,serif;line-height:1.9;letter-spacing:.3px}.letter-paper strong{color:#000;font-weight:600;font-family:Playfair Display,serif}.closing{margin-top:3rem;font-style:italic;text-align:right;font-family:Cormorant Garamond,serif}.signature{font-family:Dancing Script,cursive;font-size:1.8rem;color:#000;display:block;margin-top:.5rem;font-weight:600}.heart-seal{position:absolute;bottom:2rem;right:3rem;font-size:2rem;animation:heartbeat 1.5s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,100,150,.6))}@keyframes heartbeat{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.3) rotate(-5deg)}50%{transform:scale(1) rotate(0)}75%{transform:scale(1.3) rotate(5deg)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.love-letter{padding:4rem 1rem}.section-title{font-size:1.8rem;padding:0 1rem}.envelope{width:220px;height:150px}.envelope-body{height:110px}.envelope-flap{height:75px}.reveal-button{padding:.8rem 2rem;font-size:1rem}.letter-paper{padding:1.5rem 1rem;margin:0 .5rem}.letter-paper h3{font-size:1.5rem}.letter-paper p{font-size:1rem;line-height:1.8;text-align:left}.closing{margin-top:2rem}.signature{font-size:1.5rem}.heart-seal{bottom:1rem;right:1.5rem;font-size:1.5rem}}.timeline{min-height:100vh;background:linear-gradient(180deg,#0a0a0a,#1a1a1a,#2d2d2d);padding:6rem 2rem;position:relative}.timeline .section-title{font-size:3rem;text-align:center;color:#fff;margin-bottom:4rem;font-weight:300;letter-spacing:.1em}.timeline-container{max-width:1200px;margin:0 auto;position:relative;padding:2rem 0}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(180deg,transparent 0%,#ffffff 10%,#ffccdd 50%,#ffffff 90%,transparent 100%);transform:translate(-50%);box-shadow:0 0 20px #ffc8dc80;animation:lineGlow 3s ease-in-out infinite}@keyframes lineGlow{0%,to{box-shadow:0 0 15px #ffc8dc66;opacity:.8}50%{box-shadow:0 0 30px #ffc8dccc;opacity:1}}.timeline-item{display:flex;justify-content:flex-start;padding:2rem 0;position:relative;opacity:0;transform:translateY(80px) scale(.9);transition:all 1s cubic-bezier(.68,-.55,.265,1.55)}.timeline-item.visible{opacity:1;transform:translateY(0) scale(1)}.timeline-item.left{justify-content:flex-end}.timeline-item.left .timeline-content{text-align:right;margin-right:3rem}.timeline-item.right .timeline-content{text-align:left;margin-left:3rem}.timeline-content{width:calc(50% - 4rem);background:linear-gradient(135deg,#ffffff1f,#ffc8dc14,#ffffff0d);padding:2rem;border-radius:15px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;transition:all .4s ease;box-shadow:0 5px 20px #ffc8dc1a}.timeline-content:hover{transform:scale(1.08) translateY(-5px);box-shadow:0 15px 50px #ffc8dc4d,0 0 40px #ffc8dc33;border-color:#ffc8dc99;background:linear-gradient(135deg,#ffffff26,#ffc8dc1f,#ffffff14)}.timeline-item.special .timeline-content{background:linear-gradient(135deg,#ffffff40,#ffc8dc33,#ffffff26);border:2px solid rgba(255,200,220,.6);box-shadow:0 0 40px #ffc8dc66,inset 0 0 40px #ffc8dc1a;animation:specialGlow 3s ease-in-out infinite}@keyframes specialGlow{0%,to{box-shadow:0 0 30px #ffc8dc66,inset 0 0 30px #ffc8dc1a}50%{box-shadow:0 0 60px #ffc8dc99,inset 0 0 50px #ffc8dc33}}.timeline-icon{font-size:3rem;margin-bottom:1rem;animation:iconBounce 3s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,200,220,.6))}@keyframes iconBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-15px) scale(1.1)}}.timeline-year{font-size:1.2rem;color:#ccc;font-weight:600;margin-bottom:.5rem;display:flex;flex-direction:column;gap:.3rem}.timeline-time{font-size:1rem;color:#fff;font-weight:400}.timeline-content h3{font-size:1.8rem;color:#fff;margin-bottom:1rem;font-weight:500}.timeline-content p{font-size:1.1rem;color:#e0e0e0;line-height:1.6}.timeline-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:radial-gradient(circle,#fff,#fcd);border:4px solid #1a1a1a;border-radius:50%;z-index:2;transition:all .4s ease;box-shadow:0 0 15px #ffc8dc66;animation:dotPulse 2s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 10px #ffc8dc66}50%{box-shadow:0 0 25px #ffc8dccc}}.timeline-item:hover .timeline-dot{width:30px;height:30px;box-shadow:0 0 40px #ffc8dc;background:radial-gradient(circle,#fff,#fac)}.timeline-item.special .timeline-dot{width:30px;height:30px;background:radial-gradient(circle,#fff,#fac,#f8b);box-shadow:0 0 40px #ff96b4cc;animation:specialDotPulse 1.5s ease-in-out infinite;border-color:#ffc8dc80}@keyframes specialDotPulse{0%,to{box-shadow:0 0 30px #ff96b4cc;transform:translate(-50%,-50%) scale(1)}50%{box-shadow:0 0 60px #ff6496,0 0 90px #ff96b499;transform:translate(-50%,-50%) scale(1.2)}}@media(max-width:768px){.timeline{padding:4rem 1rem}.timeline-line{left:25px}.timeline-item,.timeline-item.left{justify-content:flex-start;padding:1.5rem 0}.timeline-content,.timeline-item.left .timeline-content,.timeline-item.right .timeline-content{width:calc(100% - 60px);margin-left:50px;margin-right:0;text-align:left;padding:1.5rem}.timeline-dot{left:25px}.timeline .section-title{font-size:1.8rem;padding:0 1rem}.timeline-icon{font-size:2rem}.timeline-year{font-size:1rem}.timeline-time{font-size:.9rem}.timeline-content h3{font-size:1.2rem}.timeline-content p{font-size:.95rem;line-height:1.6}}.gallery{min-height:100vh;background:linear-gradient(180deg,#2d2d2d,#1a1a1a,#2d2d2d);padding:6rem 2rem;position:relative;overflow:hidden}.gallery:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(255,200,220,.05) 0%,transparent 70%);animation:galleryGlow 8s ease-in-out infinite}@keyframes galleryGlow{0%,to{opacity:.5}50%{opacity:1}}.gallery .section-title{font-size:3rem;text-align:center;color:#fff;margin-bottom:1rem;font-weight:300;letter-spacing:.1em;animation:titleGlow 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(255,200,220,.4));position:relative;z-index:1}@keyframes titleGlow{0%,to{filter:drop-shadow(0 0 15px rgba(255,200,220,.3))}50%{filter:drop-shadow(0 0 30px rgba(255,200,220,.6))}}.gallery-subtitle{text-align:center;color:#ccc;font-size:1.2rem;margin-bottom:4rem;animation:fadeIn 1.5s ease-out .3s both;position:relative;z-index:1}.gallery-grid{max-width:600px;margin:0 auto;display:flex;justify-content:center;padding:2rem 1rem}.gallery-item{opacity:0;transform:translateY(50px) scale(.85);transition:all 1s cubic-bezier(.68,-.55,.265,1.55);cursor:pointer;max-width:400px;width:100%;position:relative;z-index:1}.gallery-item.visible{opacity:1;transform:translateY(0) scale(1);animation:itemFloat 4s ease-in-out infinite}@keyframes itemFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1)}}.gallery-image-container{position:relative;width:100%;padding-bottom:100%;overflow:hidden;border-radius:15px;background:#333;box-shadow:0 10px 30px #00000080,0 0 40px #ffc8dc33;border:2px solid rgba(255,200,220,.3);transition:all .4s ease}.gallery-image-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,200,220,.1) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;z-index:1;pointer-events:none}.gallery-image-container img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.68,-.55,.265,1.55);filter:brightness(.95)}.gallery-item:hover .gallery-image-container{box-shadow:0 20px 50px #000000b3,0 0 60px #ffc8dc80;border-color:#ffc8dccc;transform:translateY(-10px)}.gallery-item:hover .gallery-image-container:before{opacity:1}.gallery-item:hover .gallery-image-container img{transform:scale(1.15) rotate(2deg);filter:brightness(1.05)}.gallery-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#ff64964d,#000000b3,#ff64964d);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;z-index:2}.gallery-item:hover .gallery-overlay{opacity:1}.view-text{color:#fff;font-size:1.2rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;filter:drop-shadow(0 0 10px rgba(255,200,220,.8));animation:textPulse 2s ease-in-out infinite}@keyframes textPulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 10px rgba(255,200,220,.6))}50%{transform:scale(1.05);filter:drop-shadow(0 0 20px rgba(255,200,220,1))}}.gallery-caption{padding:1.5rem 0;text-align:center;transition:all .3s ease}.gallery-item:hover .gallery-caption{transform:translateY(-5px)}.gallery-caption h3{color:#fff;font-size:1.3rem;margin-bottom:.5rem;font-weight:500;transition:all .3s ease}.gallery-item:hover .gallery-caption h3{color:#fcd;filter:drop-shadow(0 0 10px rgba(255,200,220,.6))}.gallery-caption p{color:#ccc;font-size:1rem;font-style:italic;transition:all .3s ease}.gallery-item:hover .gallery-caption p{color:#fde}.lightbox{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease;padding:2rem}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;animation:zoomIn .3s ease}.lightbox-content img{width:100%;height:auto;max-height:70vh;object-fit:contain;border-radius:10px;box-shadow:0 20px 60px #000c}.close-button{position:absolute;top:-50px;right:0;background:#ffffff1a;border:2px solid #ffffff;color:#fff;font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#fff;color:#000;transform:rotate(90deg)}.lightbox-info{text-align:center;margin-top:1.5rem;color:#fff}.lightbox-info h3{font-size:1.5rem;margin-bottom:.5rem}.lightbox-info p{font-size:1.1rem;color:#ccc;font-style:italic}.loading-message{max-width:600px;margin:3rem auto 0;padding:1.5rem;text-align:center;position:relative;z-index:1}.loading-message p{color:#ccc;font-size:1.1rem;font-style:italic;margin:0;animation:messageFade 3s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,200,220,.3))}@keyframes messageFade{0%,to{opacity:.7;filter:drop-shadow(0 0 5px rgba(255,200,220,.2))}50%{opacity:1;filter:drop-shadow(0 0 15px rgba(255,200,220,.5))}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.gallery{padding:4rem 1rem}.gallery .section-title{font-size:2rem;padding:0 1rem}.gallery-subtitle{font-size:1rem;padding:0 1rem}.gallery-grid{padding:2rem .5rem}.gallery-item{max-width:100%}.lightbox-content{max-width:95vw}.close-button{top:-60px;width:40px;height:40px;font-size:1.5rem}.loading-message{padding:1rem}.loading-message p{font-size:1rem}}.music-player{position:fixed;bottom:1rem;right:1rem;z-index:1000;animation:slideInRight .5s ease-out}.play-button-compact{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#fffffff2,#ffc8dcb3);border:2px solid rgba(255,200,220,.4);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#000;font-weight:700}.play-button-compact:hover:not(:disabled){transform:scale(1.1);box-shadow:0 6px 20px #ffc8dc4d;border-color:#ffc8dc99}.play-button-compact:disabled{opacity:.5;cursor:not-allowed}.play-button-compact.playing{animation:musicPulse 2s infinite;background:linear-gradient(135deg,#fff,#ffc8dce6);border-color:#ffc8dc99}@keyframes musicPulse{0%,to{box-shadow:0 4px 15px #ffc8dc33;transform:scale(1)}50%{box-shadow:0 6px 25px #ffc8dc80;transform:scale(1.05)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.music-player{bottom:1rem;right:1rem}.play-button-compact{width:45px;height:45px;font-size:1rem}}*{margin:0;padding:0;box-sizing:border-box}.app{width:100%;overflow-x:hidden;background:#000;position:relative;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.global-click-hearts{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:9999}.global-heart{position:absolute;font-size:28px;animation:globalBurstHeart 2s ease-out forwards;opacity:0;pointer-events:none;filter:drop-shadow(0 0 10px rgba(255,100,150,.8))}@keyframes globalBurstHeart{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}10%{opacity:1}to{transform:translate(calc(-50% + cos(var(--angle))*200px),calc(-50% + sin(var(--angle))*200px)) scale(1.8) rotate(720deg);opacity:0}}@media(max-width:768px){.global-heart{font-size:24px}@keyframes globalBurstHeart{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}10%{opacity:1}to{transform:translate(calc(-50% + cos(var(--angle))*120px),calc(-50% + sin(var(--angle))*120px)) scale(1.5) rotate(720deg);opacity:0}}}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.footer{background:linear-gradient(180deg,#1a1a1a,#000,#0a0a0a);padding:3rem 2rem 5rem;text-align:center;border-top:2px solid rgba(255,200,220,.2);position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:200%;height:100%;background:radial-gradient(circle at 50% 0%,rgba(255,200,220,.1) 0%,transparent 50%);animation:footerGlow 6s ease-in-out infinite}@keyframes footerGlow{0%,to{opacity:.5}50%{opacity:1}}.footer-content{max-width:800px;margin:0 auto;position:relative;z-index:1}.footer-message{font-size:1.5rem;color:#fff;margin-bottom:1rem;font-weight:300;animation:footerMessageGlow 3s ease-in-out infinite;filter:drop-shadow(0 0 15px rgba(255,200,220,.4))}@keyframes footerMessageGlow{0%,to{filter:drop-shadow(0 0 10px rgba(255,200,220,.3))}50%{filter:drop-shadow(0 0 25px rgba(255,200,220,.6))}}.footer-date{font-size:1rem;color:#fcd;font-style:italic;animation:dateFade 4s ease-in-out infinite;margin-bottom:2rem}@keyframes dateFade{0%,to{opacity:.8}50%{opacity:1}}.countdown{margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,200,220,.2)}.countdown-title{font-size:1.2rem;color:#fcd;margin-bottom:1.5rem;font-weight:300;letter-spacing:1px}.countdown-timer{display:flex;justify-content:center;align-items:center;gap:.5rem;flex-wrap:wrap}.countdown-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.countdown-value{font-size:2.5rem;font-weight:700;color:#fff;text-shadow:0 0 20px rgba(255,200,220,.6);animation:countPulse 2s ease-in-out infinite;min-width:60px;text-align:center}@keyframes countPulse{0%,to{text-shadow:0 0 20px rgba(255,200,220,.6)}50%{text-shadow:0 0 30px rgba(255,200,220,1)}}.countdown-label{font-size:.8rem;color:#fcd;text-transform:uppercase;letter-spacing:1px;opacity:.8}.countdown-separator{font-size:2rem;color:#fcd;margin:0 .5rem;animation:separatorBlink 1s ease-in-out infinite}@keyframes separatorBlink{0%,to{opacity:1}50%{opacity:.3}}.last-updated{text-align:center;margin-top:2rem;font-size:.75rem;color:#fff6;font-family:monospace;letter-spacing:.5px}@media(max-width:768px){.footer{padding:2.5rem 1.5rem 4rem}.footer-message{font-size:1.2rem}.footer-date{font-size:.9rem;margin-bottom:1.5rem}.countdown-title{font-size:1rem}.countdown-value{font-size:1.8rem;min-width:45px}.countdown-label{font-size:.65rem}.countdown-separator{font-size:1.5rem;margin:0 .25rem}.last-updated{font-size:.7rem}}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#1a1a1a;border-left:1px solid rgba(255,200,220,.1)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#fcd,#f9b,#888);border-radius:6px;border:2px solid #1a1a1a;box-shadow:0 0 10px #ffc8dc66}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#fff,#fac,#666);box-shadow:0 0 20px #ffc8dc99}::selection{background:#ffc8dc4d;color:#fff;text-shadow:0 0 10px rgba(255,200,220,.5)}::-moz-selection{background:#ffc8dc4d;color:#fff;text-shadow:0 0 10px rgba(255,200,220,.5)}
