@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Great+Vibes&family=Inter:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#b8860b;--gold-light:#d4a843;--gold-soft:#e8d5a8;
  --dark:#2c2418;--dark2:#3d3228;--cream:#faf5ec;--cream2:#f3ead8;
  --white:#fff;--text:#3d3529;--text-light:#7a6e5d;
  --green-soft:#e8edd4;--pink-soft:#f5e1d0;
}
html{scroll-behavior:smooth;scroll-snap-type:y proximity}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Playfair Display',serif}
.cursive{font-family:'Great Vibes',cursive}
.serif{font-family:'Cormorant Garamond',serif}

/* ==================== NAVIGATION ==================== */
.main-nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  background:rgba(250,245,236,.92);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(184,134,11,.12);
  transition:transform .5s cubic-bezier(.4,0,.2,1),box-shadow .5s;
  transform:translateY(-100%);
}
.main-nav.visible{transform:translateY(0);box-shadow:0 4px 30px rgba(0,0,0,.06)}
.nav-inner{
  display:flex;justify-content:center;align-items:center;gap:clamp(12px,3vw,40px);
  padding:16px 20px;max-width:1100px;margin:0 auto;
}
.nav-link{
  color:var(--dark2);text-decoration:none;font-size:.8rem;font-weight:500;
  letter-spacing:1.5px;text-transform:uppercase;position:relative;
  transition:color .3s;padding:4px 0;
}
.nav-link::after{
  content:'';position:absolute;bottom:-2px;left:50%;width:0;height:2px;
  background:var(--gold);transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateX(-50%);border-radius:2px;
}
.nav-link:hover{color:var(--gold)}
.nav-link:hover::after{width:100%}

/* ==================== HERO SPLIT ==================== */
.hero{
  min-height:100vh;width:100%;display:grid;
  grid-template-columns:1fr 1fr;position:relative;overflow:hidden;
}
.hero-photo{
  position:relative;overflow:hidden;
}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;
  animation:heroZoom 25s ease-in-out infinite alternate;
}
@keyframes heroZoom{0%{transform:scale(1)}100%{transform:scale(1.08)}}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,transparent 70%,var(--cream));
}
.hero-content{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:clamp(30px,5vw,60px);text-align:center;position:relative;
  background:var(--cream);
}
.hero-content::before{
  content:'';position:absolute;top:20px;right:20px;width:120px;height:120px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='%23d4a84330' stroke-width='0.5'%3E%3Cpath d='M80 10 Q90 30 70 50 Q50 70 30 60 Q10 50 20 30 Q30 10 50 20 Q70 30 60 50'/%3E%3Cpath d='M20 80 Q30 60 50 70 Q70 80 60 90'/%3E%3C/svg%3E") no-repeat center/contain;
  opacity:.6;animation:floatDecor 8s ease-in-out infinite;
}
.hero-content::after{
  content:'';position:absolute;bottom:20px;left:20px;width:100px;height:100px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='%23d4a84330' stroke-width='0.5'%3E%3Cpath d='M20 90 Q10 70 30 50 Q50 30 70 40 Q90 50 80 70 Q70 90 50 80 Q30 70 40 50'/%3E%3Cpath d='M80 20 Q70 40 50 30 Q30 20 40 10'/%3E%3C/svg%3E") no-repeat center/contain;
  opacity:.6;transform:rotate(180deg);animation:floatDecor 8s ease-in-out infinite reverse;
}
@keyframes floatDecor{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(5deg)}}
.hero-subtitle{
  font-size:clamp(.9rem,2vw,1.15rem);color:var(--text-light);letter-spacing:2px;
  margin-bottom:8px;opacity:0;animation:fadeSlideUp .8s .3s forwards;
}
.hero-names{
  font-family:'Great Vibes',cursive;font-size:clamp(2.2rem,5vw,3.8rem);
  color:var(--dark);line-height:1.3;margin-bottom:5px;
  opacity:0;animation:fadeSlideUp .8s .6s forwards;
}
.hero-date{
  font-family:'Cormorant Garamond',serif;font-size:clamp(1rem,2.5vw,1.4rem);
  color:var(--gold);letter-spacing:3px;margin-bottom:30px;
  opacity:0;animation:fadeSlideUp .8s .9s forwards;
}
/* HERO COUNTDOWN */
.hero-countdown{
  display:flex;gap:clamp(8px,2vw,18px);margin-bottom:30px;
  opacity:0;animation:fadeSlideUp .8s 1.2s forwards;
}
.hero-countdown .cbox{
  width:clamp(58px,10vw,75px);height:clamp(58px,10vw,75px);
  border:1.5px solid var(--gold-soft);border-radius:14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(184,134,11,.04);transition:all .4s;position:relative;overflow:hidden;
}
.hero-countdown .cbox::before{
  content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(184,134,11,.08),transparent);
  opacity:0;transition:opacity .4s;
}
.hero-countdown .cbox:hover::before{opacity:1}
.hero-countdown .cbox:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 8px 25px rgba(184,134,11,.12)}
.hero-countdown .cnum{font-family:'Playfair Display',serif;font-size:clamp(1.4rem,3vw,1.9rem);font-weight:700;color:var(--dark);line-height:1}
.hero-countdown .clbl{font-size:.6rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);margin-top:3px}
.hero-btn{
  display:inline-flex;align-items:center;gap:8px;padding:14px 35px;
  border:1.5px solid var(--gold);border-radius:50px;background:transparent;
  color:var(--gold);font-size:.85rem;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;cursor:pointer;transition:all .4s;text-decoration:none;
  opacity:0;animation:fadeSlideUp .8s 1.5s forwards;position:relative;overflow:hidden;
}
.hero-btn::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.4,0,.2,1);
  border-radius:50px;
}
.hero-btn:hover::before{transform:scaleX(1);transform-origin:left}
.hero-btn:hover{color:var(--white)}
.hero-btn span{position:relative;z-index:1}
.hero-btn svg{position:relative;z-index:1;width:16px;height:16px;stroke:currentColor}

