@charset "utf-8";
/* CSS Document */


/* =================================================================
   ✒  DECORATIVE FONT — "Austin Pen"
   Austin Pen is a premium font and can't be loaded from a free CDN.
   1. Buy/download it, convert to .woff2 + .woff (e.g. transfonter.org)
   2. Place the files in a /fonts folder next to this HTML
   3. The rule below will pick them up automatically.
   Until then it gracefully falls back to Cormorant Garamond italic.
   ================================================================= */
@font-face{
  font-family:'Austin Pen';
  src:url('fonts/AustinPen.woff2') format('woff2'),
      url('fonts/AustinPen.woff')  format('woff');
  font-weight:normal; font-style:normal; font-display:swap;
}



/* =================================================================
   🎨  COLOUR PALETTE  — change these to re-theme the whole site
   ================================================================= */
:root{
  --ivory:        #EAE5E2;   /* page background (warm cream)      */
  --ivory-soft:   #DED3C9;   /* alternating section (soft taupe)  */
  --cream:        #F5F1EC;   /* cards / panels (lightest)         */
  --taupe:        #D7CAC1;   /* warm taupe                        */
  --sage:         #B7BC9C;   /* sage green                        */
  --olive:        #4A4E2E;   /* primary olive (labels/accents)    */
  --olive-deep:   #2E3020;   /* deeper olive                      */
  --moss:         #3D3F27;   /* deep olive-moss                   */
  --moss-deep:    #382418;   /* darkest — chocolate (dark sections)*/
  --brown:        #402A1C;   /* chocolate brown                   */
  --brass:        #9A8460;   /* warm bronze accent for hairlines  */
  --ink:          #2E2620;   /* body text (warm near-black)       */
  --ink-soft:     #6E6453;   /* muted text                        */

  --serif:  'Cormorant Garamond', serif;
  --deco:   'Austin Pen', 'Cormorant Garamond', serif;  /* decorative accents */
  --body:   'EB Garamond', serif;
  --label:  'Jost', sans-serif;

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* =================================================================
   BASE
   ================================================================= */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background-color:var(--ivory);
  font-size:1.18rem;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* Soft paper grain texture layered over the whole page */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }
a{ color:inherit; }

.shell{ max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:2; }

/* =================================================================
   TYPOGRAPHY HELPERS
   ================================================================= */
.eyebrow{
  font-family:var(--label);
  font-weight:400;
  font-size:.72rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--olive);
  margin:0 0 1.2rem;
  display:inline-block;
}
h1,h2,h3{ font-family:var(--serif); font-weight:400; line-height:1.05; margin:0; }
.script{
  font-family:var(--deco);
  font-style:italic;        /* italic helps the Cormorant fallback; Austin Pen ignores it */
  font-weight:400;
  line-height:.9;           /* tighter for the flowing script */
}

.section-title{
  font-size:clamp(2.4rem, 5.5vw, 4rem);
  color:var(--moss-deep);
  margin-bottom:1.4rem;
}
.lead{ font-size:1.25rem; color:var(--ink-soft); max-width:42ch; }

/* Thin decorative divider with a centred diamond */
.divider{
  display:flex; align-items:center; justify-content:center;
  gap:18px; margin:0 auto;
}
.divider span{ height:1px; width:70px; background:var(--brass); opacity:.6; }
.divider svg{ width:14px; height:14px; color:var(--brass); }

/* =================================================================
   SCROLL REVEAL — soft fade + rise
   ================================================================= */
.reveal{
  opacity:0;
  transform:translateY(34px);
  transition:opacity 1.1s var(--ease), transform 1.1s var(--ease);
  will-change:opacity, transform;
}
.reveal.in{ opacity:1; transform:none; }
/* stagger children */
.reveal.d1{ transition-delay:.12s; }
.reveal.d2{ transition-delay:.24s; }
.reveal.d3{ transition-delay:.36s; }
.reveal.d4{ transition-delay:.48s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* =================================================================
   NAVBAR
   ================================================================= */
.nav-bar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:center;
  padding:18px 28px;
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav-bar.solid{
  background:rgba(243,238,226,.9);
  backdrop-filter:blur(10px);
  padding:12px 28px;
  box-shadow:0 1px 0 rgba(169,140,86,.25);
}
.nav-inner{ width:100%; max-width:var(--maxw); display:flex; align-items:center; justify-content:space-between; }
.nav-monogram{ font-family:var(--serif); font-size:1.45rem; letter-spacing:.12em; color:var(--moss-deep); }
.nav-links{ display:flex; gap:30px; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--label); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase;
  text-decoration:none; color:var(--moss); position:relative; padding:4px 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--brass);
  transition:width .4s var(--ease);
}
.nav-links a:hover::after{ width:100%; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; }
.nav-toggle span{ display:block; width:26px; height:1.5px; background:var(--moss-deep); margin:5px 0; transition:.3s; }

