:root {
  --paper: #fffdf9;
  --ink: #a8957d;
  --ink-soft: #bcae9a;
  --line: rgba(188, 174, 154, 0.35);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--paper);
}

body {
  min-height: 100%;
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "Cormorant Garamond", Georgia, serif;
}

img {
  display: block;
  max-width: 100%;
}

.page {
  width: 100%;
  min-height: 100svh;
  display: flex;
  justify-content: center;
  background: var(--paper);
}

.invitation {
  position: relative;
  isolation: isolate;
  width: min(100vw, 860px);
  min-height: 100svh;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 44%, rgba(255, 255, 255, 0) 48%, rgba(255, 253, 249, 0.29) 74%, var(--paper) 100%),
    var(--paper);
}

.hero-photo {
  position: absolute;
  z-index: 1;
  inset: 0 0 auto;
  height: 75%;
  overflow: hidden;
  background: var(--paper);
}

.hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 63% 42%;
  filter: saturate(1.12) brightness(1.05) contrast(1.06);
  transform: scale(1.08);
  transform-origin: 58% 42%;
  -webkit-mask-image: radial-gradient(ellipse 86% 74% at 58% 36%, #000 0 56%, rgba(0, 0, 0, 0.82) 68%, rgba(0, 0, 0, 0.34) 86%, rgba(0, 0, 0, 0) 100%);
  mask-image: radial-gradient(ellipse 86% 74% at 58% 36%, #000 0 56%, rgba(0, 0, 0, 0.82) 68%, rgba(0, 0, 0, 0.34) 86%, rgba(0, 0, 0, 0) 100%);
}

.hero-photo::after {
  position: absolute;
  inset: -1px;
  content: "";
  background:
    linear-gradient(to bottom, rgba(255, 253, 249, 0.47) 0%, rgba(255, 253, 249, 0.1) 14%, rgba(255, 253, 249, 0) 36%, rgba(255, 253, 249, 0) 61%, rgba(255, 253, 249, 0.39) 82%, var(--paper) 100%),
    radial-gradient(ellipse 56% 72% at -18% 47%, var(--paper) 0%, rgba(255, 253, 249, 0.43) 25%, rgba(255, 253, 249, 0.21) 49%, rgba(255, 253, 249, 0) 82%),
    radial-gradient(ellipse 58% 76% at 113% 48%, var(--paper) 0%, rgba(255, 253, 249, 0.43) 27%, rgba(255, 253, 249, 0.21) 51%, rgba(255, 253, 249, 0) 84%),
    radial-gradient(ellipse 118% 35% at 50% 100%, var(--paper) 0%, rgba(255, 253, 249, 0.45) 38%, rgba(255, 253, 249, 0.17) 66%, rgba(255, 253, 249, 0) 92%);
}

.family-photo {
  position: absolute;
  z-index: 3;
  top: 52%;
  right: 3.5%;
  width: clamp(150px, 43vw, 330px);
  aspect-ratio: 1.35;
  margin: 0;
  filter: saturate(1.15) brightness(1.18) contrast(1.05);
}

.family-photo::before {
  position: absolute;
  z-index: 0;
  inset: -18%;
  content: "";
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(255, 253, 249, 0.94) 0 45%, rgba(255, 253, 249, 0.72) 58%, rgba(255, 253, 249, 0.36) 72%, rgba(255, 253, 249, 0) 90%);
  filter: blur(18px);
}

.family-photo img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 49%;
  border-radius: 50%;
  -webkit-mask-image: radial-gradient(ellipse at center, #000 0 58%, rgba(0, 0, 0, 0.82) 67%, rgba(0, 0, 0, 0.34) 79%, rgba(0, 0, 0, 0) 92%);
  mask-image: radial-gradient(ellipse at center, #000 0 58%, rgba(0, 0, 0, 0.82) 67%, rgba(0, 0, 0, 0.34) 79%, rgba(0, 0, 0, 0) 92%);
}

.family-photo::after {
  position: absolute;
  z-index: 2;
  inset: -8%;
  content: "";
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(255, 253, 249, 0) 58%, rgba(255, 253, 249, 0.22) 72%, rgba(255, 253, 249, 0.5) 84%, rgba(255, 253, 249, 0) 100%);
  filter: blur(8px);
}

.copy {
  position: absolute;
  z-index: 4;
  right: 4.5vw;
  bottom: clamp(18px, 3.5svh, 36px);
  left: 4.5vw;
  text-align: center;
  text-wrap: balance;
}