.scroll-hint{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:5px;
  opacity:0;animation:fadeSlideUp .8s 2s forwards;
}
.scroll-hint span{font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-light)}
.scroll-mouse{
  width:24px;height:38px;border:2px solid var(--gold-soft);border-radius:12px;
  position:relative;
}
.scroll-mouse::after{
  content:'';position:absolute;top:8px;left:50%;width:3px;height:8px;
  background:var(--gold);border-radius:3px;transform:translateX(-50%);
  animation:scrollDot 2s infinite;
}
@keyframes scrollDot{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(12px)}}

/* ==================== ANIMATIONS ==================== */
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeSlideLeft{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeSlideRight{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes revealLine{from{width:0}to{width:60px}}
@keyframes scaleIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes rotateIn{from{opacity:0;transform:rotate(-10deg) scale(.9)}to{opacity:1;transform:rotate(0) scale(1)}}
.reveal{opacity:0;transform:translateY(40px);transition:all .8s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-50px);transition:all .8s cubic-bezier(.4,0,.2,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:all .8s cubic-bezier(.4,0,.2,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.85);transition:all .8s cubic-bezier(.4,0,.2,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.stagger-1{transition-delay:.1s}
.stagger-2{transition-delay:.2s}
.stagger-3{transition-delay:.3s}
.stagger-4{transition-delay:.4s}

/* ==================== SPLIT INFO SECTION ==================== */
.info-split{
  display:grid;grid-template-columns:1fr 1fr;width:100%;
  min-height:auto;position:relative;
}
.info-split::before{
  content:'';position:absolute;top:0;left:50%;width:1px;height:100%;
  background:linear-gradient(to bottom,transparent,var(--gold-soft),transparent);
}
.info-card{
  padding:clamp(40px,5vw,80px) clamp(25px,4vw,60px);
  position:relative;
}
.info-card:first-child{background:var(--white)}
.info-card:last-child{background:var(--cream)}
.info-card .leaf-decor{
  position:absolute;width:80px;height:80px;opacity:.15;
}
.info-card .leaf-decor.top-right{top:15px;right:15px}
.info-card .leaf-decor.bottom-left{bottom:15px;left:15px;transform:rotate(180deg)}
.info-card h2{
  font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--dark);margin-bottom:20px;font-weight:600;
}
.info-card p{line-height:1.85;color:var(--text-light);font-size:clamp(.9rem,1.5vw,1rem)}
.gold-line{width:60px;height:2px;background:var(--gold);margin:20px 0;border-radius:2px}

/* TIMELINE */
.timeline{margin-top:25px;position:relative;padding-left:25px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold-soft)}
.timeline-item{position:relative;margin-bottom:20px;padding-left:20px}
.timeline-item::before{
  content:'';position:absolute;left:-29px;top:5px;width:10px;height:10px;
  border-radius:50%;background:var(--gold);border:2px solid var(--cream);
}
.timeline-item h4{font-family:'Playfair Display',serif;font-size:1rem;color:var(--dark);margin-bottom:4px}
.timeline-item p{font-size:.85rem;color:var(--text-light)}

/* EVENT DETAILS */
.event-detail{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.event-detail .icon-circle{
  width:42px;height:42px;border-radius:50%;background:rgba(184,134,11,.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid rgba(184,134,11,.15);
}
.event-detail .icon-circle svg{width:18px;height:18px;stroke:var(--gold)}
.event-detail .detail-text h4{font-size:.9rem;color:var(--dark);margin-bottom:2px;font-weight:600}
.event-detail .detail-text p{font-size:.85rem;color:var(--text-light)}
.mini-map{width:100%;height:180px;border-radius:16px;overflow:hidden;margin-top:15px;border:1px solid var(--gold-soft)}
.mini-map iframe{width:100%;height:100%;border:none}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;margin-top:15px;padding:10px 24px;
  border:1.5px solid var(--gold);border-radius:50px;background:transparent;
  color:var(--gold);font-size:.8rem;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;cursor:pointer;transition:all .4s;text-decoration:none;
}
.btn-outline:hover{background:var(--gold);color:var(--white)}
.btn-outline svg{width:14px;height:14px;stroke:currentColor}

/* ==================== COUPLE PHOTO SECTION ==================== */
.couple-section{
  padding:80px 20px;background:var(--white);text-align:center;width:100%;position:relative;
  overflow:hidden;
}
.couple-section::before,.couple-section::after{
  content:'';position:absolute;width:200px;height:200px;opacity:.06;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='%23b8860b' stroke-width='0.3'%3E%3Ccircle cx='50' cy='50' r='40'/%3E%3Ccircle cx='50' cy='50' r='30'/%3E%3Ccircle cx='50' cy='50' r='20'/%3E%3C/svg%3E") no-repeat center/contain;
}
.couple-section::before{top:-50px;left:-50px}
.couple-section::after{bottom:-50px;right:-50px}
.couple-photo{
  width:clamp(200px,30vw,280px);height:clamp(200px,30vw,280px);
  border-radius:50%;overflow:hidden;margin:0 auto 25px;
  border:3px solid var(--gold-soft);box-shadow:0 15px 50px rgba(184,134,11,.1);
  position:relative;
}
.couple-photo img{width:100%;height:100%;object-fit:cover}
.couple-photo::after{
  content:'';position:absolute;inset:-8px;border-radius:50%;
  border:1px dashed var(--gold-soft);animation:rotateSlow 30s linear infinite;
}
@keyframes rotateSlow{to{transform:rotate(360deg)}}

/* ==================== GALLERY ==================== */
.gallery-section{padding:80px 20px;background:var(--cream);text-align:center;width:100%}
.section-header{margin-bottom:40px}
.section-header .label{
  display:inline-flex;align-items:center;gap:8px;font-size:.7rem;
  letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;
}
.section-header .label svg{width:14px;height:14px;stroke:var(--gold)}
.section-header h2{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--dark);font-weight:600}
.section-header .line{width:60px;height:2px;background:var(--gold);margin:12px auto 0;border-radius:2px}
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(8px,1.5vw,15px);max-width:950px;margin:0 auto;
}
.gallery-item{
  border-radius:16px;overflow:hidden;cursor:pointer;position:relative;
  aspect-ratio:4/3;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.4,0,.2,1)}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item .g-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(44,36,24,.4),rgba(184,134,11,.2));
  opacity:0;transition:opacity .4s;
}
.gallery-item .g-overlay svg{width:32px;height:32px;stroke:#fff;stroke-width:1.5}
.gallery-item:hover .g-overlay{opacity:1}

/* ==================== LIGHTBOX ==================== */
.lightbox{display:none;position:fixed;inset:0;background:rgba(26,22,18,.95);z-index:1000;align-items:center;justify-content:center;padding:20px}
.lightbox.active{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 0 60px rgba(184,134,11,.1);animation:scaleIn .4s}
.lb-btn{position:absolute;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.7);transition:all .3s;padding:10px}
.lb-btn:hover{color:var(--gold-light)}
.lb-btn svg{width:28px;height:28px;stroke:currentColor}
.lb-close{top:20px;right:20px}
.lb-prev{top:50%;left:15px;transform:translateY(-50%)}
.lb-next{top:50%;right:15px;transform:translateY(-50%)}