@media (max-width:860px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    background:var(--cream); flex-direction:column; justify-content:center; align-items:center;
    gap:34px; transform:translateX(100%); transition:transform .5s var(--ease); box-shadow:-20px 0 60px rgba(46,58,38,.15);
  }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1rem; }
  .nav-toggle{ display:block; z-index:60; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }
}

/* =================================================================
   HERO
   ================================================================= */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(245,241,236,.5), transparent 60%),
    linear-gradient(180deg, #C7C9AD 0%, #A9AE8C 48%, #6F7350 100%);
}
/* IMAGE PLACEHOLDER — drop your hero photo in .hero-photo (see note) */
.hero-photo{
  position:absolute; inset:0; z-index:0;
/*  background:var(--olive);    fallback colour while no image */
/*   👉 TO ADD YOUR PHOTO: uncomment & set the url below*/
  background-image:url('/img/hero-bg.png');
  background-size:cover; background-position:center; 
  opacity:1;                 /* set to 1 once you add a photo */
}
.hero::after{ /* warm vignette so text stays readable over any photo */
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(46,58,38,.28), rgba(46,58,38,.12) 40%, rgba(46,58,38,.45));
}
.hero-inner{ position:relative; z-index:2; color:var(--cream); padding:120px 20px 80px; }
.hero .eyebrow{ color:rgba(251,248,240,.85); }
.hero h1{
  font-size:clamp(3.2rem, 11vw, 8.5rem);
  color:var(--cream); letter-spacing:.01em; text-shadow:0 2px 30px rgba(46,58,38,.4);
}
.hero .amp{ font-family:var(--deco); font-style:italic; font-weight:400; display:block; font-size:.62em; margin:-.05em 0; opacity:.95; }
.hero-meta{
  font-family:var(--label); letter-spacing:.32em; text-transform:uppercase; font-size:.82rem;
  margin-top:1.8rem; color:rgba(251,248,240,.9);
}
.hero-divider span{ background:rgba(251,248,240,.7); }
.hero-divider svg{ color:rgba(251,248,240,.85); }
.scroll-cue{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:2;
  font-family:var(--label); letter-spacing:.3em; font-size:.62rem; text-transform:uppercase;
  color:rgba(251,248,240,.8); display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-cue .line{ width:1px; height:46px; background:rgba(251,248,240,.6); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.3); opacity:.4;} 50%{ transform:scaleY(1); opacity:1;} }

/* =================================================================
   SECTION SCAFFOLD
   ================================================================= */
section{ position:relative; }
.band{ padding:clamp(80px,12vw,150px) 0; }
.band.alt{ background:var(--ivory-soft); }
.center{ text-align:center; }
.center .lead, .center .divider{ margin-left:auto; margin-right:auto; }

/* COUNTDOWN */
.countdown{ display:flex; gap:clamp(18px,5vw,64px); justify-content:center; margin-top:2.4rem; flex-wrap:wrap; }
.count-cell{ text-align:center; min-width:64px; }
.count-num{ font-family:var(--serif); font-size:clamp(2.6rem,7vw,4.4rem); color:var(--moss-deep); line-height:1; }
.count-lab{ font-family:var(--label); letter-spacing:.28em; text-transform:uppercase; font-size:.66rem; color:var(--olive); margin-top:.6rem; }

/* STORY split layout */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,90px); align-items:center; }
.split.reverse .split-media{ order:2; }
@media (max-width:820px){ .split{ grid-template-columns:1fr; } .split.reverse .split-media{ order:0; } }

