:root {
  --gold:#C9A84C; --gold-light:#E8D9A0; --gold-pale:#F5EDD6;
  --burgundy:#6B1D2A; --burgundy-dark:#4A0E1A; --burgundy-light:#8B2E3F;
  --cream:#FDF8F0; --cream-dark:#F0E6D3; --ivory:#FFFDF7;
  --charcoal:#2C2420; --warm-gray:#8A7E74;
  --text-dark:#3B2F2B; --text-muted:#7A6E66;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--ivory);color:var(--text-dark);overflow-x:hidden}
::selection{background:var(--gold-light);color:var(--burgundy-dark)}
img{max-width:100%;display:block}

/* Fonts */
.script{font-family:'Great Vibes',cursive}
.serif{font-family:'Cormorant Garamond',serif}
.sans{font-family:'Jost',sans-serif}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes gentlePulse{0%,100%{opacity:.6}50%{opacity:1}}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--gold-light);border-radius:3px}

/* Navigation */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;backdrop-filter:blur(12px);transition:all .5s ease}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-link{position:relative;color:var(--cream);text-decoration:none;font-family:'Jost',sans-serif;font-weight:300;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;padding:4px 0;background:none;border:none;cursor:pointer;transition:color .3s}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link:hover,.nav-link.active{color:var(--gold)}

/* Burger */
.burger{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer}
.burger span{width:24px;height:1.5px;background:var(--gold);transition:all .3s}
.mobile-menu{max-height:0;overflow:hidden;transition:max-height .4s ease}
.mobile-menu.open{max-height:400px}
.mobile-menu-inner{padding:16px 24px;display:flex;flex-direction:column;gap:20px}

@media(max-width:768px){
  .nav-links{display:none !important}
  .burger{display:flex !important}
}

/* Buttons */
.btn{display:inline-block;padding:14px 48px;border:1px solid var(--gold);color:var(--gold);font-family:'Jost',sans-serif;font-weight:300;font-size:12px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;background:transparent;cursor:pointer;transition:all .4s}
.btn:hover{background:var(--gold);color:var(--burgundy-dark)}
.btn-burg{border-color:var(--burgundy);color:var(--burgundy)}
.btn-burg:hover{background:var(--burgundy);color:var(--cream)}
.btn-light{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.8)}
.btn-light:hover{background:rgba(255,255,255,.1)}

/* Hero - full-bleed photo with contain, text at bottom */
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;justify-content:center;background:var(--burgundy-dark);overflow:hidden}
.hero-photo{position:absolute;inset:0;overflow:hidden}
.hero-photo img{width:100%;height:100%;object-fit:contain;object-position:center top}
.hero-photo-fade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(75,14,26,0) 0%,rgba(75,14,26,0) 35%,rgba(75,14,26,.35) 50%,rgba(75,14,26,.75) 65%,rgba(75,14,26,.93) 78%,var(--burgundy-dark) 90%)}
.hero-text{position:relative;z-index:2;text-align:center;padding:0 24px 56px;width:100%;display:flex;flex-direction:column;align-items:center}
.hero-corner{position:absolute;width:60px;height:60px;opacity:.5;z-index:3}
.hero-corner.tl{top:40px;left:40px;border-top:1px solid var(--gold-light);border-left:1px solid var(--gold-light)}
.hero-corner.tr{top:40px;right:40px;border-top:1px solid var(--gold-light);border-right:1px solid var(--gold-light)}
.hero-corner.bl{bottom:40px;left:40px;border-bottom:1px solid var(--gold-light);border-left:1px solid var(--gold-light)}
.hero-corner.br{bottom:40px;right:40px;border-bottom:1px solid var(--gold-light);border-right:1px solid var(--gold-light)}
.hero h1{font-size:clamp(40px,8vw,76px);line-height:1.1;font-weight:400;color:var(--cream)}
.scroll-indicator{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);text-align:center;animation:gentlePulse 2s ease infinite;z-index:3}

/* Ornamental divider */
.ornament{display:flex;align-items:center;justify-content:center;gap:12px;margin:32px auto}
.ornament .line{height:1px;width:40px}
.ornament .diamond{width:6px;height:6px;border:1px solid;transform:rotate(45deg)}

/* Section titles */
.section-title{text-align:center;margin-bottom:48px}
.section-title h2{font-size:clamp(28px,5vw,42px);font-weight:300;letter-spacing:2px;text-transform:uppercase}

/* Content containers */
.container{max-width:800px;margin:0 auto;padding:0 24px}
.section{padding:100px 24px}
.section-dark{background:linear-gradient(135deg,var(--burgundy-dark) 0%,var(--burgundy) 50%,var(--burgundy-light) 100%);position:relative;overflow:hidden}
.section-dark .dot-pattern{position:absolute;inset:0;opacity:.04;background-image:radial-gradient(var(--gold) 1px,transparent 1px);background-size:32px 32px}
.page-header{padding-top:140px;padding-bottom:80px;text-align:center;background:linear-gradient(180deg,var(--burgundy-dark),var(--burgundy));position:relative}
.page-header .dot-pattern{position:absolute;inset:0;opacity:.03;background-image:radial-gradient(var(--gold) 1px,transparent 1px);background-size:28px 28px}