/* ==================== MAP SECTION ==================== */
.map-section{
  background:var(--white);padding:80px 20px;text-align:center;width:100%;
  position:relative;
}
.map-tabs{display:flex;justify-content:center;gap:10px;margin-bottom:25px;flex-wrap:wrap}
.map-tab{
  padding:10px 28px;border:1.5px solid var(--gold-soft);border-radius:50px;
  background:transparent;color:var(--text);cursor:pointer;font-weight:500;
  transition:all .3s;font-size:.82rem;font-family:'Inter',sans-serif;
}
.map-tab.active{background:var(--gold);color:var(--white);border-color:var(--gold)}
.map-tab:hover:not(.active){border-color:var(--gold);color:var(--gold)}
.map-frame{
  width:100%;max-width:900px;height:clamp(300px,40vw,450px);border:none;
  border-radius:20px;margin:0 auto;display:block;
  box-shadow:0 10px 40px rgba(0,0,0,.06);border:1px solid var(--gold-soft);
}
.map-container{display:none;text-align:center}
.map-container.active{display:block}

/* ==================== MUSIC BTN ==================== */
.music-btn{
  position:fixed;bottom:25px;right:25px;width:52px;height:52px;border-radius:50%;
  border:1.5px solid var(--gold-soft);background:rgba(250,245,236,.92);
  color:var(--gold);cursor:pointer;z-index:999;display:flex;align-items:center;justify-content:center;
  transition:all .4s;backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.music-btn svg{width:20px;height:20px;stroke:currentColor;fill:none}
.music-btn:hover{transform:scale(1.1);background:var(--gold);color:var(--white);border-color:var(--gold)}
.music-btn.playing .music-wave{animation:musicPulse 1s infinite}
@keyframes musicPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:0}}
.music-wave{
  position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--gold);
  opacity:0;pointer-events:none;
}

