@import"https://fonts.googleapis.com/css2?family=Great+Vibes&family=Montserrat:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap";.scene-nav-button{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;border-radius:50%;background:linear-gradient(145deg,#ff4d88,#c90b3e);border:2px solid rgba(255,255,255,.2);box-shadow:0 10px 25px #ff4d8866;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;z-index:1000;transition:all .3s ease}.prev-mode{right:auto;left:2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:50px;height:50px;font-size:1.2rem;box-shadow:none;border-color:#ffffff26}.prev-mode:hover{background:#fff3;border-color:#ff4d88}@media(max-width:480px){.scene-nav-button{width:50px;height:50px;bottom:1.5rem;right:1.5rem;font-size:1.2rem}.prev-mode{width:40px;height:40px;bottom:1.5rem;left:1.5rem;font-size:1rem}}.scene-1-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;perspective:1000px;position:relative;z-index:10;padding-bottom:80px}.scene-1-content-wrapper{position:relative;text-align:center;transform-style:flat;z-index:20;width:100%}.scene-1-butterfly-container{position:absolute;top:-15vh;right:10vw;filter:drop-shadow(0 0 10px rgba(255,215,0,.5));z-index:5}.scene-1-butterfly-large{font-size:clamp(5rem,10vw,8rem);color:gold;animation:wing-flap .2s infinite alternate}.scene-1-title-3d{display:flex;justify-content:center;width:100%;padding:0 5%}.scene-1-char{display:inline-block;font-family:Great Vibes,cursive;font-size:30vw;line-height:1.1;color:#fff;text-shadow:0 0 5px rgba(255,183,197,.9),0 0 20px rgba(255,77,136,.6);transform-origin:bottom center;backface-visibility:hidden;-webkit-font-smoothing:subpixel-antialiased;will-change:transform,opacity}.scene-1-subtitle{margin-top:2rem;font-family:Montserrat,sans-serif;font-size:clamp(1.5rem,4vw,3rem);letter-spacing:2px;text-transform:uppercase;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.8);font-weight:500}@media(max-width:480px){.scene-1-butterfly-container{top:-80px;right:5px}.scene-1-subtitle{font-size:1.2rem;letter-spacing:1px;margin-top:3rem;padding:0 10px}}.scene-2-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:60px}.scene-2-3d-wrapper{display:flex;align-items:center;gap:3rem;width:90%;max-width:900px;justify-content:center}.scene-2-photo-card{position:relative;width:260px;background:#fff;padding:10px 10px 40px;box-shadow:0 15px 35px #00000080;transform-style:preserve-3d;flex-shrink:0}.scene-2-img{width:100%;height:300px;object-fit:cover;display:block}.scene-2-tape{position:absolute;top:-12px;left:50%;transform:translate(-50%);width:80px;height:25px;background:#ffffff80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 2px 4px #0003}.scene-2-chat-area{display:flex;flex-direction:column;gap:1.2rem;width:100%;max-width:350px;position:relative}.scene-2-bubble{padding:1rem;border-radius:18px;background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;gap:10px;box-shadow:0 5px 15px #0003;font-size:1rem;line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.8)}.scene-2-bubble.right{align-self:flex-end;background:#ff4d8833;border-color:#ff4d8866}.scene-2-mini-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #fff;flex-shrink:0}.scene-2-inline-icon{color:#ff4d88;margin-left:5px;vertical-align:middle}.scene-2-floating-emoji{position:absolute;top:-40px;right:10px;font-size:2.5rem;color:gold;filter:drop-shadow(0 0 10px rgba(0,0,0,.5))}@media(max-width:768px){.scene-2-3d-wrapper{flex-direction:column;gap:2rem}.scene-2-photo-card{width:200px;padding-bottom:30px}.scene-2-img{height:250px}.scene-2-chat-area{width:90%}}@media(max-width:320px){.scene-2-photo-card{width:160px}.scene-2-img{height:200px}.scene-2-bubble{font-size:.9rem;padding:.8rem}}.scene-3-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-3-wrapper{display:flex;flex-direction:column;align-items:center;gap:2.5rem;width:90%}.scene-3-record-container{filter:drop-shadow(0 15px 30px rgba(0,0,0,.6))}.scene-3-vinyl{width:250px;height:250px;border-radius:50%;background:#111;background:repeating-radial-gradient(#111 0 2px,#222 3px 4px);display:flex;align-items:center;justify-content:center;border:4px solid #000}.scene-3-label{width:90px;height:90px;border-radius:50%;overflow:hidden;border:2px solid #ff4d88}.scene-3-label img{width:100%;height:100%;object-fit:cover}.scene-3-visualizer{display:flex;align-items:flex-end;gap:8px;height:100px}.scene-3-bar{width:10px;background:#ff4d88;border-radius:5px;box-shadow:0 0 10px #ff4d88}.scene-3-text-box{display:flex;align-items:center;gap:12px;font-size:1.8rem;font-family:Playfair Display,serif;color:#fff;text-align:center;text-shadow:0 2px 5px rgba(0,0,0,.8)}.scene-3-note-icon{color:gold;animation:float 3s infinite ease-in-out;flex-shrink:0}@media(max-width:480px){.scene-3-vinyl{width:200px;height:200px}.scene-3-label{width:70px;height:70px}.scene-3-text-box{font-size:1.4rem;flex-direction:column;gap:8px}}@media(max-width:320px){.scene-3-vinyl{width:160px;height:160px}.scene-3-text-box{font-size:1.2rem}}.scene-4-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:60px}.scene-4-content{position:relative;display:flex;flex-direction:column;align-items:center}.scene-4-polaroid{background:#fff;padding:12px 12px 50px;width:280px;box-shadow:0 10px 30px #0009;transform-origin:top center;position:relative;z-index:2}.scene-4-polaroid img{width:100%;height:280px;object-fit:cover;filter:contrast(1.05) brightness(1.05)}.scene-4-caption{position:absolute;bottom:10px;width:100%;text-align:center;left:0;font-family:Great Vibes,cursive;font-size:2rem;color:#333}.scene-4-pin{width:16px;height:16px;background:#c90b3e;border-radius:50%;position:absolute;top:-8px;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0006;z-index:5}.scene-4-emojis{position:absolute;top:50%;left:50%;width:0;height:0;overflow:visible}.scene-4-floating-icon{position:absolute;top:-50px;font-size:3rem;color:gold;filter:drop-shadow(0 0 8px rgba(255,100,100,.6))}@media(max-width:480px){.scene-4-polaroid{width:220px;padding-bottom:40px}.scene-4-polaroid img{height:220px}.scene-4-caption{font-size:1.6rem}.scene-4-floating-icon{font-size:2.5rem}}.scene-5-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-5-map-wrapper{position:relative;width:95%;max-width:800px;height:auto;aspect-ratio:16 / 9;display:flex;justify-content:center}.scene-5-svg{width:100%;height:100%;overflow:visible}.scene-5-marker{position:absolute;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;z-index:20}.scene-5-marker.left{left:0}.scene-5-marker.right{right:0}.scene-5-img-container{width:130px;height:130px;border-radius:50%;border:4px solid #fff;box-shadow:0 0 25px #ff4d88;overflow:hidden;margin-bottom:10px;background:#000}.scene-5-img-container img{width:100%;height:100%;object-fit:cover}.scene-5-pin-icon{color:#ff4d88;font-size:3rem;filter:drop-shadow(0 0 10px rgba(0,0,0,.8))}.scene-5-text{position:absolute;bottom:-80px;width:100%;text-align:center;font-family:Montserrat,sans-serif;font-weight:500;letter-spacing:1px;color:#fff;font-size:clamp(2rem,5vw,4rem);text-shadow:0 4px 10px rgba(0,0,0,.9);white-space:nowrap}@media(max-width:768px){.scene-5-img-container{width:100px;height:100px}.scene-5-pin-icon{font-size:2.5rem}}@media(max-width:480px){.scene-5-map-wrapper{width:100%;margin-top:-50px}.scene-5-img-container{width:90px;height:90px;border-width:3px}.scene-5-pin-icon{font-size:2rem}.scene-5-text{font-size:1.6rem;bottom:-120px;white-space:normal;padding:0 10px}.scene-5-marker.left{left:10px}.scene-5-marker.right{right:10px}}.scene-6-container{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-6-sky{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.scene-6-star{position:absolute;color:#fff;filter:drop-shadow(0 0 5px #fff)}.scene-6-couple-silhouette{width:250px;height:250px;filter:drop-shadow(0 0 15px rgba(255,255,255,.6))}.scene-6-svg{width:100%;height:100%;overflow:visible}.scene-6-text{margin-top:1.5rem;font-family:Great Vibes,cursive;font-size:3rem;color:#fff;text-shadow:0 0 10px #a080ff;text-align:center;z-index:20;padding:0 20px}@media(max-width:480px){.scene-6-couple-silhouette{width:200px;height:200px}.scene-6-text{font-size:2.2rem}}.scene-7-container{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-7-center-piece{position:relative;width:280px;height:280px;display:flex;align-items:center;justify-content:center}.scene-7-photo-ring{width:130px;height:130px;border-radius:50%;overflow:hidden;border:4px solid #ffb7c5;box-shadow:0 0 25px #ff4d88;z-index:10;position:relative}.scene-7-photo-ring img{width:100%;height:100%;object-fit:cover}.scene-7-orbit-icon{position:absolute;width:100%;height:100%;top:0;left:0}.scene-7-icon-wrapper{position:absolute;top:0;left:50%;transform:translate(-50%);font-size:1.8rem;color:gold;background:#ffffff26;padding:12px;border-radius:50%;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 0 10px #ffd70066}.scene-7-title{margin-top:3rem;font-family:Playfair Display,serif;font-size:2.5rem;color:#fff;text-shadow:0 0 20px #ff4d88;text-align:center}@media(max-width:480px){.scene-7-center-piece{width:240px;height:240px}.scene-7-photo-ring{width:110px;height:110px}.scene-7-title{font-size:2rem;margin-top:2rem}.scene-7-icon-wrapper{font-size:1.5rem;padding:10px}}.scene-8-container{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-8-loader{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}.scene-8-svg{transform:rotate(-90deg);width:100%;height:100%}.scene-8-number{position:absolute;font-size:2rem;font-weight:700;color:#fff;text-shadow:0 0 20px #ff4d88}.scene-8-text{margin-top:2rem;font-size:1.6rem;letter-spacing:3px;text-transform:uppercase;color:#ddd;text-shadow:0 1px 3px #000}@media(max-width:480px){.scene-8-loader{width:160px;height:160px}.scene-8-number{font-size:2rem}.scene-8-text{font-size:1.6rem}}.scene-9-container{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-9-clock-face{width:280px;height:280px;border-radius:50%;border:4px solid #ffd700;position:relative;box-shadow:0 0 40px #ffd7004d;overflow:hidden}.scene-9-bg{width:100%;height:100%;object-fit:cover;opacity:.6}.scene-9-hand{position:absolute;bottom:50%;left:50%;background:#fff;transform-origin:bottom center;border-radius:5px;box-shadow:0 0 5px #00000080}.scene-9-hand.hour{width:6px;height:70px;background:#ff4d88;margin-left:-3px;z-index:5}.scene-9-hand.minute{width:4px;height:100px;background:#fff;margin-left:-2px;z-index:4}.scene-9-center-dot{position:absolute;top:50%;left:50%;width:16px;height:16px;background:gold;border-radius:50%;transform:translate(-50%,-50%);z-index:10}.scene-9-title{margin-top:3rem;font-family:Great Vibes,cursive;font-size:2.5rem;color:#fff;text-shadow:0 0 10px rgba(255,255,255,.5);text-align:center}@media(max-width:480px){.scene-9-clock-face{width:240px;height:240px}.scene-9-title{font-size:2rem}}.scene-10-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;padding-bottom:80px}.scene-10-proposal-box{width:90%;max-width:600px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.scene-10-question{font-family:Great Vibes,cursive;font-size:clamp(3rem,10vw,5rem);margin-bottom:3rem;color:#fff;text-shadow:0 0 20px #ff4d88;line-height:1.2}.scene-10-buttons{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.scene-10-btn{padding:1rem 3rem;font-size:1.5rem;border-radius:50px;font-weight:700;display:flex;align-items:center;gap:10px;transition:all .3s;cursor:pointer}.scene-10-btn.yes{background:#ff4d88;color:#fff;box-shadow:0 0 20px #ff4d8899;border:2px solid transparent}.scene-10-btn.no{background:#ffffff1a;border:2px solid #555;color:#ccc}.scene-10-success{text-align:center;color:#fff;display:flex;flex-direction:column;align-items:center}.scene-10-success h1{font-family:Playfair Display,serif;font-size:2.5rem;margin-top:1rem}.scene-10-giant-heart{font-size:8rem;color:#ff4d88;animation:heartBeat 1s infinite;filter:drop-shadow(0 0 20px #ff4d88)}.scene-10-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.scene-10-modal{background:#fff;color:#333;padding:2rem;border-radius:20px;text-align:center;max-width:350px;width:100%;box-shadow:0 10px 40px #00000080}.scene-10-modal-icon{font-size:3rem;color:#333;margin-bottom:1rem}.scene-10-modal h3{margin-bottom:1rem;font-size:1.5rem}.scene-10-modal p{margin-bottom:1.5rem;line-height:1.4}.scene-10-modal button{background:#ff4d88;color:#fff;padding:.8rem 2rem;border-radius:8px;font-size:1rem;font-weight:700}@media(max-width:480px){.scene-10-question{margin-bottom:2rem}.scene-10-btn{padding:.8rem 2rem;font-size:1.2rem}.scene-10-giant-heart{font-size:6rem}}.music-toggle-button{position:fixed;top:1.5rem;right:1.5rem;width:50px;height:50px;border-radius:50%;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,100,150,.3);box-shadow:0 5px 15px #0000004d;z-index:1000;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;transition:all .3s}.music-toggle-button:hover{transform:scale(1.1);background:#ff326433;border-color:#ff4d88}.beating-heart{color:#ff4d88;animation:heartBeat 1.5s infinite}@keyframes heartBeat{0%{transform:scale(1)}15%{transform:scale(1.2)}30%{transform:scale(1)}45%{transform:scale(1.2)}to{transform:scale(1)}}@media(max-width:480px){.music-toggle-button{width:40px;height:40px;top:1rem;right:1rem;font-size:1rem}}:root{--primary-pink: #ff4d88;--soft-pink: #ffb7c5;--deep-red: #c90b3e;--gold: #ffd700;--cream: #fff9f0}*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Montserrat,sans-serif;overflow:hidden;height:100vh;width:100vw;background:#000;color:var(--cream);perspective:1000px}#root{height:100%;width:100%;position:relative;overflow:hidden}button{cursor:pointer;border:none;outline:none;font-family:inherit;-webkit-tap-highlight-color:transparent}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-15px) rotate(3deg)}}@keyframes wing-flap{0%,to{transform:rotateY(0)}50%{transform:rotateY(50deg)}}