/* Cards */
.card{border:1px solid var(--cream-dark);padding:48px;background:var(--cream);position:relative}
.card-corner{position:absolute;width:24px;height:24px}
.card-corner.tl{top:12px;left:12px;border-top:1px solid var(--gold);border-left:1px solid var(--gold)}
.card-corner.tr{top:12px;right:12px;border-top:1px solid var(--gold);border-right:1px solid var(--gold)}
.card-corner.bl{bottom:12px;left:12px;border-bottom:1px solid var(--gold);border-left:1px solid var(--gold)}
.card-corner.br{bottom:12px;right:12px;border-bottom:1px solid var(--gold);border-right:1px solid var(--gold)}

/* ═══ JOURNEY LINE — Our Story ═══ */
/* Journey container */
.journey{max-width:1000px;margin:0 auto;position:relative;padding:0 24px}

/* The gold SVG path that winds down the page */
.journey-path{position:absolute;left:50%;top:0;transform:translateX(-50%);width:3px;z-index:0;bottom:200px}
.journey-path-line{width:100%;height:100%;background:linear-gradient(180deg,var(--gold-light),var(--gold),var(--gold-light),transparent);opacity:0.3}

/* Journey markers — burgundy circles with gold border */
.journey-marker{width:20px;height:20px;border-radius:50%;border:2px solid var(--gold);background:var(--burgundy);position:absolute;left:50%;transform:translateX(-50%);z-index:2;box-shadow:0 0 0 4px var(--ivory)}
.journey-marker::after{content:'';position:absolute;inset:3px;border-radius:50%;background:var(--gold);opacity:0.4}

/* Moment block — full-width alternating layout */
.moment{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:100px;align-items:center}
.moment:nth-child(even) .moment-photos{order:2}
.moment:nth-child(even) .moment-text{order:1;text-align:right}
.moment:nth-child(odd) .moment-photos{order:1}
.moment:nth-child(odd) .moment-text{order:2}

/* Photo treatment — primary large, secondary small tilted */
.moment-photos{position:relative;min-height:300px}
.moment-photo-primary{width:85%;position:relative;z-index:1;overflow:hidden;border:1px solid var(--cream-dark)}
.moment-photo-primary img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.moment:nth-child(odd) .moment-photo-primary{margin-left:auto}
.moment:nth-child(even) .moment-photo-primary{margin-right:auto}

/* Text content */
.moment-location{display:inline-flex;align-items:center;gap:6px;margin-bottom:12px}
.moment-location-pin{width:12px;height:12px;border-radius:50%;border:1.5px solid var(--gold);background:var(--burgundy);flex-shrink:0}
.moment-location-pin::after{content:'';display:block;width:4px;height:4px;background:var(--gold);border-radius:50%;margin:2.5px auto}
.moment-location span{font-size:11px;letter-spacing:3px;color:var(--gold);font-weight:400;text-transform:uppercase}
.moment-year{font-size:11px;letter-spacing:3px;color:var(--warm-gray);font-weight:300;text-transform:uppercase;margin-bottom:8px}
.moment-title{font-size:clamp(26px,4vw,36px);font-weight:400;color:var(--charcoal);margin-bottom:14px;line-height:1.2}
.moment-desc{font-size:16px;color:var(--text-muted);line-height:1.9;font-weight:300}

/* Last milestone (The Wedding) — special full-width centered treatment */
.moment-final{text-align:center;grid-template-columns:1fr;max-width:600px;margin:0 auto;padding-top:40px}
.moment-final .moment-photos{display:flex;justify-content:center}
.moment-final .moment-photo-primary{width:60%;margin:0 auto}
.moment-final .moment-text{order:2;text-align:center}

/* Reveal animations — photos slide from their side */
.moment-reveal{opacity:0;transition:opacity .9s ease,transform .9s ease}
.moment-reveal.from-left{transform:translateX(-60px)}
.moment-reveal.from-right{transform:translateX(60px)}
.moment-reveal.from-up{transform:translateY(40px)}
.moment-reveal.visible{opacity:1;transform:translate(0)}

/* Mobile */
@media(max-width:768px){
  .journey-path{left:20px;transform:none}
  .journey-marker{left:20px;transform:translateX(-50%)}
  .moment{grid-template-columns:1fr;gap:24px;margin-bottom:70px;padding-left:44px}
  .moment:nth-child(even) .moment-photos{order:1}
  .moment:nth-child(even) .moment-text{order:2;text-align:left}
  .moment-photo-primary{width:100%}
  .moment:nth-child(odd) .moment-photo-primary,.moment:nth-child(even) .moment-photo-primary{margin:0}
  .moment-final{max-width:100%;padding-left:44px}
  .moment-final .moment-photo-primary{width:100%}
  .moment-final .moment-text{text-align:left}
}