/* ==================== FOOTER ==================== */
footer{
  background:var(--dark);color:#fff;text-align:center;
  padding:50px 20px;width:100%;position:relative;overflow:hidden;
}
footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,var(--gold-soft),transparent);
}
footer .footer-names{font-family:'Great Vibes',cursive;font-size:clamp(1.8rem,4vw,2.5rem);color:var(--gold-light);margin-bottom:10px}
footer p{font-size:.85rem;color:rgba(255,255,255,.45)}
footer .footer-line{width:50px;height:1px;background:rgba(184,134,11,.3);margin:15px auto}

/* ==================== PARTICLES ==================== */
.particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.particle{
  position:absolute;background:var(--gold);border-radius:50%;opacity:.2;
  animation:particleFall linear infinite;
}
@keyframes particleFall{
  0%{transform:translateY(-10vh) rotate(0) scale(1);opacity:.3}
  50%{opacity:.15}
  100%{transform:translateY(110vh) rotate(720deg) scale(0);opacity:0}
}

/* ==================== RESPONSIVE ==================== */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-photo{height:50vh;min-height:300px}
  .hero-photo::after{background:linear-gradient(to bottom,transparent 60%,var(--cream))}
  .hero-content{padding:40px 25px 60px}
  .info-split{grid-template-columns:1fr}
  .info-split::before{display:none}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .hero-photo{height:40vh}
  .hero-countdown .cbox{width:55px;height:55px}
  .nav-inner{gap:10px;padding:12px 15px}
  .nav-link{font-size:.7rem;letter-spacing:1px}
  .gallery-grid{gap:6px}
  .couple-photo{width:180px;height:180px}
}
