*{margin:0;padding:0;box-sizing:border-box}:root{--primary-red:#c94545;--dark-red:#a83232;--light-red:#e57373;--dark:#2c2c2c;--light:#fff5f5;--white:#ffffff;--beige:#f9f7f4}body{font-family:"Montserrat",sans-serif;color:var(--dark);background:var(--light);overflow-x:hidden}.floating-hearts{position:fixed;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:1}.heart{position:absolute;font-size:24px;opacity:0;animation:float-heart 12s linear infinite}@keyframes float-heart{0%{transform:translateY(100vh) rotate(0deg) scale(0);opacity:0}10%{opacity:.8;transform:translateY(90vh) rotate(45deg) scale(1)}90%{opacity:.8}100%{transform:translateY(-10vh) rotate(180deg) scale(.5);opacity:0}}.hero-banner{position:relative}.hero-banner .fade-in{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:20px;position:relative;background:linear-gradient(to bottom,rgb(0 0 0 / .3),rgb(0 0 0 / .5)),url(../images/wedding_album/Layout2535_05.webp) center/cover no-repeat;background-size:cover;background-position:center;background-repeat:no-repeat;color:#fff;animation:fadeIn 1.5s ease-in}.hero-banner h1{font-family:"Dancing Script",cursive;font-size:clamp(2.5rem, 8vw, 10rem);font-weight:700;color:var(--warm-beige);margin-bottom:20px;text-shadow:2px 2px 4px var(--shadow)}.hero-banner .tagline{font-family:"Dancing Script",cursive;font-size:clamp(1rem, 3vw, 5rem);text-align:center;color:var(--pink);font-style:italic;margin-bottom:40px}@keyframes fadeIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.invitation-section{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,rgb(201 69 69 / .95) 0%,rgb(168 50 50 / .9) 50%,rgb(201 69 69 / .95) 100%);overflow:hidden;padding:40px 20px}.invitation-section::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgb(255 255 255 / .1) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgb(255 192 203 / .2) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgb(255 255 255 / .05) 0%,transparent 70%);animation:pulse-bg 8s ease-in-out infinite}@keyframes pulse-bg{0%,100%{opacity:.6}50%{opacity:1}}.invitation-section::after{content:"❤️";position:absolute;font-size:300px;opacity:.05;top:50%;left:50%;transform:translate(-50%,-50%);animation:rotate-slow 30s linear infinite}@keyframes rotate-slow{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}.invitation-section-container{position:relative;z-index:10;text-align:center;padding:60px 40px;background:rgb(255 255 255 / .98);border-radius:40px;box-shadow:0 40px 100px rgb(0 0 0 / .3),0 0 0 1px rgb(201 69 69 / .1),inset 0 1px 0 rgb(255 255 255 / .9);max-width:700px;margin:20px;animation:fadeInScale 1.2s ease-out;backdrop-filter:blur(20px)}@keyframes fadeInScale{from{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.save-the-date{background:linear-gradient(135deg,var(--primary-red) 0%,var(--dark-red) 100%);padding:35px 70px;border-radius:25px;display:inline-block;box-shadow:0 15px 40px rgb(201 69 69 / .4),inset 0 1px 0 rgb(255 255 255 / .2);animation:pulse-box 2s ease-in-out infinite;position:relative;overflow:hidden}.save-the-date::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .3),transparent);animation:shine 3s infinite}@keyframes shine{0%{left:-100%}100%{left:200%}}@keyframes pulse-box{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.save-the-date h2{font-family:"Playfair Display",serif;font-size:clamp(1rem, 5vw, 3.5rem);color:#fff;letter-spacing:4px;text-transform:uppercase;font-weight:700;position:relative}.save-the-date h2 .the{font-style:italic;font-size:.7em;font-weight:400;text-transform:lowercase}.save-the-date .date{font-family:"Cormorant Garamond",serif;font-size:clamp(1.2rem, 3vw, 1.8rem);color:rgb(255 255 255 / .95);margin-top:15px;letter-spacing:1px}.invitation-text{font-style:italic;color:#666;margin:40px 0;line-height:1.9;font-size:clamp(0.5rem, 3vw, 1.4rem)}.couple-names{margin:50px 0;position:relative}.couple-names h3{font-family:"Cormorant Garamond",serif;font-size:clamp(1.5rem, 5vw, 3.8rem);color:var(--dark);font-weight:600;margin:20px 0;position:relative;display:inline-block}.couple-names h3::after{content:"";position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);width:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary-red),transparent);animation:expand-line 2s ease-out forwards}@keyframes expand-line{to{width:100%}}.couple-names .and{font-family:"Dancing Script",cursive;font-size:clamp(1.8rem, 4vw, 2.5rem);color:var(--primary-red);margin:25px 0;display:block}.wedding-details{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:50px 0}.detail-item{text-align:center;padding:30px 20px;background:linear-gradient(135deg,rgb(201 69 69 / .05),rgb(201 69 69 / .1));border-radius:20px;border:2px solid rgb(201 69 69 / .2);transition:all 0.4s ease;position:relative;overflow:hidden}.detail-item::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgb(201 69 69 / .1);transform:translate(-50%,-50%);transition:width 0.4s ease,height 0.4s ease}.detail-item:hover::before{width:200%;height:200%}.detail-item:hover{transform:translateY(-8px);box-shadow:0 15px 35px rgb(201 69 69 / .25);border-color:var(--primary-red)}.detail-item h4{font-size:.9rem;text-transform:uppercase;letter-spacing:3px;color:var(--dark-red);margin-bottom:12px;font-weight:600;position:relative}.detail-item p{font-size:1.5rem;font-weight:600;color:var(--primary-red);position:relative}.venue-info{padding:15px;background:var(--beige);border-radius:20px;border-left:5px solid var(--primary-red);box-shadow:0 5px 20px rgb(0 0 0 / .08)}.venue-info p{margin:8px 0;font-size:clamp(0.5rem, 3vw, 2.5rem);line-height:1.7;color:#666}.venue-info strong{color:var(--dark);font-size:clamp(0.6rem, 2.5vw, 1.5rem)}.venue-info .venue-address{font-size:clamp(0.6rem, 2.5vw, 1.5rem);text-decoration:none;color:#666}.calendar-section{padding:120px 20px;background:linear-gradient(to bottom,var(--light),white,var(--light));position:relative}.calendar-section::before,.calendar-section::after{content:"💐";position:absolute;font-size:120px;opacity:.08;animation:float-decoration 20s ease-in-out infinite}.calendar-section::before{top:80px;left:5%}.calendar-section::after{content:"🌹";bottom:80px;right:5%;animation-delay:-10s}@keyframes float-decoration{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-30px) rotate(10deg)}}.calendar-container{max-width:550px;margin:0 auto;background:#fff;padding:60px 50px;border-radius:35px;box-shadow:0 30px 80px rgb(201 69 69 / .15),0 0 0 1px rgb(201 69 69 / .1);position:relative;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.calendar-header{text-align:center;margin-bottom:50px}.calendar-header h2{font-family:"Playfair Display",serif;font-size:clamp(2.5rem, 6vw, 4rem);background:linear-gradient(135deg,var(--primary-red),var(--dark-red));-webkit-background-clip:text;-webkit-text-fill-color:#fff0;background-clip:text;margin-bottom:15px;font-weight:700}.calendar-header .year{font-size:1.3rem;color:#999;letter-spacing:2px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:1.05rem;border-radius:12px;transition:all 0.3s ease;font-weight:500}.calendar-day.header{font-weight:700;color:var(--dark-red);font-size:.9rem}.calendar-day:not(.header):not(.highlighted):hover{background:rgb(201 69 69 / .1);transform:scale(1.1)}.calendar-day.highlighted{background:linear-gradient(135deg,var(--primary-red),var(--dark-red));color:#fff;font-weight:700;font-size:1.4rem;box-shadow:0 8px 25px rgb(201 69 69 / .4),0 0 0 4px rgb(201 69 69 / .1);animation:pulse-date 2s ease-in-out infinite;position:relative}.calendar-day.highlighted::after{content:"💕";position:absolute;top:-25px;left:50%;transform:translateX(-50%);font-size:1.2rem;animation:bounce-heart 1.5s ease-in-out infinite}@keyframes pulse-date{0%,100%{box-shadow:0 8px 25px rgb(201 69 69 / .4),0 0 0 4px rgb(201 69 69 / .1)}50%{box-shadow:0 8px 35px rgb(201 69 69 / .6),0 0 0 8px rgb(201 69 69 / .2)}}@keyframes bounce-heart{0%,100%{transform:translateX(-50%) translateY(0) scale(1)}50%{transform:translateX(-50%) translateY(-5px) scale(1.2)}}.parents-section{padding:120px 20px;background:linear-gradient(135deg,rgb(249 247 244) 0%,rgb(255 255 255) 50%,rgb(249 247 244) 100%);position:relative}.parents-section::before{content:"🌸";position:absolute;top:60px;left:8%;font-size:100px;opacity:.1;animation:float-decoration 15s ease-in-out infinite}.parents-section::after{content:"🌸";position:absolute;bottom:60px;right:8%;font-size:100px;opacity:.1;animation:float-decoration 15s ease-in-out infinite;animation-delay:-7s}.parents-container{max-width:1200px;margin:0 auto;position:relative}.parents-header{text-align:center;margin-bottom:80px}.header-icon{font-size:4.5rem;margin-bottom:25px;display:inline-block;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}.parents-header h2{font-family:"Playfair Display",serif;font-size:clamp(2.5rem, 6vw, 4.5rem);background:linear-gradient(135deg,var(--primary-red),var(--dark-red));-webkit-background-clip:text;-webkit-text-fill-color:#fff0;background-clip:text;margin-bottom:15px;font-weight:700}.parents-header p{font-family:"Cormorant Garamond",serif;font-size:1.3rem;font-style:italic;color:#666}.parents-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:60px;align-items:center;margin-bottom:60px}.parent-side{background:#fff;padding:50px 40px;border-radius:30px;box-shadow:0 20px 60px rgb(201 69 69 / .12);text-align:center;position:relative;transition:all 0.5s ease}.parent-side:hover{transform:translateY(-10px);box-shadow:0 30px 80px rgb(201 69 69 / .2)}.side-icon{font-size:4rem;margin-bottom:25px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}.parent-side h3{font-family:"Playfair Display",serif;font-size:1.5rem;color:var(--primary-red);letter-spacing:3px;margin-bottom:35px;font-weight:700;position:relative;padding-bottom:15px}.parent-side h3::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,transparent,var(--primary-red),transparent)}.parent-info{margin:30px 0}.parent-item{margin:25px 0;display:flex;flex-direction:column;gap:10px;padding:20px;background:linear-gradient(135deg,rgb(201 69 69 / .05),rgb(201 69 69 / .1));border-radius:15px;border-left:4px solid var(--primary-red);transition:all 0.3s ease}.parent-item:hover{background:linear-gradient(135deg,rgb(201 69 69 / .1),rgb(201 69 69 / .15));transform:translateX(5px)}.parent-label{font-size:.95rem;color:var(--dark-red);font-weight:600;text-transform:uppercase;letter-spacing:2px}.parent-name{font-family:"Cormorant Garamond",serif;font-size:1.8rem;color:var(--dark);font-weight:600}.decorative-line{margin-top:30px;height:2px;background:linear-gradient(90deg,transparent,var(--primary-red),transparent);opacity:.3}.heart-divider{display:flex;align-items:center;justify-content:center}.heart-icon{font-size:4rem;animation:heartbeat 2s ease-in-out infinite;filter:drop-shadow(0 5px 15px rgb(201 69 69 / .3))}.blessing-text{text-align:center;margin-top:60px}.blessing-text p{font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-style:italic;color:var(--dark-red);line-height:1.8;padding:30px;background:linear-gradient(135deg,rgb(201 69 69 / .05),rgb(201 69 69 / .1));border-radius:20px;border:2px solid rgb(201 69 69 / .2);max-width:800px;margin:0 auto}@media (max-width:968px){.parents-grid{grid-template-columns:1fr;gap:40px}.heart-divider{transform:rotate(0deg)}.heart-icon{font-size:3rem}.parent-side{padding:40px 30px}}.timeline-section{padding:120px 20px;background:linear-gradient(135deg,rgb(249 247 244) 0%,rgb(255 255 255) 50%,rgb(249 247 244) 100%)}.timeline-header{text-align:center;margin-bottom:60px}.timeline-icon{font-size:4rem;margin-bottom:25px;display:inline-block;animation:swing 3s ease-in-out infinite}@keyframes swing{0%,100%{transform:rotate(-15deg)}50%{transform:rotate(15deg)}}.timeline-header h2{font-family:"Playfair Display",serif;font-size:clamp(3rem, 6vw, 5rem);background:linear-gradient(135deg,var(--primary-red),var(--dark-red));-webkit-background-clip:text;-webkit-text-fill-color:#fff0;background-clip:text;margin-bottom:20px;font-weight:700}.timeline-header .time{font-size:1.4rem;color:#666;margin-top:15px;font-family:"Cormorant Garamond",serif}.timeline-content{max-width:600px;margin:0 auto;text-align:center;font-style:italic;color:#999;font-size:1.1rem}.album-section{padding:120px 20px;background:linear-gradient(to bottom,white,var(--light),white);position:relative}.album-container{max-width:1400px;margin:0 auto}.album-header{text-align:center;margin-bottom:80px}.album-header h2{font-family:"Playfair Display",serif;font-size:clamp(2.5rem, 6vw, 4.5rem);background:linear-gradient(135deg,var(--primary-red),var(--dark-red));-webkit-background-clip:text;-webkit-text-fill-color:#fff0;background-clip:text;margin-bottom:20px;font-weight:700}.album-header p{font-family:"Cormorant Garamond",serif;font-size:1.3rem;font-style:italic;color:#666}.album-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px;padding:20px 0}.album-item{position:relative;aspect-ratio:4/5;border-radius:25px;overflow:hidden;cursor:pointer;box-shadow:0 15px 40px rgb(201 69 69 / .15);transition:all 0.5s cubic-bezier(.4,0,.2,1)}.album-item:hover{transform:translateY(-15px) scale(1.02);box-shadow:0 25px 60px rgb(201 69 69 / .3)}.album-photo{width:100%;height:100%;background:linear-gradient(135deg,rgb(201 69 69 / .8),rgb(168 50 50 / .9));display:flex;align-items:center;justify-content:center;font-size:5rem;transition:transform 0.5s ease}.album-item:hover .album-photo{transform:scale(1.1)}.album-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 0%,rgb(201 69 69 / .9) 100%);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.4s ease}.album-item:hover .album-overlay{opacity:1}.zoom-icon{font-size:3rem;color:#fff;animation:zoom-pulse 1.5s ease-in-out infinite}@keyframes zoom-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}.album-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .95);z-index:2000;animation:fadeIn 0.3s ease}.album-modal.active{display:flex;align-items:center;justify-content:center}.modal-close{position:absolute;top:30px;right:50px;font-size:3rem;color:#fff;cursor:pointer;z-index:2001;transition:all 0.3s ease;width:50px;height:50px;display:flex;align-items:center;justify-content:center}.modal-close:hover{transform:rotate(90deg) scale(1.2);color:var(--light-red)}.modal-prev,.modal-next{position:absolute;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,var(--primary-red),var(--dark-red));color:#fff;border:none;width:60px;height:60px;border-radius:50%;font-size:2rem;cursor:pointer;z-index:2001;transition:all 0.3s ease;display:flex;align-items:center;justify-content:center}.modal-prev{left:30px}.modal-next{right:30px}.modal-prev:hover,.modal-next:hover{transform:translateY(-50%) scale(1.15);box-shadow:0 10px 30px rgb(201 69 69 / .5)}.modal-content{max-width:90%;max-height:90%;text-align:center;animation:zoomIn 0.4s ease}@keyframes zoomIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-image{max-width:100%;max-height:80vh;background:linear-gradient(135deg,var(--primary-red),var(--dark-red));border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:8rem;aspect-ratio:4/5;box-shadow:0 20px 60px rgb(0 0 0 / .5)}.modal-caption{color:#fff;font-size:1.3rem;margin-top:25px;font-family:"Cormorant Garamond",serif;font-style:italic}.profiles-section{padding:120px 20px;background:#fff;position:relative;overflow:hidden}.profiles-section::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 15% 20%,rgb(201 69 69 / .05) 0%,transparent 40%),radial-gradient(circle at 85% 80%,rgb(201 69 69 / .05) 0%,transparent 40%);pointer-events:none}.profile-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:80px;position:relative}.profile-card{background:#fff;border-radius:35px;overflow:hidden;box-shadow:0 25px 70px rgb(201 69 69 / .15);transition:all 0.5s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer}.profile-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--primary-red),var(--dark-red));transform:scaleX(0);transition:transform 0.5s ease}.profile-card:hover::before{transform:scaleX(1)}.profile-card:hover{transform:translateY(-20px) scale(1.02);box-shadow:0 40px 100px rgb(201 69 69 / .25)}.profile-photo{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,var(--primary-red) 0%,var(--dark-red) 100%);display:flex;align-items:center;justify-content:center;font-size:7rem;position:relative;overflow:hidden}.profile-photo::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgb(255 255 255 / .3) 50%,transparent 70%);animation:shine-photo 4s infinite}@keyframes shine-photo{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}100%{transform:translateX(100%) translateY(100%) rotate(45deg)}}.profile-info{padding:45px 35px;text-align:center;background:linear-gradient(to bottom,white,rgb(249 247 244 / .5))}.profile-info .role{font-size:.95rem;text-transform:uppercase;letter-spacing:3px;color:var(--dark-red);margin-bottom:15px;font-weight:600}.profile-info h3{font-family:"Playfair Display",serif;font-size:2.8rem;background:linear-gradient(135deg,var(--primary-red),var(--dark-red));-webkit-background-clip:text;-webkit-text-fill-color:#fff0;background-clip:text;font-weight:700}.rsvp-section{padding:120px 20px;background:linear-gradient(135deg,var(--primary-red) 0%,var(--dark-red) 100%);color:#fff;position:relative;overflow:hidden}.rsvp-section::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgb(255 255 255 / .1) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgb(0 0 0 / .1) 0%,transparent 50%);animation:pulse-bg 10s ease-in-out infinite}.rsvp-container{max-width:750px;margin:0 auto;text-align:center;position:relative;z-index:10}.rsvp-icon{font-size:6rem;margin-bottom:35px;display:inline-block;animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,100%{transform:scale(1)}10%,30%{transform:scale(1.15)}20%,40%{transform:scale(1)}}.rsvp-container h2{font-family:"Playfair Display",serif;font-size:clamp(2.5rem, 6vw, 4rem);margin-bottom:30px;font-weight:700;text-shadow:0 2px 20px rgb(0 0 0 / .2)}.rsvp-container>p{line-height:1.9;font-size:1.1rem;margin-bottom:50px;color:rgb(255 255 255 / .95)}.rsvp-form{background:rgb(255 255 255 / .98);padding:60px 50px;border-radius:35px;box-shadow:0 30px 80px rgb(0 0 0 / .3);backdrop-filter:blur(20px);animation:fadeInUp 1s ease-out 0.3s both}.form-group{margin-bottom:35px;text-align:left}.form-group label{display:block;margin-bottom:12px;font-weight:600;color:var(--dark);font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:18px 22px;border:2px solid rgb(201 69 69 / .2);border-radius:15px;font-family:inherit;font-size:1rem;transition:all 0.3s ease;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 5px rgb(201 69 69 / .1);transform:translateY(-2px)}.form-group textarea{resize:vertical;min-height:130px}.submit-btn{background:linear-gradient(135deg,var(--primary-red),var(--dark-red));color:#fff;border:none;padding:22px 70px;border-radius:50px;font-size:1.15rem;font-weight:600;cursor:pointer;transition:all 0.4s ease;box-shadow:0 15px 40px rgb(0 0 0 / .2);margin-top:25px;position:relative;overflow:hidden}.submit-btn::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgb(255 255 255 / .3);transform:translate(-50%,-50%);transition:width 0.6s ease,height 0.6s ease}.submit-btn:hover::before{width:300px;height:300px}.submit-btn:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgb(0 0 0 / .3)}.submit-btn:active{transform:translateY(-2px)}.music-control{position:fixed;bottom:100px;right:35px;width:75px;height:75px;background:linear-gradient(135deg,var(--primary-red),var(--dark-red));border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 35px rgb(201 69 69 / .4);z-index:1000;transition:all 0.4s ease;animation:float-music 3s ease-in-out infinite}@keyframes float-music{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}.music-control:hover{transform:scale(1.15) rotate(10deg);box-shadow:0 15px 45px rgb(201 69 69 / .5)}.music-control span{font-size:2.2rem;filter:drop-shadow(0 2px 4px rgb(0 0 0 / .2))}.scroll-up{position:fixed;bottom:35px;right:35px;width:65px;height:65px;background:linear-gradient(135deg,var(--primary-red),var(--dark-red));border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 35px rgb(201 69 69 / .4);z-index:1000;transition:all 0.4s ease;opacity:0;pointer-events:none;font-size:2rem;color:#fff;font-weight:700}.scroll-up.show{opacity:1;pointer-events:all}.scroll-up:hover{transform:translateY(-8px);box-shadow:0 15px 45px rgb(201 69 69 / .5)}.toast{position:fixed;top:100px;right:35px;background:linear-gradient(135deg,var(--primary-red),var(--dark-red));color:#fff;padding:22px 35px;border-radius:20px;box-shadow:0 15px 40px rgb(201 69 69 / .4);z-index:1001;transform:translateX(500px);transition:transform 0.5s cubic-bezier(.4,0,.2,1);font-size:1.05rem;font-weight:500}.toast.show{transform:translateX(0)}.section-journey{max-width:1200px;margin:0 auto}h1{font-family:"Playfair Display",serif;text-align:center;color:var(--primary-red);font-size:3em;margin-bottom:60px}.timeline{position:relative;padding:20px 0}.timeline::before{content:"";position:absolute;left:50%;transform:translateX(-50%);width:4px;height:100%;background:linear-gradient(to bottom,#fff 0%,rgb(255 255 255 / .5) 100%)}.timeline-item{display:flex;margin-bottom:80px;position:relative;opacity:0;animation:fadeIn 0.6s ease forwards}.timeline-item:nth-child(1){animation-delay:0.1s}.timeline-item:nth-child(2){animation-delay:0.2s}.timeline-item:nth-child(3){animation-delay:0.3s}.timeline-item:nth-child(4){animation-delay:0.4s}.timeline-item:nth-child(5){animation-delay:0.5s}.timeline-item:nth-child(6){animation-delay:0.6s}.timeline-item:nth-child(7){animation-delay:0.7s}.timeline-item:nth-child(8){animation-delay:0.8s}.timeline-item:nth-child(9){animation-delay:0.9s}.timeline-item:nth-child(10){animation-delay:1s}@keyframes fadeIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.timeline-item:nth-child(odd){flex-direction:row-reverse}.timeline-content{width:45%;background:#fff;padding:30px;border-radius:15px;box-shadow:0 10px 30px rgb(0 0 0 / .2);transition:transform 0.3s ease,box-shadow 0.3s ease}.timeline-content:hover{transform:translateY(-5px);box-shadow:0 15px 40px rgb(0 0 0 / .3)}.timeline-item:nth-child(odd) .timeline-content{margin-right:5%}.timeline-item:nth-child(even) .timeline-content{margin-left:5%}.timeline-marker{position:absolute;left:50%;transform:translateX(-50%);width:20px;height:20px;background:#fff;border:4px solid var(--primary-red);border-radius:50%;z-index:10;box-shadow:0 0 0 4px rgb(102 126 234 / .3)}.year{font-size:1.8em;font-weight:700;color:var(--dark-red);margin-bottom:15px}.image-container{width:100%;height:450px;overflow:hidden;border-radius:10px;margin-bottom:20px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.image-container img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease}.timeline-content:hover .image-container img{transform:scale(1.05)}.description{color:#555;line-height:1.6;font-size:1em}@media (max-width:1500px){.hero-banner .fade-in{height:90vh}}@media (max-width:1210px){.hero-banner .fade-in{height:60vh}}@media (max-width:768px){.hero-banner .fade-in{height:35vh}.invitation-section-container{padding:40px 25px}.save-the-date{padding:25px 40px}.wedding-details{gap:15px}.detail-item{padding:20px 15px}.calendar-container{padding:40px 30px}.profile-grid{gap:50px}.rsvp-form{padding:40px 25px}.music-control,.scroll-up{width:55px;height:55px}.music-control{top:20px;right:20px}.scroll-up{bottom:20px;right:20px}.toast{right:20px;left:20px;transform:translateY(-200px)}.toast.show{transform:translateY(0)}.timeline::before{left:30px}.timeline-item{flex-direction:row!important}.timeline-content{width:calc(100% - 80px);margin-left:80px!important;margin-right:5px!important}.timeline-marker{left:30px}h1{font-size:2em}}@media (max-width:480px){.hero-banner .fade-in{height:30vh}.wedding-details{grid-template-columns:1fr;gap:15px}.save-the-date{padding:20px 30px}.parent-label{font-size:.95rem}.parent-name{font-size:1.5rem}}@media (max-width:368px){.parent-name{font-size:1.2rem}}.album-section{text-align:center;padding:40px 20px}.album-section h3{font-family:"SVN Magellin",serif;font-size:40px;margin-bottom:10px;color:var(--primary-red)}.album-section p{font-style:italic}.album-section-quote{font-family:"SVN Magellin",serif;font-size:3.5rem;font-style:italic;margin:10px 0}.slider-section{width:100%;max-width:900px;margin:auto;position:relative}.slider-container{position:relative;overflow:hidden}.slide{width:100%;display:none;transition:opacity 0.6s ease}.slide.active{display:block}.slide img{width:100%;display:block;border-radius:8px}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgb(0 0 0 / .5);color:#fff;border:none;padding:10px 16px;cursor:pointer;font-size:20px;border-radius:50%}.prev{left:10px}.next{right:10px}.nav-btn:hover{background:rgb(0 0 0 / .7)}.dots{text-align:center;margin-top:10px}.dot{display:inline-block;width:12px;height:12px;margin:0 4px;background:#ccc;border-radius:50%;cursor:pointer}.dot.active{background:#333}.invite-popup{position:fixed;inset:0;background:rgb(0 0 0 / .6);display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;transition:all 0.4s ease;z-index:9999}.invite-popup.show{opacity:1;visibility:visible}.envelope{width:300px;height:200px;background:#f4e7d7;position:relative;cursor:pointer}.flap{position:absolute;top:0;width:100%;height:100px;background:#e6c9a8;transform-origin:top;transition:transform 0.6s ease}.envelope.open .flap{transform:rotateX(180deg)}.letter{position:absolute;bottom:0;width:100%;height:100%;transform:translateY(60px);opacity:0;transition:all 0.6s ease}.envelope.open .letter{transform:translateY(0);opacity:1}.popup-content{position:relative}.close-btn{position:absolute;top:-40px;right:-40px;width:36px;height:36px;border-radius:50%;border:none;background:rgb(255 255 255 / .9);font-size:20px;cursor:pointer;box-shadow:0 4px 10px rgb(0 0 0 / .2)}.close-btn:hover{background:#fff}@keyframes slideIn{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}