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

:root {
  --navy:    #1b2a45;
  --navy-dk: #141f33;
  --cream:   #f2ede4;
  --cream-lt:#f8f5ef;
  --sand:    #e8dfd0;
  --gold:    #b8965a;
  --ink:     #1a1a18;
  --muted:   rgba(26,26,24,.55);
  --border:  rgba(26,26,24,.1);
  --border-lt: rgba(255,255,255,.15);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Jost", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --max:  1200px;
  --pad:  clamp(20px, 4vw, 60px);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream-lt); color: var(--ink); font-family: var(--sans); }
a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }

.container {
  width: min(var(--max), calc(100% - 2 * var(--pad)));
  margin: 0 auto;
}

/* ── TOP NAV ── */
.topnav {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 10;
  padding: 28px var(--pad) 0;
}
.topnav-logo {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 400;
  color: #fff;
  text-align: center;
  letter-spacing: .04em;
  margin-bottom: 12px;
}
.topnav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(16px, 3vw, 40px);
  border-top: 1px solid rgba(255,255,255,.25);
  border-bottom: 1px solid rgba(255,255,255,.25);
  padding: 10px 0;
}
.topnav-links a {
  font-family: var(--sans);
  font-size: clamp(9px, 1.1vw, 11px);
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.82);
  transition: color .2s;
}
.topnav-links a:hover { color: #fff; }
/* social icons inline in nav */
.topnav-divider {
  width: 1px;
  height: 14px;
  background: rgba(255,255,255,.25);
  display: inline-block;
  margin: 0 4px;
}
.topnav-icon {
  display: inline-flex;
  align-items: center;
  color: rgba(255,255,255,.75);
  transition: color .2s;
}
.topnav-icon:hover { color: #fff; }
.topnav-icon svg { width: 16px; height: 16px; fill: currentColor; }

/* ── HERO ── */
.hero {
  position: relative;
  height: 100vh;
  height: 100dvh;
  min-height: 560px;
  overflow: hidden;
  display: grid;
  place-items: center;
}
.hero-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(.6) saturate(.75);
}
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(27,42,69,.25) 0%,
    rgba(27,42,69,.2)  50%,
    rgba(27,42,69,.6)  100%
  );
}

/* centered hero names */
.hero-center {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 var(--pad);
  color: #fff;
}
.hero-eyebrow {
  font-family: var(--sans);
  font-size: clamp(9px, 1.2vw, 11px);
  font-weight: 400;
  letter-spacing: .36em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  margin-bottom: 20px;
}
.hero-names {
  font-family: var(--serif);
  font-size: clamp(52px, 10vw, 130px);
  font-weight: 400;
  font-style: italic;
  line-height: .95;
  margin: 0;
  color: #fff;
  text-shadow: 0 2px 40px rgba(0,0,0,.2);
}
.hero-rule {
  width: 60px;
  height: 1px;
  background: rgba(255,255,255,.5);
  margin: 22px auto;
}
.hero-date {
  font-family: var(--sans);
  font-size: clamp(10px, 1.4vw, 13px);
  font-weight: 300;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}

/* ── STRIPE + CARD SECTION ── */
.stripe-section {
  background:
    repeating-linear-gradient(
      to right,
      var(--navy) 0px,
      var(--navy) 14px,
      var(--cream-lt) 14px,
      var(--cream-lt) 20px
    );
  padding: clamp(48px, 8vw, 100px) var(--pad);
  display: flex;
  align-items: center;
  justify-content: center;
}
.stripe-card {
  background: var(--cream);
  max-width: 560px;
  width: 100%;
  padding: clamp(40px, 6vw, 72px) clamp(32px, 5vw, 64px);
  text-align: center;
  box-shadow: 0 8px 48px rgba(27,42,69,.12);
}
.stripe-eyebrow {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
  display: block;
}
.stripe-script {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  margin: 0 0 20px;
  line-height: 1.15;
}
.stripe-body {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(13px, 1.6vw, 15px);
  line-height: 1.85;
  color: var(--muted);
}

/* ── SERVICES SECTION ── */
.services-section {
  padding: clamp(64px, 8vw, 110px) var(--pad);
  background: var(--cream-lt);
}
.services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 80px);
  align-items: start;
  max-width: var(--max);
  margin: 0 auto;
}
@media (max-width: 700px) {
  .services-grid { grid-template-columns: 1fr; }
}

/* photo stack */
.services-photos {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 4px;
  height: clamp(400px, 55vw, 680px);
}
.services-photos .photo {
  overflow: hidden;
}
.services-photos .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.92) saturate(.85);
  transition: transform .6s ease, filter .4s ease;
}
.services-photos .photo:hover img {
  transform: scale(1.04);
  filter: brightness(1) saturate(1);
}