/* Forms */
input,textarea,select{font-family:'Jost',sans-serif;border:1px solid var(--cream-dark);background:var(--ivory);padding:12px 16px;font-size:16px;color:var(--text-dark);outline:none;transition:border-color .3s;width:100%}
input:focus,textarea:focus,select:focus{border-color:var(--gold)}
.form-label{font-size:11px;letter-spacing:2px;color:var(--warm-gray);text-transform:uppercase;display:block;margin-bottom:8px;font-family:'Jost',sans-serif}
.form-group{margin-bottom:24px}

/* Footer */
footer{background:var(--charcoal);padding:60px 24px 40px;text-align:center}
footer .nav-link{font-size:13px;color:rgba(255,255,255,.6)}


/* ── Large screens (27"+ monitors, TVs) ── */
@media(min-width:1600px){
  .hero h1{font-size:84px}
  .hero-text{padding-bottom:64px}
  .container{max-width:900px}
  .nav-inner{max-width:1400px}
}
@media(min-width:2000px){
  .hero h1{font-size:90px}
  .hero-text{padding-bottom:72px}
}
/* ── Mobile responsive ── */
@media(max-width:768px){
  .hero{min-height:100svh}
  .hero h1{font-size:44px !important}
  .hero-text{padding-bottom:40px !important}
  .hero-photo img{object-fit:cover;object-position:center 15%}
  .hero-corner{width:30px;height:30px;opacity:.3}
  .hero-corner.tl,.hero-corner.bl{left:16px}
  .hero-corner.tr,.hero-corner.br{right:16px}
  .hero-corner.tl,.hero-corner.tr{top:16px}
  .hero-corner.bl,.hero-corner.br{bottom:16px}
  .scroll-indicator{bottom:16px}
  .section{padding:60px 16px}
  .page-header{padding-top:100px;padding-bottom:48px}
  .container{padding:0 16px}
  .card{padding:28px 20px}
  .btn{padding:12px 32px;font-size:11px;letter-spacing:2px}
  .section-title h2{font-size:24px !important}
  footer{padding:40px 16px 32px}
  footer .nav-link{font-size:12px}
  .card-corner{width:16px;height:16px}
  .card-corner.tl{top:8px;left:8px}.card-corner.tr{top:8px;right:8px}
  .card-corner.bl{bottom:8px;left:8px}.card-corner.br{bottom:8px;right:8px}
}

@media(max-width:480px){
  .hero h1{font-size:44px !important}
  .section{padding:48px 12px}
  .btn{padding:11px 24px;font-size:10px}
}

/* ── Events timeline — mobile ── */
@media(max-width:768px){
  .ev-item{flex-direction:column !important;gap:10px !important;flex-wrap:nowrap !important}
  .ev-time{min-width:unset !important;text-align:left !important;padding:4px 0 4px 10px !important;background:transparent !important;border:none !important;border-left:2px solid var(--gold) !important}
}

/* Anim delays */
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}.delay-4{transition-delay:.4s}.delay-5{transition-delay:.5s}
.anim-1{animation:fadeInUp 1s ease .3s both}
.anim-2{animation:fadeInUp 1s ease .5s both}
.anim-3{animation:fadeInUp 1s ease .65s both}
.anim-4{animation:fadeInUp 1s ease .8s both}
.anim-5{animation:fadeInUp 1s ease 1s both}
.anim-6{animation:fadeInUp 1s ease 1.1s both}
.anim-7{animation:fadeInUp 1s ease 1.3s both}

/* ═══ Our Story — Full-bleed chapters ═══ */
.sc{width:100%;overflow:hidden}
.sc-bleed{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.sc-bleed-bg{position:absolute;inset:0;z-index:0}
.sc-bleed-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.sc-bleed-overlay{position:absolute;inset:0;z-index:1}
.sc-bleed-content{position:relative;z-index:2;text-align:center;padding:80px 24px;width:100%;max-width:760px;margin:0 auto}
.sc-split{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:960px;margin:0 auto}
.sc-label{font-family:'Jost',sans-serif;font-size:11px;letter-spacing:3px;color:var(--gold);text-transform:uppercase;font-weight:400;display:block;margin-bottom:16px}
.sc-caption{font-family:'Jost',sans-serif;font-size:11px;color:var(--warm-gray);font-style:italic;margin-top:8px;font-weight:300;letter-spacing:1px}
.polaroid{background:#fff;padding:10px 10px 32px;box-shadow:0 6px 24px rgba(0,0,0,.15);display:inline-block}
.polaroid img{display:block;width:100%;object-fit:cover}
.sc-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:768px){
  .sc-bleed{min-height:75vh}
  .sc-split{grid-template-columns:1fr;gap:20px}
  .sc-bleed-content{padding:60px 20px}
  .sc-grid-4{grid-template-columns:1fr 1fr}
  .polaroid{width:120px !important}
}