/* IMAGE PLACEHOLDER component */
.photo-ph{
  position:relative; width:100%; aspect-ratio:4/5; border-radius:2px;
  background:linear-gradient(135deg, var(--olive) 0%, var(--moss) 100%);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(46,58,38,.5);
}
.photo-ph::after{ /* subtle inner frame */
  content:""; position:absolute; inset:14px; border:1px solid rgba(251,248,240,.4);
}
.photo-ph .ph-label{
  font-family:var(--label); letter-spacing:.25em; text-transform:uppercase; font-size:.66rem;
  color:rgba(251,248,240,.85); text-align:center; padding:0 20px; z-index:2;
}
.photo-ph.wide{ aspect-ratio:3/2; }
.photo-ph.tall{ aspect-ratio:3/4; }
/* 👉 To use a real image instead, set on the element:
   style="background-image:url('images/your.jpg');background-size:cover;background-position:center" */

/* DETAILS cards */
.detail-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:3rem; }
@media (max-width:820px){ .detail-grid{ grid-template-columns:1fr; } }
.detail-card{
  background:var(--cream); padding:46px 38px; text-align:center;
  border:1px solid rgba(169,140,86,.3); border-radius:2px;
  transition:transform .6s var(--ease), box-shadow .6s var(--ease);
}
.detail-card:hover{ transform:translateY(-8px); box-shadow:0 30px 50px -28px rgba(46,58,38,.4); }
.detail-card .ic{ color:var(--brass); margin-bottom:1.2rem; }
.detail-card h3{ font-size:1.9rem; color:var(--moss-deep); margin-bottom:.4rem; }
.detail-card .when{ font-family:var(--label); letter-spacing:.18em; text-transform:uppercase; font-size:.7rem; color:var(--olive); margin-bottom:1rem; }
.detail-card p{ margin:0; color:var(--ink-soft); font-size:1.08rem; }

/* SCHEDULE timeline — robust alternating layout */
.timeline{ max-width:760px; margin:3.5rem auto 0; position:relative; }
.timeline::before{ /* centre spine */
  content:""; position:absolute; left:50%; top:6px; bottom:6px; width:1px;
  transform:translateX(-50%); background:var(--brass); opacity:.45;
}
.tl-item{
  position:relative; width:50%; box-sizing:border-box; padding:0 46px; margin-bottom:46px;
}
.tl-item:last-child{ margin-bottom:0; }
.tl-item:nth-child(odd){  left:0;    text-align:right; }
.tl-item:nth-child(even){ left:50%;  text-align:left;  }
.tl-time{ font-family:var(--serif); font-size:1.9rem; color:var(--moss-deep); line-height:1; margin-bottom:.35rem; }
.tl-desc{ color:var(--ink-soft); font-size:1.08rem; }
.tl-dot{ /* node sitting on the spine */
  position:absolute; top:.55rem; width:13px; height:13px; border-radius:50%;
  background:var(--olive); border:2px solid var(--ivory);
  box-shadow:0 0 0 5px rgba(74,78,46,.16);
}
.tl-item:nth-child(odd)  .tl-dot{ right:-6.5px; }
.tl-item:nth-child(even) .tl-dot{ left:-6.5px;  }

@media (max-width:640px){
  .timeline::before{ left:7px; }
  .tl-item,
  .tl-item:nth-child(even){ width:100%; left:0; text-align:left; padding:0 0 0 38px; }
  .tl-item:nth-child(odd)  .tl-dot,
  .tl-item:nth-child(even) .tl-dot{ left:1px; right:auto; }
  .tl-time{ font-size:1.55rem; }
}

/* GALLERY */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:3rem; }
.gallery .photo-ph{ aspect-ratio:1; box-shadow:none; }
.gallery .photo-ph.span2{ grid-column:span 2; aspect-ratio:2/1; }
@media (max-width:820px){ .gallery{ grid-template-columns:repeat(2,1fr); } .gallery .photo-ph.span2{ grid-column:span 2; } }

