:root{--green:#5A8B5F;--green-d:#3D6742;--peach:#FFB89A;--white:#FFF;--cream:#FEFDFB;--text:#4A5047;--dark:#2A2F28;--serif:'Crimson Text',serif;--sans:'Inter',sans-serif}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--sans);color:var(--text);background:var(--cream);line-height:1.6;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
.wrap{max-width:1260px;margin:0 auto;padding:0 40px}.container{max-width:920px;margin:0 auto;padding:0 40px}
.top{position:fixed;top:0;left:0;width:100%;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);box-shadow:0 2px 14px rgba(90,139,95,.12);z-index:1000;transition:all .3s}
.top.scrolled{box-shadow:0 3px 20px rgba(90,139,95,.16)}.top-bar{display:flex;align-items:center;justify-content:space-between;height:82px}
.initials{display:flex;align-items:center;gap:6px;font-family:var(--serif);font-size:22px;font-weight:600;color:var(--green-d);padding:10px 18px;border:2px solid var(--green);border-radius:50px;background:linear-gradient(135deg,rgba(90,139,95,.1),rgba(255,255,255,.5))}
.initials i{font-size:17px;color:var(--peach)}.initials.small{font-size:17px;padding:7px 14px}.initials.small i{font-size:13px}
.nav{display:flex;gap:32px}.link{font-size:13px;font-weight:600;color:var(--text);text-decoration:none;letter-spacing:1px;text-transform:uppercase;transition:all .3s;position:relative;padding-bottom:3px}
.link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--green);transition:width .3s}.link:hover,.link.active{color:var(--green-d)}.link:hover::after,.link.active::after{width:100%}
.menu-btn{display:none;flex-direction:column;gap:5px;background:0 0;border:none;cursor:pointer;padding:6px}.menu-btn span{width:24px;height:2px;background:var(--green-d);transition:all .3s}
.menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.menu-btn.active span:nth-child(2){opacity:0}.menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:108px 40px 72px}
.hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:-2}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(90,139,95,.85) 0%,rgba(61,103,66,.81) 50%,rgba(255,184,154,.75) 100%);z-index:-1}
.leaves{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0}
.leaf{position:absolute;width:16px;height:18px;background:linear-gradient(135deg,rgba(255,184,154,.6),rgba(90,139,95,.5));clip-path:polygon(50% 0,100% 38%,85% 100%,50% 85%,15% 100%,0 38%);opacity:0;animation:floatLeaf 16s infinite ease-in-out}
.leaf:nth-child(1){left:15%;animation-delay:0s}.leaf:nth-child(2){left:40%;animation-delay:4s}.leaf:nth-child(3){left:65%;animation-delay:8s}.leaf:nth-child(4){left:85%;animation-delay:12s}
@keyframes floatLeaf{0%{transform:translateY(110vh) rotate(0deg);opacity:0}10%{opacity:.7}90%{opacity:.5}100%{transform:translateY(-20vh) rotate(360deg);opacity:0}}
.hero-content{position:relative;z-index:1;text-align:center;color:var(--white);max-width:840px}.badge{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--white);background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.3);padding:8px 19px;border-radius:20px;margin-bottom:27px}
.names{font-family:var(--serif);font-size:84px;font-weight:600;line-height:1.1;margin-bottom:20px;display:flex;flex-direction:column;gap:7px}.name{display:block}
.and{font-size:42px;opacity:.88;margin:7px 0}.tagline{font-size:17px;font-weight:300;letter-spacing:.6px;margin-bottom:27px}
.details{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:39px;font-size:15px}.detail{display:flex;align-items:center;gap:7px}.detail i{font-size:17px}.dot{opacity:.6}
.countdown{display:flex;justify-content:center;gap:25px;margin-bottom:39px}.unit{display:flex;flex-direction:column;align-items:center;gap:6px}
.value{font-family:var(--serif);font-size:48px;font-weight:600;line-height:1;color:var(--white);min-width:72px;padding:10px 12px;border:2px solid rgba(255,255,255,.4);background:rgba(255,255,255,.1);border-radius:6px}
.label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px}.godparents{display:flex;flex-direction:column;gap:5px;padding:17px 27px;border-top:1px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.25)}
.godparents-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;opacity:.86}.godparents-names{font-family:var(--serif);font-size:21px;font-weight:600}
section{padding:108px 40px;position:relative}.heading{text-align:center;margin-bottom:62px}.subtitle{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--green);margin-bottom:10px}
.title{font-family:var(--serif);font-size:50px;font-weight:600;color:var(--dark);line-height:1.2;margin-bottom:16px}.line{width:82px;height:3px;background:linear-gradient(90deg,transparent,var(--peach),transparent);margin:0 auto}
.story{background:linear-gradient(180deg,var(--cream) 0%,#F5F3F0 100%)}.story-grid{display:grid;grid-template-columns:38% 1fr;gap:66px;align-items:center}
.img-wrapper{position:relative;padding:18px}.img-wrapper img{width:100%;height:auto;display:block;border-radius:8px;box-shadow:0 10px 34px rgba(90,139,95,.2)}
.story-text{padding:15px 0}.story-text p{font-size:16px;font-weight:300;line-height:1.73;margin-bottom:21px}.story-text p:last-child{margin-bottom:0}
.couple{background:var(--white)}.couple-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:56px;max-width:1040px;margin:0 auto}
.profile{display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .4s}.profile:hover{transform:translateY(-9px)}
.profile-img{margin-bottom:27px;position:relative}.photo-frame{position:relative;width:290px;height:368px;overflow:hidden;border-radius:8px;box-shadow:0 13px 40px rgba(90,139,95,.18);transition:all .4s}
.bride-frame{border:3px solid var(--green)}.groom-frame{border:3px solid var(--peach)}.profile:hover .photo-frame{box-shadow:0 19px 52px rgba(90,139,95,.27)}
.photo{width:100%;height:100%;object-fit:cover;transition:transform .4s}.profile:hover .photo{transform:scale(1.05)}
.profile-text{max-width:290px}.profile-name{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--dark);margin-bottom:6px}
.profile-role{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--green);margin-bottom:17px}
.profile-bio{font-size:15px;font-weight:300;line-height:1.63}
.events{background:linear-gradient(180deg,#F5F3F0 0%,var(--cream) 100%)}.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:35px}
.event{background:var(--white);border-radius:8px;overflow:hidden;box-shadow:0 6px 27px rgba(90,139,95,.13);transition:all .4s;display:flex;flex-direction:column}
.event:hover{transform:translateY(-6px);box-shadow:0 11px 39px rgba(90,139,95,.2)}.event-img{position:relative;height:215px;overflow:hidden}
.event-photo{width:100%;height:100%;object-fit:cover;transition:transform .5s}.event:hover .event-photo{transform:scale(1.06)}
.event-icon{position:absolute;top:15px;right:15px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.94);border:2px solid var(--peach);border-radius:50%;box-shadow:0 3px 13px rgba(0,0,0,.12)}
.event-icon i{font-size:21px;color:var(--green-d)}.event-body{padding:27px 23px;flex:1;display:flex;flex-direction:column}.event-title{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--dark);margin-bottom:16px}
.event-row{display:flex;align-items:center;gap:9px;font-size:14px;margin-bottom:9px}.event-row i{font-size:17px;color:var(--green)}
.event-location{display:flex;align-items:flex-start;gap:9px;margin-bottom:21px}.event-location i{font-size:17px;color:var(--green);margin-top:2px}.location-info{flex:1}
.location-name{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:3px}.location-address{font-size:13px;font-weight:300;line-height:1.4}
.event-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--green-d);text-decoration:none;padding:10px 19px;border:1px solid var(--green);border-radius:6px;transition:all .3s;margin-top:auto}
.event-button:hover{background:var(--green);color:var(--white)}
.rsvp{background:var(--white)}.rsvp-wrapper{background:#F7F5F2;padding:50px 42px;border-radius:8px;box-shadow:0 9px 34px rgba(90,139,95,.14)}
.rsvp-intro{font-size:16px;font-weight:300;line-height:1.63;text-align:center;margin-bottom:34px;max-width:620px;margin-left:auto;margin-right:auto}
.form{max-width:620px;margin:0 auto}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:21px;margin-bottom:21px}
.form-group{display:flex;flex-direction:column;gap:9px}.form-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--green-d)}
.form-input,.form-textarea{font-family:var(--sans);font-size:15px;padding:12px 14px;border:1px solid #D4CDC6;border-radius:6px;background:var(--white);color:var(--text);transition:all .3s}
.form-input:focus,.form-textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(90,139,95,.12)}.radio-group{display:flex;flex-direction:column;gap:10px}
.radio{display:flex;align-items:center;gap:9px;font-size:15px;cursor:pointer}.radio input[type=radio]{width:17px;height:17px;accent-color:var(--green);cursor:pointer}
.form-submit{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--white);background:linear-gradient(135deg,var(--green-d),var(--green));border:none;border-radius:6px;padding:14px 28px;cursor:pointer;transition:all .3s;margin-top:9px}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(90,139,95,.33)}.form-alert{margin-top:21px;padding:14px 17px;border-radius:6px;font-size:14px;text-align:center;display:none}
.form-alert.success{display:block;background:#E7F4E7;color:#2E7D32;border:1px solid #4CAF50}.form-alert.error{display:block;background:#FFECEC;color:#C62828;border:1px solid #F44336}
.footer{background:var(--green-d);color:var(--white);padding:54px 40px}.footer-content{display:flex;flex-direction:column;align-items:center;gap:27px;text-align:center}
.footer-main{display:flex;flex-direction:column;align-items:center;gap:13px}.footer-names{font-family:var(--serif);font-size:29px;font-weight:600}
.footer-date{font-size:14px;font-weight:300;opacity:.9}.footer-menu{display:flex;gap:21px;flex-wrap:wrap;justify-content:center}
.footer-menu a{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--white);text-decoration:none;opacity:.9;transition:opacity .3s}.footer-menu a:hover{opacity:1}
.footer-text{font-family:var(--serif);font-size:16px;font-style:italic;opacity:.84}.reveal{opacity:0;transform:translateY(34px);transition:all .73s}.reveal.revealed{opacity:1;transform:translateY(0)}
@media (max-width:1024px){.story-grid{grid-template-columns:1fr;gap:42px}.events-grid{grid-template-columns:1fr;max-width:470px;margin:0 auto}.couple-grid{grid-template-columns:1fr;gap:58px}}
@media (max-width:768px){.wrap,.container{padding:0 21px}section{padding:74px 21px}.top-bar{height:68px}.nav{position:fixed;top:68px;left:0;width:100%;background:rgba(255,255,255,.98);backdrop-filter:blur(8px);flex-direction:column;gap:0;padding:17px 21px;box-shadow:0 5px 20px rgba(90,139,95,.19);transform:translateY(-130%);transition:transform .4s}
.nav.active{transform:translateY(0)}.link{padding:10px 0;width:100%;text-align:center}.menu-btn{display:flex}.hero{padding:92px 21px 54px}.names{font-size:50px}.and{font-size:28px}
.countdown{gap:9px;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:5px}.unit{flex-shrink:0}.value{font-size:36px;min-width:64px;padding:8px 10px}
.title{font-size:36px}.form-row{grid-template-columns:1fr}.rsvp-wrapper{padding:36px 24px}.profile-name{font-size:25px}.photo-frame{width:255px;height:333px}}
