@import"https://fonts.googleapis.com/css2?family=Cormorant+Upright:wght@400;500;600;700&family=Lato:wght@300;400;700&display=swap";:root{--color-primary: #1A4D2E;--color-secondary: #D4AF37;--color-background: #F9F7F2;--color-text: #2C2C2C;--font-heading: "Cormorant Upright", serif;--font-body: "Lato", sans-serif}body{margin:0;padding:0;font-family:var(--font-body);background-color:var(--color-background);color:var(--color-text);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-primary);margin-top:0}h2{font-size:3rem;text-align:center;margin-bottom:2rem}button{cursor:pointer;border:none;background-color:var(--color-primary);color:#fff;padding:10px 20px;font-size:1rem;transition:background-color .3s ease}button:hover{background-color:#143d24}section{padding:4rem 2rem;max-width:1200px;margin:0 auto}.gold-accent{color:var(--color-secondary)}.header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 2rem;background-color:#fff;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000}.logo-container{display:flex;align-items:center}.logo-img{height:80px;width:auto}.header nav ul{display:flex;list-style:none;gap:2rem;margin:0;padding:0}.header nav a{text-decoration:none;color:var(--color-text);font-weight:500;transition:color .3s;font-family:var(--font-heading);font-size:1.1rem}.header nav a:hover{color:var(--color-primary)}.menu-toggle{display:none;flex-direction:column;justify-content:space-between;width:30px;height:21px;background:transparent!important;border:none;padding:0;cursor:pointer;z-index:1001}.menu-toggle:hover{background:transparent!important}.menu-toggle span{width:100%;height:3px;background-color:var(--color-primary);border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}@media(max-width:768px){.header{padding:.5rem 1.5rem}.menu-toggle{display:flex}.header nav{position:fixed;top:0;right:-100%;width:70%;height:100vh;background-color:#fff;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease-in-out;z-index:1000;display:flex;justify-content:center;align-items:center}.header nav.nav-open{right:0}.header nav ul{flex-direction:column;align-items:center;gap:2.5rem}.header nav a{font-size:1.5rem}.menu-toggle.open span:nth-child(1){transform:rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0;transform:translate(20px)}.menu-toggle.open span:nth-child(3){transform:rotate(-45deg)}}.hero{height:90vh;display:flex;justify-content:center;align-items:center;text-align:center;background:linear-gradient(#1a4d2e1a,#1a4d2e0d),url(/assets/hero-photo.jpeg);background-size:cover;background-position:center;color:#fff}.hero h1{font-size:4rem;margin-bottom:1rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.hero .gold-accent{color:var(--color-secondary)}.hero .date{font-size:1.5rem;margin-bottom:.5rem;letter-spacing:2px}.hero .location{font-size:1.2rem;text-transform:uppercase;letter-spacing:1px}#locations{padding:0;max-width:none}#locations>h2{text-align:center;padding:3rem 2rem 1rem;margin:0}.location-item{position:relative;padding:8rem 2rem 9rem;margin:0;overflow:hidden}.parallax-bg{position:absolute;inset:-50% 0;background-size:cover;background-position:center;opacity:.2;z-index:0;will-change:transform}.location-item:after{content:"";position:absolute;top:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,var(--color-background) 0%,transparent 100%);z-index:1;pointer-events:none}.location-content{position:relative;z-index:2;max-width:800px;margin:0 auto;text-align:center}.location-ceremony{background:linear-gradient(135deg,#1a4d2e14,#1a4d2e26,#1a4d2e14)}.location-ceremony .parallax-bg{background-image:url(/assets/ceremony-bg.png)}.location-ceremony h3{color:var(--color-primary)}.location-ceremony .location-content:after{content:"";position:absolute;bottom:-9rem;left:-50%;right:-50%;height:120px;background:linear-gradient(to bottom,transparent 0%,var(--color-background) 100%);z-index:3;pointer-events:none}.location-celebration{background:linear-gradient(135deg,#d4af3714,#d4af3726,#d4af3714)}.location-celebration .parallax-bg{background-image:url(/assets/celebration-bg.png)}.location-celebration h3{color:var(--color-secondary)}.location-celebration .location-content:after{content:"";position:absolute;bottom:-9rem;left:-50%;right:-50%;height:120px;background:linear-gradient(to bottom,transparent 0%,var(--color-background) 100%);z-index:3;pointer-events:none}.location-item h3{font-size:2rem;margin-bottom:.5rem}.location-time{font-size:1.3rem;font-weight:600;color:var(--color-secondary);margin:.5rem 0 1.5rem;text-shadow:1px 1px 0 rgba(0,0,0,.3),-1px -1px 0 rgba(0,0,0,.1),1px -1px 0 rgba(0,0,0,.2),-1px 1px 0 rgba(0,0,0,.2)}.map-container{position:relative;margin-top:1rem;border:5px solid white;box-shadow:0 4px 20px #00000026;border-radius:12px;overflow:hidden}.map-overlay-pin{position:absolute;top:10px;right:10px;background:#fff;padding:5px 10px;border-radius:50px;box-shadow:0 2px 5px #0003;font-size:1.5rem;pointer-events:none;z-index:10}@media(max-width:768px){.location-item{padding:2rem 1rem 3rem}.location-item h3{font-size:1.6rem}.location-time{font-size:1.1rem}}.timeline-subtitle{font-size:1.2rem;color:var(--color-secondary);margin-bottom:2rem;font-style:italic;text-align:center}.timeline-container{max-width:600px;margin:0 auto;position:relative;padding-left:60px}.timeline-container:before{content:"";position:absolute;left:25px;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--color-secondary),var(--color-primary));border-radius:3px}.timeline-item{position:relative;margin-bottom:2rem;display:flex;align-items:flex-start}.timeline-icon{position:absolute;left:-48px;width:50px;height:50px;background:#fff;border:3px solid var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 3px 10px #0000001a;z-index:1}.timeline-content{background:#fff;padding:1rem 1.5rem;border-radius:10px;box-shadow:0 4px 15px #00000014;border-left:4px solid var(--color-secondary);flex:1;transition:transform .3s ease,box-shadow .3s ease}.timeline-content:hover{transform:translate(5px);box-shadow:0 6px 20px #0000001f}.timeline-time{display:inline-block;background:var(--color-primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.timeline-title{margin:0;font-size:1.1rem;color:var(--color-text);line-height:1.4}@media(max-width:600px){.timeline-container{padding-left:50px}.timeline-container:before{left:20px}.timeline-icon{left:-43px;width:40px;height:40px;font-size:1.2rem}.timeline-content{padding:.8rem 1rem}.timeline-time{font-size:.8rem}.timeline-title{font-size:1rem}}.rsvp-form{max-width:600px;margin:2rem auto;display:flex;flex-direction:column;gap:1.5rem;text-align:left;background:#fff;padding:2.5rem;border-radius:15px;box-shadow:0 10px 30px #0000000d}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:700;color:var(--color-primary);font-size:1.1rem}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-secondary)}.radio-group{display:flex;gap:1rem;margin-top:.5rem}.radio-option{flex:1;position:relative}.radio-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.radio-label{display:block;padding:12px;text-align:center;border:2px solid #eee;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fdfdfd;font-weight:500}.radio-option input[type=radio]:checked+.radio-label{border-color:var(--color-secondary);background-color:#fff9e6;color:var(--color-primary);box-shadow:0 4px 10px #d4af371a}.rsvp-submit-btn{margin-top:1rem;padding:15px;font-weight:700;letter-spacing:1px;border-radius:8px;text-transform:uppercase}.status-message{margin-top:1rem;padding:15px;border-radius:8px;text-align:center;font-weight:500}.status-success{background-color:#e6f4ea;color:#1e7e34}.status-error{background-color:#fce8e6;color:#d93025}#menu{position:relative;padding:4rem 2rem;overflow:hidden}.menu-parallax-wrapper{position:absolute;inset:0;overflow:hidden}.menu-parallax-wrapper .parallax-bg{position:absolute;inset:-50% 0;background-image:url(/assets/menu-bg.png);background-size:cover;background-position:center;opacity:.3;z-index:0;will-change:transform}#menu:after{content:"";position:absolute;top:0;left:0;right:0;height:100px;background:linear-gradient(to bottom,var(--color-background) 0%,transparent 100%);z-index:1;pointer-events:none}.menu-content{position:relative;z-index:2;max-width:600px;margin:0 auto;text-align:center}.menu-content h3{color:var(--color-primary);font-size:1.6rem;margin-top:2rem;margin-bottom:.5rem}.menu-content h3:first-child{margin-top:0}.menu-content p{margin:.3rem 0}.fade-in{animation:fadeIn .8s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}#faq{background-color:var(--color-background);padding:4rem 2rem}#faq h2{margin-bottom:3rem}.faq-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.faq-item{background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000000d;overflow:hidden;transition:box-shadow .3s ease;cursor:pointer}.faq-item:hover{box-shadow:0 6px 12px #0000001a}.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background-color:#fff}.faq-question h3{margin:0;font-size:1.5rem;color:var(--color-primary);font-family:var(--font-heading)}.faq-toggle-icon{font-size:2rem;color:var(--color-secondary);line-height:1;font-weight:300}.faq-answer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease-out}.faq-item.active .faq-answer{grid-template-rows:1fr}.faq-answer-content{overflow:hidden}.faq-answer-content p{padding:0 2rem 2rem;margin:0;font-size:1.1rem;line-height:1.6;color:var(--color-text)}.faq-image{display:block;max-width:250px;height:auto;margin:1rem auto 1.5rem;opacity:.8}.final-photo-section{text-align:center;padding:4rem 2rem;background:linear-gradient(to bottom,var(--color-background),rgba(26,77,46,.05))}.photo-frame{max-width:800px;margin:0 auto;position:relative;border:8px solid white;box-shadow:0 10px 40px #00000026,0 0 0 1px #d4af374d;border-radius:4px;overflow:hidden;background:var(--color-background)}.final-photo-img{width:100%;height:auto;display:block;transition:transform .5s ease}.photo-frame:hover .final-photo-img{transform:scale(1.02)}.photo-placeholder{display:none;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:linear-gradient(135deg,#1a4d2e0d,#d4af3714);color:var(--color-primary)}.photo-placeholder.show{display:flex}.placeholder-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.photo-placeholder p{font-family:var(--font-heading);font-size:1.5rem;font-style:italic;opacity:.7}.photo-caption{margin-top:1.5rem;font-family:var(--font-heading);font-size:1.4rem;color:var(--color-primary);font-style:italic}.photo-frame:before,.photo-frame:after{content:"";position:absolute;width:30px;height:30px;border:3px solid var(--color-secondary);opacity:.6}.photo-frame:before{top:15px;left:15px;border-right:none;border-bottom:none}.photo-frame:after{bottom:15px;right:15px;border-left:none;border-top:none}@media(max-width:600px){.photo-frame{border-width:5px}.photo-placeholder{min-height:250px}.placeholder-icon{font-size:3rem}.photo-placeholder p{font-size:1.2rem}}.parallax-decorations-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;overflow:hidden}@media(max-width:1024px){.parallax-decorations-container{display:block}}.invitation-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;width:100vw;background-color:var(--dark-green, #10261f);overflow:hidden;position:relative;font-family:Cormorant Upright,serif;padding:2rem 1rem;box-sizing:border-box}.slideshow-wrapper{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;z-index:1}.invitation-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;color:#fffc;font-size:1.2rem;letter-spacing:1px}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--gold, #d4af37);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.slideshow{position:relative;width:100%;max-width:85vh;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 10px 30px #0006;border-radius:12px;background-color:transparent}:fullscreen .invitation-container{background-color:var(--dark-green, #10261f);padding:0;height:100vh;max-height:100vh;overflow:hidden}:fullscreen .slideshow{max-width:100vw;flex:1 1 auto;min-height:0;border-radius:0;background-color:var(--dark-green, #10261f);box-shadow:none}:fullscreen .invitation-img{max-height:calc(100vh - 70px);width:100vw;object-fit:contain;border-radius:0}:fullscreen .fullscreen-button{background:#fff3;color:#fff}.slides-track{display:flex;width:100%;transition:transform .3s cubic-bezier(.25,.8,.25,1)}.slide{min-width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden}.invitation-img{width:100%;max-height:80vh;display:block;border-radius:12px;object-fit:contain;transition:transform .15s ease-out;touch-action:none;user-select:none;-webkit-user-select:none}.nav-button{position:absolute;top:50%;transform:translateY(-50%);background-color:#fffc;color:var(--dark-green);border:none;width:45px;height:45px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background-color .3s,opacity .3s,transform .2s;z-index:10;box-shadow:0 4px 10px #0003}.nav-button:hover{background-color:#fff;transform:translateY(-50%) scale(1.05)}.nav-button.hidden{opacity:0;pointer-events:none}.prev-button{left:15px}.next-button{right:15px}.fullscreen-button{position:absolute;top:15px;right:15px;background:#fff9;border:none;color:var(--dark-green);border-radius:8px;padding:8px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background-color .3s,transform .2s;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0003}.fullscreen-button:hover{background:#ffffffe6;transform:scale(1.05)}.invitation-footer{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;min-height:80px}:fullscreen .invitation-footer{margin-top:0;padding:.5rem 0;min-height:auto;gap:.5rem;flex-shrink:0;position:relative;z-index:30}.indicators{display:flex;gap:10px}.dot{width:10px;height:10px;border-radius:50%;background-color:#ffffff4d;transition:background-color .3s,transform .3s;cursor:pointer}.dot.active{background-color:var(--gold, #d4af37);transform:scale(1.3)}.enter-website-button{background-color:var(--gold, #d4af37);color:#fff;border:none;padding:14px 35px;font-size:1.2rem;border-radius:30px;cursor:pointer;transition:transform .3s,background-color .3s,box-shadow .3s;font-family:inherit;text-transform:uppercase;letter-spacing:2px;box-shadow:0 4px 15px #d4af374d;animation:fadeIn .5s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.enter-website-button:hover{background-color:#b5952f;transform:translateY(-2px);box-shadow:0 6px 20px #d4af3780}@media(max-width:600px){.invitation-container{padding:0;justify-content:flex-start;padding-top:2rem}.slideshow{max-width:90vw;border-radius:12px}.invitation-img{border-radius:12px}.nav-button{width:38px;height:38px;font-size:1.2rem}.prev-button{left:8px}.next-button{right:8px}}.envelope-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--dark-green, #10261f);display:flex;justify-content:center;align-items:center;z-index:9999;cursor:pointer;overflow:hidden;perspective:1000px}.envelope-overlay.opening{pointer-events:none;animation:fadeOverlayOut 1s ease-in-out 1.2s both}@keyframes fadeOverlayOut{0%{opacity:1;visibility:visible}99%{opacity:0;visibility:visible}to{opacity:0;visibility:hidden}}.envelope-wrapper{position:relative;width:min(340px,90vw);aspect-ratio:3 / 2;background-color:#5b6b55;box-shadow:0 15px 40px #00000080;border-radius:6px;display:flex;justify-content:center;align-items:center;transform-style:preserve-3d}.envelope-overlay.opening .envelope-wrapper{animation:slideWrapperDown 1s cubic-bezier(.4,0,.2,1) .8s both}@keyframes slideWrapperDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100vh);opacity:0}}.envelope-back{position:absolute;inset:0;background-color:#4f5e49;border-radius:6px;box-shadow:inset 0 0 40px #0000001a}.envelope-letter{position:absolute;width:90%;height:85%;background-color:#fff;bottom:5%;border-radius:4px;display:flex;justify-content:center;align-items:center;padding:3%;box-sizing:border-box;box-shadow:0 2px 10px #0000001a;z-index:1}.envelope-preview-img{width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:2px}.envelope-overlay.opening .envelope-letter{animation:letterPeek .8s ease-out .3s both}@keyframes letterPeek{0%{transform:translateY(0);opacity:1}to{transform:translateY(-45%);opacity:1}}.envelope-front{position:absolute;inset:0;z-index:2;border-radius:6px;overflow:hidden}.envelope-front:before{content:"";position:absolute;inset:0;background-color:#63755c;clip-path:polygon(0 0,50% 50%,100% 0,100% 100%,0 100%)}.envelope-front:after{content:"";position:absolute;inset:0;background-color:#6e8267;clip-path:polygon(0 100%,50% 48%,100% 100%);filter:drop-shadow(0 -4px 4px rgba(0,0,0,.1))}.envelope-flap{position:absolute;top:0;left:0;width:100%;height:60%;background-color:#65785e;z-index:3;clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top;backface-visibility:hidden}.envelope-flap-shadow{position:absolute;top:0;left:0;width:100%;height:61%;background-color:#00000026;z-index:2;clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top}.envelope-overlay.opening .envelope-flap{animation:openFlap .6s ease-in-out both}@keyframes openFlap{0%{transform:rotateX(0)}to{transform:rotateX(180deg)}}@keyframes changeZIndex{0%{z-index:3}to{z-index:0}}.wax-seal{position:absolute;top:55%;left:50%;transform:translate(-50%,-50%);width:clamp(60px,15vw,80px);aspect-ratio:1;z-index:4;display:flex;justify-content:center;align-items:center;filter:drop-shadow(0 4px 6px rgba(0,0,0,.4))}.wax-seal-img{width:100%;height:100%;object-fit:contain;z-index:5;mix-blend-mode:multiply}.envelope-overlay.opening .wax-seal{animation:breakSeal .4s ease-in-out both}@keyframes breakSeal{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}@keyframes gentlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.envelope-overlay:not(.opening):hover .envelope-wrapper{animation-play-state:paused;transform:scale(1.05)}.envelope-hint{position:absolute;bottom:15%;color:#ffffffb3;font-size:1.2rem;letter-spacing:2px;animation:fadeInOut 2s infinite ease-in-out;pointer-events:none}@keyframes fadeInOut{0%,to{opacity:.4}50%{opacity:.9}}.envelope-overlay.opening .envelope-hint{opacity:0;transition:opacity .3s;animation:none}