/* service list */
.services-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.service-item {
  border-bottom: 1px solid var(--border);
  padding: clamp(20px, 3vw, 32px) 0;
}
.service-item:first-child { border-top: 1px solid var(--border); }
.service-title {
  font-family: var(--serif);
  font-size: clamp(22px, 3.5vw, 38px);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 6px;
  line-height: 1;
}
.service-desc {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(12px, 1.5vw, 14px);
  color: var(--muted);
  margin: 0 0 12px;
}
.service-link {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.service-link:hover { color: var(--navy); border-color: var(--navy); }
.service-link::after { content: "→"; }

/* ── PHOTO GALLERY GRID ── */
.gallery-section {
  padding: 0;
  background: var(--cream-lt);
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, clamp(180px, 22vw, 320px));
  gap: 3px;
}
.gallery-grid .g-photo {
  overflow: hidden;
}
.gallery-grid .g-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.9) saturate(.85);
  transition: transform .6s ease, filter .4s ease;
}
.gallery-grid .g-photo:hover img {
  transform: scale(1.05);
  filter: brightness(1) saturate(1);
}
@media (max-width: 600px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: repeat(3, 180px); }
}

/* ── MEET SECTION ── */
.meet-section {
  padding: clamp(64px, 8vw, 110px) var(--pad);
  background: var(--cream-lt);
}
.meet-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 80px);
  align-items: center;
  max-width: var(--max);
  margin: 0 auto;
}
@media (max-width: 700px) {
  .meet-grid { grid-template-columns: 1fr; }
}
.meet-title {
  font-family: var(--serif);
  font-size: clamp(48px, 9vw, 110px);
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--navy);
  line-height: .88;
  margin: 0;
}
.meet-body {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(13px, 1.6vw, 16px);
  line-height: 1.85;
  color: var(--muted);
}

/* ── RSVP SECTION ── */
.rsvp-section {
  background:
    linear-gradient(rgba(27,42,69,.90), rgba(27,42,69,.90)),
    url('../wedding-navy-site/1.png') center / cover no-repeat fixed;
  color: #fff;
  padding: clamp(64px, 8vw, 110px) var(--pad);
}
.rsvp-inner {
  max-width: 640px;
  margin: 0 auto;
}
.rsvp-eyebrow {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  margin-bottom: 12px;
  display: block;
}
.rsvp-title {
  font-family: var(--serif);
  font-size: clamp(36px, 6vw, 72px);
  font-weight: 400;
  font-style: italic;
  color: #fff;
  margin: 0 0 8px;
  line-height: 1;
}
.rsvp-sub {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(13px, 1.5vw, 15px);
  color: rgba(255,255,255,.6);
  margin-bottom: 40px;
}
.rsvp-sub strong { color: rgba(255,255,255,.9); font-weight: 400; }

.rsvp-form { display: grid; gap: 16px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 560px) { .form-row { grid-template-columns: 1fr; } }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group.full { grid-column: 1 / -1; }
.form-group label {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 400;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
}
.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 14px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  padding: 12px 16px;
  outline: none;
  transition: border-color .2s;
  width: 100%;
  border-radius: 0;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(255,255,255,.25); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: rgba(255,255,255,.55); }
.form-group select option { background: var(--navy-dk); color: #fff; }
.form-group textarea { resize: vertical; min-height: 80px; }

.radio-group { display: flex; gap: 22px; align-items: center; padding: 10px 0; }
.radio-label {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-weight: 300; font-size: 14px;
  color: rgba(255,255,255,.8); cursor: pointer;
}
.radio-label input[type="radio"] { width: 16px; height: 16px; accent-color: #fff; }

.form-submit { margin-top: 8px; }
.btn-rsvp {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  background: #fff;
  color: var(--navy);
  border: none;
  padding: 16px 52px;
  cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.btn-rsvp:hover { opacity: .88; transform: translateY(-1px); }
.btn-rsvp:active { transform: translateY(0); }

.rsvp-success { padding: 32px 0; }
.rsvp-success .serif-lg {
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 56px);
  font-style: italic;
  color: #fff;
  display: block;
  margin-bottom: 10px;
}
.rsvp-success p {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 15px;
  color: rgba(255,255,255,.65);
  margin: 0;
}

/* ── FOOTER ── */
.footerbar {
  background:
    linear-gradient(rgba(20,31,51,.97), rgba(20,31,51,.97)),
    url('../wedding-navy-site/2.png') center / cover no-repeat;
  color: rgba(255,255,255,.55);
  font-family: var(--sans);
  font-size: 11px;
}
.footerbar .inner {
  width: min(var(--max), calc(100% - 2 * var(--pad)));
  margin: 0 auto;
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.footerbar a { color: rgba(255,255,255,.45); margin-right: 18px; }
.footerbar a:hover { color: rgba(255,255,255,.85); }
.pill {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: 5px 12px;
  font-size: 10px;
  letter-spacing: .06em;
  color: rgba(255,255,255,.6);
}