.app{position:relative;width:100%;min-height:100vh;overflow:hidden}.progress-indicator{position:fixed;top:0;left:0;width:100%;height:3px;background:#fff3;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.progress-bar{height:100%;background:linear-gradient(90deg,#ff69b4,#ff1493,pink);transition:width .3s ease;box-shadow:0 0 10px #ff69b480}.progress-text{position:fixed;top:10px;right:15px;font-size:11px;color:#ff69b4cc;font-weight:600;z-index:101;text-shadow:0 1px 3px rgba(0,0,0,.1);letter-spacing:.5px;padding:4px 10px;background:#ffffff4d;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 768px){.progress-indicator{height:2px}.progress-text{font-size:10px;top:8px;right:10px;padding:3px 8px}}.background-gradient{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#fef5f1,#ffe4e1,pink,#ffb6c1,#fef5f1);background-size:400% 400%;animation:gradientShift 30s ease infinite,initialFlash 1.5s ease-out;z-index:0}@keyframes initialFlash{0%{filter:brightness(1) saturate(1)}40%{filter:brightness(1.6) saturate(1.8) hue-rotate(-10deg)}to{filter:brightness(1) saturate(1)}}.scroll-container{position:relative;width:100%;height:100vh;overflow-y:scroll;overflow-x:hidden;scroll-snap-type:y proximity;z-index:10;perspective:1000px}.scenes-wrapper{position:relative;width:100%;min-height:100vh;padding:100px 20px}.scene-block{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;scroll-snap-align:center;transform-style:preserve-3d}@media (max-width: 768px){.scene-block{align-items:flex-start;padding-top:25vh}}.intro-text{text-align:center;padding:40px}.intro-text h1{font-family:Cormorant Garamond,serif;font-size:4rem;font-weight:300;color:#333;margin-bottom:40px;letter-spacing:2px;text-shadow:0 2px 20px rgba(255,192,203,.3);min-height:2.4em;display:flex;align-items:center;justify-content:center}.typing-text{display:block;text-align:center;line-height:1.2;animation:fadeIn .5s ease-out}.typing-text .line{display:block}.letter-btn{position:relative;display:inline-block;padding:18px 50px;font-size:1.2rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffc0cb33;transition:all .3s ease;margin:60px 0 40px;text-decoration:none;animation:pulse 5s ease-in-out infinite}.letter-btn:hover{transform:translateY(-2px);box-shadow:0 10px 40px #ffc0cb66;animation:none}@keyframes pulse{0%,to{box-shadow:0 8px 32px #ffc0cb33;border-color:#ffc0cb80}50%{box-shadow:0 8px 38px #ff69b473,0 0 25px #ff69b44d;border-color:#ff69b4bf}}.letter-badge{position:absolute;top:-8px;right:-8px;background:linear-gradient(135deg,#ff1493,#ff69b4);color:#fff;font-size:.75rem;font-weight:600;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #ff149366;animation:badgePop .5s ease-out 1s both}@keyframes badgePop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.scroll-hint{font-family:Montserrat,sans-serif;font-size:1rem;font-weight:300;color:#999;letter-spacing:3px;text-transform:lowercase;animation:bounce 2s infinite;margin-bottom:100px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.letter-card{max-width:700px;width:100%;padding:60px;background:#fff6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;border:1px solid rgba(255,255,255,.6);box-shadow:0 8px 32px #ffc0cb33,inset 0 1px #fffc;position:relative;transform-style:preserve-3d;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0px,rgba(255,255,255,.05) 1px,transparent 1px,transparent 2px)}.letter-card:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#ffc0cb1a,#ffb6c11a,#ffc0cb1a);border-radius:20px;z-index:-1;filter:blur(10px)}.her-quote{margin-bottom:40px;position:relative;padding-left:30px}.quote-mark{position:absolute;left:-10px;top:-20px;font-family:Cormorant Garamond,serif;font-size:6rem;color:#ffc0cb4d;line-height:1}.her-quote p{font-family:Cormorant Garamond,serif;font-size:1.8rem;font-style:italic;color:#555;line-height:1.6;font-weight:300}.quote-underline{width:100px;height:2px;background:linear-gradient(to right,#ffc0cb99,#ffc0cb00);margin-top:20px;border-radius:2px;transform:skew(-10deg)}.my-response{padding:30px;background:#ffffff4d;border-left:3px solid rgba(255,192,203,.5);border-radius:10px}.my-response p{font-family:Montserrat,sans-serif;font-size:1.2rem;line-height:1.9;color:#333;font-weight:300}@media (max-width: 768px){.intro-text h1,.typing-text{font-size:2.5rem}.letter-btn{padding:15px 40px;font-size:1rem;margin:30px 0}.letter-badge{width:20px;height:20px;font-size:.7rem;top:-6px;right:-6px}.letter-card{padding:40px 30px;margin:0 10px}.her-quote p{font-size:1.4rem}.my-response p{font-size:1rem}.quote-mark{font-size:4rem;left:-5px}}@media (max-width: 480px){.intro-text h1{font-size:2rem}.letter-card{padding:30px 20px}.her-quote{padding-left:20px}.her-quote p{font-size:1.2rem}.my-response p{font-size:.95rem}}.letter-card:hover{box-shadow:0 12px 48px #ffc0cb4d,inset 0 1px #ffffffe6;transform:translateY(-5px);transition:all .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}*{transition:opacity .3s ease,transform .3s ease}.floating-particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.particle{position:absolute;background:radial-gradient(circle,#ffc0cb99,#ffb6c133);border-radius:50%;filter:blur(1px);box-shadow:0 0 10px #ffc0cb80}.final-scene{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px;position:relative}.back-to-letters-btn{position:absolute;top:30px;left:30px;padding:12px 30px;font-size:1rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #ffc0cb33;transition:all .3s ease;z-index:10}.back-to-letters-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px #ffc0cb4d}.invitation{text-align:center;max-width:600px;animation:fadeInUp .8s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.final-message{font-family:Cormorant Garamond,serif;font-size:1.8rem;line-height:1.8;color:#333;margin-bottom:60px;font-weight:300}.final-message .subtle{font-size:1.2rem;opacity:.7;font-style:italic;display:inline-block;margin-top:20px}.photo-container{margin:40px 0;display:flex;justify-content:center}.our-photo{max-width:100%;width:400px;height:auto;border-radius:20px;box-shadow:0 8px 32px #ffc0cb4d;border:2px solid rgba(255,255,255,.6);object-fit:cover}.take-flowers-btn{padding:18px 50px;font-size:1.2rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffc0cb33;transition:all .3s ease}.flower-choice{text-align:center;max-width:700px;animation:fadeInUp .8s ease}.flower-message{font-family:Cormorant Garamond,serif;font-size:1.8rem;line-height:1.8;color:#333;margin-bottom:40px;font-weight:300}.flower-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:600px;margin:0 auto}.flower-btn{padding:18px 50px;font-size:1.2rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffc0cb33;transition:all .3s ease;text-align:center}.flower-btn:hover{transform:translateY(-2px);box-shadow:0 10px 40px #ffc0cb4d}.delivery-choice{text-align:center;max-width:600px;animation:fadeInUp .8s ease}.delivery-message{font-family:Cormorant Garamond,serif;font-size:1.8rem;line-height:1.8;color:#333;margin-bottom:50px;font-weight:300}.delivery-buttons{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.delivery-btn{padding:18px 50px;font-size:1.2rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffc0cb33;transition:all .3s ease;min-width:150px}.thanks-container{display:flex;align-items:center;justify-content:center;min-height:300px;animation:fadeInUp .8s ease}.thanks-message{text-align:center;animation:fadeInUp .8s ease .3s both}.thanks-message p{font-family:Cormorant Garamond,serif;font-size:2rem;color:#333;margin:10px 0}.thanks-message .respect{font-size:1.3rem;opacity:.7;font-style:italic;font-weight:300}@media (max-width: 768px){.final-scene{padding:20px}.final-message{font-size:1.4rem;margin-bottom:30px}.photo-container{margin:30px 0}.our-photo{width:100%;max-width:320px;border-radius:15px}.take-flowers-btn{padding:15px 40px;font-size:1rem}.flower-message{font-size:1.4rem;margin-bottom:30px}.flower-grid{grid-template-columns:repeat(1,1fr);gap:15px;max-width:100%}.flower-btn{padding:15px 40px;font-size:1rem}.delivery-message{font-size:1.4rem;margin-bottom:40px}.delivery-buttons{gap:20px}.delivery-btn{padding:15px 40px;font-size:1rem;min-width:130px}.thanks-message p{font-size:1.5rem}.thanks-message .respect{font-size:1.1rem}}.letter-page-full{position:fixed;top:0;left:0;width:100%;height:100vh;background:linear-gradient(135deg,#fef5f1,#ffe4e1,pink,#ffb6c1,#fef5f1);background-size:400% 400%;animation:gradientShift 30s ease infinite;overflow-y:auto;z-index:1000}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.letter-full-container{max-width:800px;margin:0 auto;padding:40px 20px 60px;min-height:100vh}.back-btn{padding:12px 30px;font-size:1rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #ffc0cb33;transition:all .3s ease;margin-bottom:30px}.back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px #ffc0cb4d}.letter-title{font-family:Cormorant Garamond,serif;font-size:3rem;font-weight:300;text-align:center;color:#d4669a;letter-spacing:2px;margin-bottom:10px;text-shadow:0 2px 20px rgba(255,192,203,.3)}.letter-subtitle{font-family:Montserrat,sans-serif;font-size:1rem;font-weight:300;text-align:center;color:#999;letter-spacing:1px;margin-bottom:40px}.letter-full-date{font-family:Montserrat,sans-serif;font-size:.9rem;font-weight:300;text-align:center;color:#d4669a;letter-spacing:1px;margin-top:-10px;margin-bottom:30px}.letter-full-text{background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:60px 50px;box-shadow:0 20px 60px #0000001a;font-family:Cormorant Garamond,serif;font-size:1.3rem;line-height:1.9;color:#333;font-weight:300}.letter-full-text p{margin-bottom:20px}.next-letter-btn{display:block;margin:40px auto 0;padding:15px 45px;font-size:1.1rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #ffc0cb33;transition:all .3s ease}.next-letter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px #ffc0cb4d}.letters-list{display:flex;flex-direction:column;gap:20px;max-width:600px;margin:0 auto}.letter-item{display:flex;align-items:center;gap:20px;padding:25px 35px;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(255,192,203,.3);border-radius:15px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #ffc0cb33;font-family:Montserrat,sans-serif}.letter-item:hover{transform:translateY(-3px);box-shadow:0 12px 35px #ffc0cb4d;border-color:#ffc0cb80}.letter-number{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,pink,#ffb6c1);border-radius:50%;font-weight:600;color:#fff;font-size:1.1rem;flex-shrink:0}.letter-item-title{flex:1;text-align:left;font-size:1.2rem;color:#333;font-weight:400}.letter-date{font-size:.85rem;color:#d4669a;font-weight:300;flex-shrink:0;margin-right:10px;font-family:Montserrat,sans-serif}.letter-arrow{font-size:1.5rem;color:#d4669a;flex-shrink:0;transition:transform .3s ease}.letter-item:hover .letter-arrow{transform:translate(5px)}.flowers-btn{display:block;margin:60px auto 0;padding:18px 50px;font-size:1.2rem;font-family:Montserrat,sans-serif;font-weight:400;background:#ffc0cb33;border:2px solid rgba(255,192,203,.5);border-radius:50px;color:#d4669a;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #ffc0cb33;transition:all .3s ease}.flowers-btn:hover{transform:translateY(-2px);box-shadow:0 10px 40px #ffc0cb66}@media (max-width: 768px){.letter-full-container{padding:20px 15px 40px}.back-btn{padding:10px 25px;font-size:.9rem;margin-bottom:20px}.letter-title{font-size:2rem;margin-bottom:30px}.letter-full-text{padding:40px 30px;font-size:1.1rem;line-height:1.7}.letters-list{gap:15px}.letter-item{padding:20px 25px;gap:15px}.letter-number{width:35px;height:35px;font-size:1rem}.letter-item-title{font-size:1.05rem}.letter-arrow{font-size:1.3rem}.flowers-btn{margin:40px auto 0;padding:15px 40px;font-size:1rem}.letter-subtitle{font-size:.9rem}.letter-full-date{font-size:.8rem;margin-top:-5px;margin-bottom:20px}.letter-date{font-size:.75rem}.next-letter-btn{padding:12px 35px;font-size:1rem;margin-top:30px}}.letter-page{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.letter-page-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.letter-page-content{position:relative;max-width:800px;width:90%;max-height:80vh;background:#fffffff2;border-radius:20px;padding:60px 50px;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.close-letter-btn{position:absolute;top:20px;right:20px;width:40px;height:40px;border:none;background:#ffc0cb33;border-radius:50%;font-size:24px;color:#d4669a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-letter-btn:hover{background:#ffc0cb66;transform:scale(1.1)}.letter-page-text{font-family:Cormorant Garamond,serif;font-size:1.3rem;line-height:1.9;color:#333;font-weight:300}.letter-page-text p{margin-bottom:20px}@media (max-width: 768px){.letter-page-content{width:95%;padding:50px 30px;max-height:85vh}.letter-page-text{font-size:1.1rem;line-height:1.7}.close-letter-btn{top:15px;right:15px;width:35px;height:35px;font-size:20px}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Montserrat,sans-serif;overflow-x:hidden;background:#fef5f1;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffc0cb1a}::-webkit-scrollbar-thumb{background:#ffc0cb80;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffc0cbb3}