/* TRAVEL list */
.info-list{ list-style:none; padding:0; margin:2.2rem 0 0; }
.info-list li{ padding:22px 0; border-bottom:1px solid rgba(169,140,86,.25); display:flex; gap:24px; align-items:baseline; }
.info-list li:first-child{ border-top:1px solid rgba(169,140,86,.25); }
.info-list .k{ font-family:var(--label); letter-spacing:.14em; text-transform:uppercase; font-size:.72rem; color:var(--olive); min-width:130px; }
.info-list .v{ color:var(--ink); flex:1; }
.info-list .v strong{ font-weight:500; color:var(--moss-deep); }

/* FAQ accordion */
.faq{ max-width:760px; margin:2.4rem auto 0; }
.faq-item{ border-bottom:1px solid rgba(169,140,86,.3); }
.faq-q{
  width:100%; background:none; border:none; cursor:pointer; text-align:left;
  font-family:var(--serif); font-size:1.5rem; color:var(--moss-deep);
  padding:24px 40px 24px 0; position:relative; display:flex;
}
.faq-q::after{ content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%); font-size:1.6rem; color:var(--brass); transition:transform .4s var(--ease); }
.faq-item.open .faq-q::after{ transform:translateY(-50%) rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .55s var(--ease); }
.faq-a p{ padding:0 0 24px; margin:0; color:var(--ink-soft); }

/* =================================================================
   RSVP
   ================================================================= */
.rsvp{ background:var(--moss-deep); color:var(--cream); }
.rsvp .eyebrow{ color:var(--brass); }
.rsvp .section-title{ color:var(--cream); }
.rsvp .lead{ color:rgba(251,248,240,.75); }
.rsvp .divider span{ background:var(--brass); }
.rsvp .divider svg{ color:var(--brass); }
.rsvp-card{
  background:rgba(251,248,240,.04); border:1px solid rgba(169,140,86,.35);
  padding:clamp(34px,5vw,60px); border-radius:3px; max-width:720px; margin:3rem auto 0;
}
.rsvp label{ font-family:var(--label); letter-spacing:.14em; text-transform:uppercase; font-size:.68rem; color:rgba(251,248,240,.7); margin-bottom:.5rem; display:block; }
.rsvp .form-control, .rsvp .form-select{
  background:transparent; border:none; border-bottom:1px solid rgba(169,140,86,.5);
  border-radius:0; color:var(--cream); font-family:var(--body); font-size:1.1rem;
  padding:.5rem .2rem; box-shadow:none;
}
.rsvp .form-control::placeholder{ color:rgba(251,248,240,.4); }
.rsvp .form-control:focus, .rsvp .form-select:focus{ background:transparent; color:var(--cream); border-color:var(--brass); box-shadow:none; }
.rsvp .form-select option{ color:#222; }
.rsvp .seg{ display:flex; gap:14px; }
.rsvp .seg label{ flex:1; cursor:pointer; margin:0; }
.rsvp .seg input{ position:absolute; opacity:0; }
.rsvp .seg .pill{
  display:block; text-align:center; padding:14px; border:1px solid rgba(169,140,86,.5);
  font-family:var(--label); letter-spacing:.16em; text-transform:uppercase; font-size:.74rem;
  color:rgba(251,248,240,.8); transition:.35s var(--ease); border-radius:2px;
}
.rsvp .seg input:checked + .pill{ background:var(--brass); color:var(--moss-deep); border-color:var(--brass); }
.btn-rsvp{
  background:var(--brass); color:var(--moss-deep); border:none;
  font-family:var(--label); letter-spacing:.22em; text-transform:uppercase; font-size:.78rem;
  padding:18px 54px; border-radius:2px; cursor:pointer; transition:.4s var(--ease);
}
.btn-rsvp:hover{ background:var(--cream); transform:translateY(-2px); }
.rsvp-thanks{ display:none; text-align:center; padding:20px; }
.rsvp-thanks.show{ display:block; }
.rsvp-thanks h3{ color:var(--brass); font-size:2.4rem; margin-bottom:.6rem; }

/* FOOTER */
.foot{ background:var(--moss-deep); color:rgba(251,248,240,.7); text-align:center; padding:60px 20px 50px; border-top:1px solid rgba(169,140,86,.25); }
.foot .mono{ font-family:var(--serif); font-size:2.4rem; color:var(--cream); letter-spacing:.1em; }
.foot .meta{ font-family:var(--label); letter-spacing:.3em; text-transform:uppercase; font-size:.68rem; margin-top:1rem; }
