body{margin:0}#root{width:100%;max-width:100%;margin:0 auto;min-height:100svh;display:flex;flex-direction:column;box-sizing:border-box}:root{--bg-primary: #1a0a0e;--bg-secondary: #2a1018;--bg-card: #2e1420;--bg-card-hover: #3a1a2a;--text-primary: #f5e6ea;--text-secondary: #c9a0ad;--text-muted: #8a6070;--accent: #e8607a;--accent-light: #f0849a;--accent-dark: #c0405a;--gold: #d4a855;--gold-light: #e8c878;--border: rgba(232, 96, 122, .15);--shadow: 0 8px 32px rgba(0, 0, 0, .3);--shadow-glow: 0 0 40px rgba(232, 96, 122, .15)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Lato,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden}h1,h2,h3,h4{font-family:Playfair Display,serif;font-weight:600}.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-primary);transition:opacity .8s ease,transform .8s ease}.landing-opening{opacity:0;transform:scale(1.05)}.landing-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(232,96,122,.12) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:glowPulse 4s ease-in-out infinite}@keyframes glowPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}}.landing-content{position:relative;z-index:2;text-align:center;padding:40px 28px;max-width:560px;animation:landingFadeIn 1.5s ease forwards}@keyframes landingFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-heart-top{font-size:48px;margin-bottom:28px;animation:pulse 2s ease-in-out infinite}.landing-line{font-family:Playfair Display,serif;font-style:italic;color:var(--text-primary);line-height:1.5}.landing-line-1,.landing-line-2,.landing-line-3{font-size:clamp(1.2rem,3vw,1.65rem)}.landing-line-2{color:var(--accent-light)}.landing-divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:28px 0}.landing-divider-line{width:50px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}.landing-divider-icon{font-size:1rem}.landing-line-funny{font-size:clamp(1.1rem,2.5vw,1.45rem);color:var(--gold-light);margin-bottom:8px}.landing-line-name{font-size:clamp(1.5rem,4vw,2.2rem);color:var(--text-primary);font-weight:700;font-style:normal;margin-bottom:44px;letter-spacing:.5px}.landing-btn{background:linear-gradient(135deg,var(--accent-dark),var(--accent),var(--accent-dark));background-size:200% 200%;animation:shimmer 3s ease-in-out infinite;border:none;border-radius:40px;padding:18px 40px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;margin:0 auto;transition:transform .3s ease,box-shadow .3s ease}.landing-btn:hover{transform:scale(1.05);box-shadow:0 8px 40px #e8607a80}.landing-btn:active{transform:scale(.97)}@keyframes shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.landing-btn-text{font-family:Playfair Display,serif;font-size:clamp(1rem,2.2vw,1.2rem);color:#fff;font-weight:600;letter-spacing:.5px}.landing-btn-hint{font-family:Lato,sans-serif;font-size:.8rem;color:#fff9;font-weight:300;font-style:italic}.landing-petals{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;overflow:hidden}.petal{position:absolute;top:-30px;animation:petalFall linear infinite}@keyframes petalFall{0%{transform:translateY(0) rotate(0) translate(0);opacity:0}10%{opacity:inherit}90%{opacity:inherit}to{transform:translateY(100vh) rotate(360deg) translate(40px);opacity:0}}.app-enter{animation:appFadeIn 1s ease forwards}@keyframes appFadeIn{0%{opacity:0}to{opacity:1}}.music-toggle{position:fixed;bottom:24px;right:24px;z-index:100;width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--accent-light);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease,background .3s ease;-webkit-tap-highlight-color:transparent}.music-toggle:hover{transform:scale(1.1);box-shadow:var(--shadow-glow);background:var(--bg-card-hover)}.music-toggle:active{transform:scale(.95)}.app{position:relative;min-height:100vh;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.landing{padding-bottom:env(safe-area-inset-bottom)}.floating-hearts{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.heart{position:absolute;bottom:-40px;color:var(--accent);animation:floatUp linear infinite}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:inherit}90%{opacity:inherit}to{transform:translateY(-100vh) rotate(20deg);opacity:0}}.section-reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease;position:relative;z-index:1}.section-reveal.visible{opacity:1;transform:translateY(0)}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:40px 24px;position:relative;z-index:1;background:radial-gradient(ellipse at center,rgba(232,96,122,.08) 0%,transparent 70%)}.hero-hearts{font-size:48px;margin-bottom:16px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);color:var(--text-primary);margin-bottom:8px;letter-spacing:1px}.hero h1 .name{color:var(--accent-light);font-style:italic}.hero .subtitle{font-family:Playfair Display,serif;font-style:italic;font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--text-secondary);margin-bottom:32px}.hero .love-letter{max-width:580px;font-size:1.05rem;color:var(--text-secondary);line-height:1.9;margin-bottom:40px;font-weight:300}.scroll-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.85rem;letter-spacing:2px;text-transform:uppercase;animation:bounce 2s ease-in-out infinite}.scroll-arrow{font-size:1.2rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.section-header{text-align:center;margin-bottom:60px}.section-header h2{font-size:clamp(1.8rem,4vw,2.8rem);color:var(--text-primary);margin-bottom:12px}.section-header .divider{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--accent);font-size:.9rem}.section-header .divider-line{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.how-we-met{padding:80px 24px;position:relative;background:linear-gradient(180deg,transparent,rgba(232,96,122,.04),transparent)}.how-we-met-inner{max-width:760px;margin:0 auto;text-align:center}.meet-story{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:48px 40px;position:relative;box-shadow:var(--shadow)}.meet-story:before,.meet-story:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:80%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.4}.meet-story:before{top:20px}.meet-story:after{bottom:20px}.meet-quote{font-family:Playfair Display,serif;font-style:italic;font-size:clamp(1.15rem,2.4vw,1.5rem);color:var(--accent-light);margin-bottom:28px;line-height:1.5}.meet-body{color:var(--text-secondary);font-size:1.05rem;line-height:1.9;margin-bottom:20px;font-weight:300}.meet-body:last-of-type{margin-bottom:28px}.meet-signature{font-family:Playfair Display,serif;font-style:italic;color:var(--gold);font-size:1.1rem;letter-spacing:1px;margin-top:8px}.little-things{margin-top:60px;padding:36px 32px;text-align:center;background:radial-gradient(ellipse at center,rgba(212,168,85,.06),transparent 70%);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.little-things-label{font-family:Playfair Display,serif;font-style:italic;color:var(--gold);font-size:1.3rem;margin-bottom:16px;letter-spacing:1px}.little-things-text{color:var(--text-secondary);font-weight:300;line-height:1.9;max-width:560px;margin:0 auto;font-size:1rem}.timeline-section{padding:80px 24px 100px;max-width:900px;margin:0 auto}.timeline{position:relative;padding-left:40px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent),var(--gold),var(--accent));opacity:.4}.timeline-item{position:relative;margin-bottom:48px;padding:28px 32px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}.timeline-item:hover{transform:translate(6px);box-shadow:var(--shadow-glow);border-color:#e8607a4d}.timeline-item:before{content:"";position:absolute;left:-36px;top:32px;width:14px;height:14px;background:var(--accent);border-radius:50%;border:3px solid var(--bg-primary);box-shadow:0 0 12px #e8607a66}.timeline-item .date-number{font-family:Playfair Display,serif;font-size:.85rem;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}.timeline-item h3{font-size:1.3rem;color:var(--text-primary);margin-bottom:10px}.timeline-item p{color:var(--text-secondary);font-weight:300;line-height:1.8}.timeline-item .highlight{color:var(--accent-light);font-style:italic;font-weight:400}.timeline-photos{display:grid;gap:10px;margin-bottom:18px;border-radius:12px;overflow:hidden}.timeline-photos.single{grid-template-columns:1fr}.timeline-photos.double{grid-template-columns:1fr 1fr}.timeline-photos.triple{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.timeline-photos.triple .timeline-photo-wrapper:first-child{grid-column:1 / -1}.timeline-photos.multi{grid-template-columns:1fr 1fr}.timeline-photos.multi .timeline-photo-wrapper:first-child{grid-column:1 / -1}.timeline-photo-wrapper{overflow:hidden;border-radius:10px;border:1px solid var(--border);background:var(--bg-secondary)}.timeline-photo{width:100%;max-height:420px;object-fit:contain;display:block;transition:transform .4s ease}.timeline-photo-wrapper:hover .timeline-photo{transform:scale(1.03)}.timeline-item-sandwiched .timeline-photos{margin-bottom:20px}.timeline-item-sandwiched .timeline-photos:last-of-type{margin-top:20px;margin-bottom:0}.carousel-section{padding:60px 24px 80px;text-align:center;background:linear-gradient(180deg,transparent,rgba(212,168,85,.04),transparent)}.carousel-header{margin-bottom:32px}.carousel-label{font-family:Playfair Display,serif;font-style:italic;font-size:clamp(1.2rem,2.5vw,1.6rem);color:var(--gold-light);letter-spacing:1px}.carousel{position:relative;max-width:600px;margin:0 auto;aspect-ratio:4 / 5;border-radius:20px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--bg-card)}.carousel-slide{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transform:translate(60px);transition:opacity .8s ease,transform .8s ease;pointer-events:none}.carousel-slide.carousel-active{opacity:1;transform:translate(0);pointer-events:auto}.carousel-slide.carousel-prev{opacity:0;transform:translate(-60px)}.carousel-slide img{width:100%;height:100%;object-fit:contain;display:block;background:var(--bg-card)}.carousel-dots{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:10px;z-index:2}.carousel-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.6);background:transparent;cursor:pointer;padding:0;transition:background .3s ease,border-color .3s ease}.carousel-dot.active{background:var(--accent-light);border-color:var(--accent-light)}.carousel-dot:hover{border-color:#fff}.activities-section{padding:80px 24px 100px;max-width:1100px;margin:0 auto}.activities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}.activity-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:36px 28px;text-align:center;transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}.activity-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--gold),var(--accent));opacity:.6}.activity-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-glow)}.activity-icon{font-size:42px;margin-bottom:16px}.activity-card h3{font-size:1.3rem;color:var(--gold-light);margin-bottom:20px}.hint-box{background:#e8607a0f;border:1px solid rgba(232,96,122,.12);border-radius:12px;padding:20px;margin-bottom:20px;min-height:80px;display:flex;flex-direction:column;justify-content:center}.hint-text{color:var(--text-secondary);font-style:italic;font-size:1rem;line-height:1.6}.hint-number{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}.hint-controls{display:flex;flex-direction:column;gap:12px;align-items:center}.btn{font-family:Lato,sans-serif;font-size:.9rem;padding:10px 24px;border-radius:30px;border:none;cursor:pointer;transition:all .3s ease;letter-spacing:1px}.btn-hint{background:transparent;border:1px solid var(--accent);color:var(--accent-light)}.btn-hint:hover{background:#e8607a1a}.btn-hint:disabled{opacity:.3;cursor:not-allowed}.btn-guess{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;font-weight:700;width:100%}.btn-guess:hover{box-shadow:0 4px 20px #e8607a66;transform:scale(1.02)}.guess-input{width:100%;padding:12px 18px;border-radius:12px;border:1px solid var(--border);background:#0003;color:var(--text-primary);font-family:Lato,sans-serif;font-size:1rem;outline:none;transition:border-color .3s ease}.guess-input::placeholder{color:var(--text-muted)}.guess-input:focus{border-color:var(--accent)}.guess-result{margin-top:16px;padding:16px;border-radius:12px;font-weight:600}.guess-result.correct{background:#50c8781a;border:1px solid rgba(80,200,120,.3);color:#50c878}.guess-result.incorrect{background:#e8607a1a;border:1px solid rgba(232,96,122,.2);color:var(--accent-light)}.revealed-answer{margin-top:16px;padding:20px;background:#d4a85514;border:1px solid rgba(212,168,85,.2);border-radius:12px;color:var(--gold-light);font-family:Playfair Display,serif;font-size:1.15rem}.footer{text-align:center;padding:80px 24px 60px;position:relative}.footer-heart{font-size:64px;margin-bottom:24px;animation:pulse 2s ease-in-out infinite}.footer h2{font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--text-primary);margin-bottom:16px}.footer p{color:var(--text-secondary);font-size:1.1rem;max-width:500px;margin:0 auto;font-weight:300;line-height:1.8}.footer .signature{margin-top:32px;font-family:Playfair Display,serif;font-style:italic;color:var(--gold);font-size:1.2rem}button,.landing-btn,.btn,.carousel-dot{-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media (max-width: 768px){.hero{padding:32px 20px;min-height:100svh}.hero .love-letter{font-size:.95rem;line-height:1.8}.section-header{margin-bottom:40px}.how-we-met{padding:60px 20px}.meet-story{padding:36px 28px}.timeline-section{padding:60px 16px 80px}.timeline-item{padding:24px;margin-bottom:36px}.timeline-item:hover,.timeline-photo-wrapper:hover .timeline-photo{transform:none}.carousel-section{padding:48px 20px 60px}.activities-section{padding:60px 20px 80px}.activity-card:hover{transform:none}.footer{padding:60px 20px 48px}}@media (max-width: 480px){body{font-size:15px}.landing-content{padding:32px 20px}.landing-glow{width:300px;height:300px}.landing-heart-top{font-size:40px;margin-bottom:20px}.landing-line-name{margin-bottom:36px}.landing-btn{padding:16px 32px}.hero{padding:28px 16px}.hero-hearts{font-size:40px}.hero .love-letter{font-size:.9rem;padding:0 4px}.scroll-indicator{font-size:.75rem}.how-we-met{padding:48px 16px}.meet-story{padding:28px 18px;border-radius:14px}.meet-quote{font-size:1.05rem;margin-bottom:20px}.meet-body{font-size:.95rem}.meet-signature{font-size:1rem}.timeline-section{padding:48px 12px 60px}.timeline{padding-left:28px}.timeline:before{left:6px}.timeline-item{padding:18px 16px;margin-bottom:28px;border-radius:12px}.timeline-item:before{left:-25px;top:24px;width:10px;height:10px;border-width:2px}.timeline-item .date-number{font-size:.75rem;letter-spacing:1.5px}.timeline-item h3{font-size:1.1rem;margin-bottom:8px}.timeline-item p{font-size:.9rem;line-height:1.7}.timeline-photos{gap:6px;margin-bottom:14px}.timeline-photos.double,.timeline-photos.triple{grid-template-columns:1fr}.timeline-photos.triple .timeline-photo-wrapper:first-child,.timeline-photos.multi .timeline-photo-wrapper:first-child{grid-column:1}.timeline-photos.multi{grid-template-columns:1fr}.timeline-photo{max-height:300px}.timeline-photo-wrapper{border-radius:8px}.timeline-item-sandwiched .timeline-photos{margin-bottom:14px}.timeline-item-sandwiched .timeline-photos:last-of-type{margin-top:14px}.little-things{margin-top:40px;padding:28px 16px}.little-things-label{font-size:1.1rem}.little-things-text{font-size:.9rem}.carousel-section{padding:40px 16px 52px}.carousel{max-width:100%;aspect-ratio:3 / 4;border-radius:14px}.carousel-dots{bottom:12px;gap:8px}.carousel-dot{width:9px;height:9px}.activities-section{padding:48px 16px 60px}.activities-grid{grid-template-columns:1fr;gap:24px}.activity-card{padding:24px 18px;border-radius:14px}.activity-icon{font-size:36px;margin-bottom:12px}.activity-card h3{font-size:1.15rem;margin-bottom:16px}.hint-box{padding:16px;min-height:70px}.hint-text{font-size:.9rem}.guess-input{padding:10px 14px;font-size:16px}.btn{padding:12px 20px;font-size:.85rem}.revealed-answer{font-size:1rem;padding:16px}.footer{padding:48px 16px 40px}.footer-heart{font-size:48px;margin-bottom:16px}.footer p{font-size:.95rem}.footer .signature{font-size:1.05rem;margin-top:24px}.floating-hearts .heart:nth-child(n+8){display:none}}