.copy::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: -12% -18% -35%;
  background: radial-gradient(ellipse at 50% 18%, rgba(255, 253, 249, 0.62) 0%, rgba(255, 253, 249, 0.38) 38%, rgba(255, 253, 249, 0) 70%);
  filter: blur(20px);
}

.eyebrow,
.occasion,
.date {
  margin: 0;
  font-weight: 500;
  text-transform: none;
  color: var(--ink);
}

.eyebrow {
  font-size: clamp(0.95rem, 4vw, 1.45rem);
  letter-spacing: 0.42em;
  padding-left: 0.42em;
}

h1 {
  margin: 0.02em 0 0;
  color: var(--ink);
  font-family: "Pinyon Script", "Apple Chancery", "Brush Script MT", cursive;
  font-size: clamp(4.15rem, 13vw, 7.1rem);
  font-weight: 400;
  line-height: 0.86;
  letter-spacing: 0;
  transform: scaleX(0.86);
  transform-origin: center;
  white-space: nowrap;
}

h1 span {
  display: inline-block;
  margin: 0 0.04em;
}

.occasion {
  max-width: 28em;
  margin-top: 0.42em;
  margin-right: auto;
  margin-left: auto;
  font-size: clamp(1.12rem, 4.2vw, 1.78rem);
  letter-spacing: 0.18em;
  padding-left: 0.18em;
}

.ornament {
  width: min(58vw, 360px);
  margin: clamp(0.9rem, 2.5vw, 1.2rem) auto clamp(0.85rem, 2.3vw, 1.15rem);
  display: flex;
  align-items: center;
  gap: 0.88rem;
  color: var(--ink-soft);
}

.ornament span {
  height: 1px;
  flex: 1;
  background: linear-gradient(to right, rgba(188, 174, 154, 0), var(--line));
}

.ornament span:last-child {
  background: linear-gradient(to left, rgba(188, 174, 154, 0), var(--line));
}

.ornament b {
  font-size: clamp(1.1rem, 4vw, 1.45rem);
  font-weight: 400;
  line-height: 1;
}

.date {
  max-width: 15em;
  margin-right: auto;
  margin-left: auto;
  font-size: clamp(1.16rem, 4.6vw, 1.78rem);
  letter-spacing: 0.24em;
  padding-left: 0.24em;
}

@media (min-width: 700px) {
  .page {
    align-items: center;
    padding: 0;
  }

  .invitation {
    width: min(100vw, 980px);
    min-height: max(100svh, 760px);
  }

  .hero-photo {
    height: 73%;
  }

  .hero-photo img {
    object-position: 58% 42%;
    transform: scale(1.03);
  }

  .family-photo {
    top: 39.5%;
    right: 7%;
    width: clamp(210px, 27%, 270px);
  }

  .copy {
    right: 7%;
    bottom: 20px;
    left: 7%;
  }

  h1 {
    font-size: clamp(5.9rem, 9.4vw, 7.35rem);
    transform: scaleX(0.82);
  }
}

@media (max-width: 430px) {
  .hero-photo {
    height: 74%;
  }

  .hero-photo img {
    object-position: 61.5% 42%;
    transform: scale(1.14);
  }

  .family-photo {
    top: 52.7%;
    right: 1.5%;
    width: 46vw;
    filter: saturate(0.95) brightness(0.92) contrast(0.97);
  }

  .family-photo::after {
    background: radial-gradient(ellipse at center, rgba(255, 253, 249, 0.28) 0 52%, rgba(255, 253, 249, 0.18) 68%, rgba(255, 253, 249, 0.5) 84%, rgba(255, 253, 249, 0) 100%);
    filter: blur(8px);
  }

  .copy {
    right: 1.15rem;
    bottom: clamp(6px, 1.5svh, 18px);
    left: 1.15rem;
  }

  .eyebrow {
    font-size: clamp(0.82rem, 3.6vw, 0.96rem);
  }

  h1 {
    font-size: clamp(3.35rem, 14.2vw, 3.9rem);
    transform: scaleX(0.86);
    margin-top: 0.15em;
  }

.occasion {
    font-size: clamp(0.95rem, 4.2vw, 1.12rem);
    letter-spacing: 0.14em;
    padding-left: 0.14em;
  }

  .ornament {
    width: 54vw;
    margin-top: 0.74rem;
    margin-bottom: 0.68rem;
  }

  .date {
    font-size: clamp(1rem, 4.5vw, 1.2rem);
    letter-spacing: 0.2em;
    padding-left: 0.2em;
  }
}

@media (max-width: 360px) {
  h1 {
    font-size: 17.2vw;
    transform: scaleX(0.84);
  }

  .occasion {
    letter-spacing: 0.1em;
    padding-left: 0.1em;
  }
}
