:root {
  --paper: oklch(98.2% 0.025 86);
  --paper-warm: oklch(95.6% 0.045 78);
  --linen: oklch(93.6% 0.035 102);
  --ink: oklch(22% 0.035 326);
  --muted: oklch(42% 0.035 330);
  --rose: oklch(64% 0.11 20);
  --olive: oklch(51% 0.075 132);
  --honey: oklch(76% 0.11 82);
  --apricot: oklch(88% 0.075 58);
  --shadow: 0 24px 70px oklch(30% 0.04 326 / 0.16);
  --soft-shadow: 0 14px 34px oklch(30% 0.04 326 / 0.12);
  --ease: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  direction: rtl;
  color: var(--ink);
  background:
    radial-gradient(circle at 18% 12%, oklch(90% 0.08 58 / 0.48), transparent 28rem),
    linear-gradient(120deg, var(--paper), var(--linen));
  font-family: "Heebo", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.65;
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
}

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

a {
  color: inherit;
}

.progress {
  position: fixed;
  inset-block: 0 auto;
  inset-inline: 0;
  z-index: 20;
  height: 5px;
  background: oklch(89% 0.035 86 / 0.72);
}

.progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, var(--olive), var(--honey), var(--rose));
  transform-origin: right center;
  transform: scaleX(var(--scroll-progress, 0));
}

.birthday-card {
  overflow: clip;
}

.chapter {
  position: relative;
  min-height: 82svh;
  padding: clamp(38px, 6vw, 86px);
  isolation: isolate;
}

.chapter::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      oklch(99% 0.018 86 / 0.58),
      oklch(99% 0.018 86 / 0) 34%
    );
  opacity: calc(1 - var(--local-progress, 0));
  transform: translateY(calc((1 - var(--local-progress, 0)) * 28px));
  transition:
    opacity 500ms var(--ease-out-quint),
    transform 700ms var(--ease-out-expo);
}

.chapter + .chapter {
  border-block-start: 1px solid oklch(50% 0.04 326 / 0.1);
}

.hero {
  display: grid;
  align-items: end;
  min-height: 100svh;
  padding-block-end: clamp(56px, 10vh, 108px);
}

.hero::before,
.finale::before {
  content: "";
  position: absolute;
  inset: clamp(12px, 2vw, 24px);
  border: 1px solid oklch(47% 0.045 326 / 0.18);
  pointer-events: none;
  z-index: 2;
}

.hero__photo {
  position: absolute;
  inset: clamp(12px, 2vw, 24px);
  z-index: -2;
  overflow: hidden;
  clip-path: inset(calc((1 - var(--local-progress, 0)) * 42%) 0 0 0);
  transition: clip-path 900ms var(--ease);
}

.hero__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, oklch(98% 0.025 86 / 0.94), oklch(98% 0.025 86 / 0.36) 52%, oklch(20% 0.03 326 / 0.04)),
    linear-gradient(0deg, oklch(98% 0.025 86 / 0.85), transparent 58%);
}

.hero__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: translateY(calc(var(--parallax, 0px) * -1)) scale(1.04);
}

.hero__copy {
  position: relative;
  z-index: 3;
  width: min(820px, 100%);
  margin-inline-start: auto;
  padding-block: clamp(18px, 3vw, 38px);
}

.stamp,
.kicker {
  margin: 0 0 16px;
  color: var(--olive);
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  font-weight: 900;
  letter-spacing: 0;
}

.stamp {
  display: inline-grid;
  place-items: center;
  min-width: 86px;
  min-height: 86px;
  margin-block-end: clamp(18px, 3vw, 28px);
  border: 1px solid currentColor;
  border-radius: 999px;
  color: var(--rose);
  background: oklch(98.4% 0.025 86 / 0.78);
  box-shadow: var(--soft-shadow);
}

h1,
h2,
h3,
p {
  margin-block-start: 0;
}

h1,
h2 {
  max-width: 11ch;
  margin-block-end: clamp(18px, 3vw, 30px);
  font-weight: 900;
  line-height: 0.96;
  letter-spacing: 0;
}

h1 {
  font-size: clamp(3.8rem, 10vw, 8.8rem);
}

h2 {
  font-size: clamp(2.8rem, 7vw, 7.6rem);
}

p {
  max-width: 64ch;
  font-size: clamp(1.12rem, 1.6vw, 1.42rem);
}

.hero__copy p:not(.stamp),
.letter__sheet p,
.gallery__copy p,
.finale__inner p {
  color: var(--muted);
  font-weight: 400;
}

.hero__copy p:not(.stamp) {
  max-width: 52ch;
  margin-inline: auto;
  color: oklch(31% 0.035 326);
  font-weight: 500;
}

.scroll-cue {
  position: absolute;
  inset-block-end: clamp(34px, 5vw, 64px);
  inset-inline-start: clamp(26px, 5vw, 76px);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--ink);
  font-weight: 700;
}

.scroll-cue::before {
  content: "";
  width: 42px;
  height: 42px;
  border: 1px solid currentColor;
  border-radius: 999px;
  background:
    linear-gradient(currentColor, currentColor) center 14px / 1px 14px no-repeat,
    radial-gradient(circle at center 28px, currentColor 2px, transparent 2.5px);
  animation: scroll-pulse 2200ms var(--ease-out-quint) infinite;
}

.letter {
  display: grid;
  place-items: center;
  min-height: 74svh;
  padding-block: clamp(56px, 9vw, 118px);
  background:
    radial-gradient(circle at 82% 16%, oklch(88% 0.08 23 / 0.34), transparent 24rem),
    linear-gradient(135deg, var(--paper), oklch(96% 0.038 104));
}

.letter--soft {
  min-height: 82svh;
}

.chapter__number {
  position: absolute;
  inset-block-start: clamp(30px, 6vw, 82px);
  inset-inline-end: clamp(28px, 6vw, 92px);
  color: oklch(52% 0.05 326 / 0.14);
  font-size: clamp(5rem, 20vw, 19rem);
  font-weight: 900;
  line-height: 0.75;
  z-index: -1;
}

.letter__sheet {
  width: min(820px, 100%);
  padding: clamp(34px, 6.5vw, 78px);
  background: oklch(98.7% 0.02 86 / 0.9);
  border: 1px solid oklch(48% 0.04 326 / 0.14);
  box-shadow: var(--shadow);
}

.letter__sheet p {
  max-width: 58ch;
  margin-inline: auto;
  font-size: clamp(1.28rem, 2vw, 1.72rem);
  line-height: 1.78;
}

.letter__sheet p + p,
.gallery__copy p + p,
.finale__inner p + p {
  margin-block-start: 1.1em;
}

.invested-duo {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: clamp(12px, 2vw, 20px);
  align-items: center;
  width: min(720px, 100%);
  margin: clamp(24px, 4vw, 44px) auto clamp(28px, 4.6vw, 52px);
}

.invested-photo {
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 8px solid oklch(98.6% 0.018 86);
  box-shadow: var(--soft-shadow);
}

.invested-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.invested-photo--balloons {
  aspect-ratio: 1.06;
  rotate: 1.5deg;
}

.invested-photo--balloons img {
  object-position: 48% 52%;
}

.invested-photo--table {
  aspect-ratio: 1.18;
  rotate: -1deg;
}

.invested-photo--table img {
  object-position: center;
}

.skills-collage {
  display: grid;
  grid-template-columns: 1.08fr 0.78fr;
  gap: clamp(12px, 2vw, 22px);
  align-items: center;
  width: min(740px, 100%);
  margin: clamp(26px, 4.4vw, 50px) auto clamp(30px, 5vw, 58px);
}

.skills-photo {
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 8px solid oklch(98.6% 0.018 86);
  box-shadow: var(--soft-shadow);
}

.skills-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.skills-photo--water {
  aspect-ratio: 1.28;
  rotate: -1.2deg;
}

.skills-photo--water img {
  object-position: 50% 46%;
}

.skills-photo--portrait {
  grid-row: span 2;
  aspect-ratio: 0.72;
  rotate: 1.3deg;
}

.skills-photo--portrait img {
  object-position: 50% 42%;
}

.skills-photo--train {
  aspect-ratio: 1.36;
  rotate: 1deg;
}

.skills-photo--train img {
  object-position: 42% 48%;
}

.mami-triptych {
  display: grid;
  grid-template-columns: 0.9fr 0.82fr 1.08fr;
  gap: clamp(12px, 2vw, 22px);
  align-items: end;
  margin-block-start: clamp(28px, 4.5vw, 54px);
}

.mami-photo {
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 8px solid oklch(98.6% 0.018 86);
  box-shadow: var(--soft-shadow);
}

.mami-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mami-photo--mami {
  aspect-ratio: 0.82;
  rotate: 2deg;
}

.mami-photo--mami img {
  object-position: 54% 42%;
}

.mami-photo--mommy {
  aspect-ratio: 0.68;
  translate: 0 -18px;
  rotate: -1deg;
}

.mami-photo--mommy img {
  object-position: 50% 18%;
}

.mami-photo--mamacita {
  aspect-ratio: 1.05;
  rotate: 1deg;
}

.mami-photo--mamacita img {
  object-position: 44% 42%;
}

.gallery {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(320px, 1.14fr);
  gap: clamp(36px, 7vw, 108px);
  align-items: center;
  min-height: 94svh;
  background:
    linear-gradient(90deg, oklch(96% 0.04 102), var(--paper) 54%),
    radial-gradient(circle at 10% 88%, oklch(84% 0.08 78 / 0.42), transparent 24rem);
}

.gallery--two {
  grid-template-columns: minmax(320px, 1.1fr) minmax(0, 0.9fr);
  background:
    radial-gradient(circle at 78% 22%, oklch(88% 0.07 18 / 0.32), transparent 25rem),
    linear-gradient(130deg, var(--paper-warm), oklch(97.8% 0.025 86));
}

.gallery--text-only {
  grid-template-columns: 1fr;
  place-items: center;
  min-height: 64svh;
  text-align: center;
}

.gallery--text-only .gallery__copy {
  width: min(820px, 100%);
}

.gallery--text-only .gallery__copy p {
  margin-inline: auto;
}

.gallery__copy {
  align-self: center;
  width: min(680px, 100%);
}

.gallery__copy p {
  max-width: 50ch;
  font-size: clamp(1.2rem, 1.85vw, 1.56rem);
  line-height: 1.72;
}

.gallery__copy--long p:first-child {
  color: var(--ink);
  font-size: clamp(1.5rem, 2.4vw, 2.3rem);
  font-weight: 900;
  line-height: 1.2;
}

.gallery__copy--long p:not(:first-child) {
  font-size: clamp(1.06rem, 1.25vw, 1.24rem);
  line-height: 1.7;
}

.kids-strip {
  display: grid;
  grid-template-columns: 0.92fr 1fr 0.92fr;
  gap: clamp(10px, 1.5vw, 16px);
  align-items: end;
  margin-block: clamp(22px, 3vw, 34px);
}

.kids-photo {
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 7px solid oklch(98.6% 0.018 86);
  box-shadow: var(--soft-shadow);
}

.kids-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kids-photo--one {
  aspect-ratio: 0.78;
  rotate: -1deg;
}

.kids-photo--one img {
  object-position: 54% 36%;
}

.kids-photo--two {
  aspect-ratio: 0.74;
  rotate: 1.2deg;
}

.kids-photo--two img {
  object-position: 48% 38%;
}

.kids-photo--three {
  aspect-ratio: 0.78;
  rotate: -1.4deg;
}

.kids-photo--three img {
  object-position: 50% 42%;
}

.photo-pair {
  position: relative;
  min-height: clamp(560px, 72vw, 820px);
  transform: translateY(var(--parallax, 0px));
}

.print {
  position: absolute;
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 12px solid oklch(98.6% 0.018 86);
  box-shadow: var(--shadow);
}

.print img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.print--large {
  inset-block: 2% auto;
  inset-inline: auto 4%;
  width: min(66%, 520px);
  height: 82%;
  rotate: -2deg;
}

.print--small {
  inset-block: auto 3%;
  inset-inline: 0 auto;
  width: min(48%, 390px);
  height: 46%;
  rotate: 4deg;
}

.print--wide {
  inset-block: 6% auto;
  inset-inline: 0 auto;
  width: min(76%, 620px);
  height: 54%;
  rotate: 2deg;
}

.print--lifted {
  inset-block: auto 0;
  inset-inline: auto 7%;
  width: min(44%, 360px);
  height: 48%;
  rotate: -5deg;
}

.doing-collage {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: clamp(12px, 2vw, 22px);
  align-items: center;
  transform: translateY(var(--parallax, 0px));
}

.doing-photo {
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 10px solid oklch(98.6% 0.018 86);
  box-shadow: var(--shadow);
}

.doing-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.doing-photo--packages {
  aspect-ratio: 1.05;
  rotate: 1.2deg;
}

.doing-photo--packages img {
  object-position: 50% 48%;
}

.doing-photo--coffee {
  aspect-ratio: 1.1;
  rotate: -1.5deg;
}

.doing-photo--coffee img {
  object-position: 48% 50%;
}

.doing-photo--market {
  grid-column: 1 / -1;
  aspect-ratio: 1.72;
  width: min(92%, 720px);
  margin-inline: auto;
  rotate: 0.8deg;
}

.doing-photo--market img {
  object-position: 50% 48%;
}

.words {
  display: grid;
  place-items: center;
  min-height: 96svh;
  padding-block: clamp(72px, 10vw, 136px);
  background:
    linear-gradient(135deg, oklch(98% 0.02 86), oklch(94% 0.04 116)),
    radial-gradient(circle at 14% 20%, oklch(86% 0.08 58 / 0.4), transparent 20rem);
}

.comparison-strip {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap: clamp(24px, 4vw, 58px);
  width: min(1180px, 100%);
  margin: 0 auto;
  align-items: center;
}

.comparison-card {
  display: grid;
  gap: clamp(18px, 2.6vw, 30px);
  padding: clamp(18px, 2.6vw, 32px);
  background: oklch(98.4% 0.02 86 / 0.78);
  border: 1px solid oklch(49% 0.035 326 / 0.16);
  box-shadow: 0 10px 26px oklch(30% 0.04 326 / 0.08);
}

.comparison-card--kg {
  grid-row: span 2;
}

.comparison-card--husband {
  grid-template-columns: minmax(150px, 0.72fr) minmax(0, 1fr);
  align-items: center;
  align-self: end;
}

.comparison-card p {
  margin: 0;
  color: oklch(35% 0.035 326);
  font-size: clamp(1.16rem, 1.55vw, 1.38rem);
  font-weight: 700;
  line-height: 1.5;
}

.comparison-photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(10px, 1.5vw, 18px);
}

.comparison-card figure {
  position: relative;
  margin: 0;
  overflow: hidden;
  background: var(--paper);
  border: 8px solid oklch(98.6% 0.018 86);
  box-shadow: var(--soft-shadow);
}

.comparison-photos figure {
  aspect-ratio: 0.76;
}

.comparison-card--pizza .comparison-photos figure {
  aspect-ratio: 1;
}

.comparison-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.comparison-card--kg .comparison-photos figure:first-child img {
  object-position: 52% 48%;
}

.comparison-card--kg .comparison-photos figure:last-child img {
  object-position: 50% 20%;
}

.comparison-card--pizza .comparison-photos figure:first-child img {
  object-position: center;
}

.comparison-card--pizza .comparison-photos figure:last-child img {
  object-position: 50% 24%;
}

.comparison-card figcaption {
  position: absolute;
  inset-block-start: 10px;
  inset-inline-start: 10px;
  padding: 4px 10px 5px;
  background: oklch(98.4% 0.02 86 / 0.9);
  color: var(--ink);
  font-size: 0.92rem;
  font-weight: 900;
  line-height: 1;
}

.husband-photo {
  aspect-ratio: 0.92;
  rotate: -2deg;
}

.husband-photo img {
  object-position: 58% center;
}

.finale {
  display: grid;
  place-items: center;
  min-height: 82svh;
  padding-block: clamp(64px, 9vw, 120px);
  text-align: center;
  background:
    radial-gradient(circle at 50% 28%, oklch(89% 0.1 76 / 0.46), transparent 19rem),
    linear-gradient(135deg, oklch(98.6% 0.022 86), oklch(94.8% 0.045 58));
}

.finale__inner {
  width: min(920px, 100%);
  overflow: visible;
}

.finale__inner h2 {
  max-width: 12ch;
  margin-inline: auto;
  font-size: clamp(2.5rem, 6.8vw, 6.8rem);
}

.finale-photo {
  width: min(620px, 92%);
  aspect-ratio: 1.12;
  margin: clamp(30px, 5vw, 54px) auto 0;
  overflow: hidden;
  background: var(--paper);
  border: 10px solid oklch(98.6% 0.018 86);
  box-shadow: var(--shadow);
  rotate: -1deg;
}

.finale-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 52% 45%;
}

.finale__inner p {
  margin-inline: auto;
}

.signature {
  margin-block-start: 34px;
  color: var(--rose) !important;
  font-family: "Rubik Dirt", "Heebo", sans-serif;
  font-size: clamp(2rem, 4vw, 4rem) !important;
  line-height: 1.1;
}

.reveal,
.reveal-item {
  --reveal-y: 54px;
  opacity: 0;
  transform: translateY(var(--reveal-y));
  clip-path: inset(18% 0 0 0);
  transition:
    opacity 760ms var(--ease-out-quint),
    transform 1000ms var(--ease-out-expo),
    clip-path 1000ms var(--ease-out-expo),
    filter 1000ms var(--ease-out-expo);
  transition-delay: var(--reveal-delay, 0ms);
  filter: saturate(0.92) brightness(1.04);
  will-change: opacity, transform, clip-path;
}

.reveal.is-visible,
.reveal.is-visible .reveal-item,
.reveal-item.is-visible {
  --reveal-y: 0px;
  opacity: 1;
  clip-path: inset(0 0 0 0);
  filter: saturate(1) brightness(1);
}

.reveal-item {
  --reveal-y: 30px;
}

.reveal-photo {
  --reveal-y: 42px;
  clip-path: inset(24% 0 0 0);
}

.reveal-text {
  --reveal-y: 24px;
}

[data-parallax].reveal,
[data-parallax].reveal.is-visible {
  transform: translateY(calc(var(--parallax, 0px) + var(--reveal-y, 0px)));
}

.hero__copy.reveal {
  --reveal-y: 34px;
  animation: hero-copy-in 1100ms 140ms var(--ease-out-expo) both;
}

.stamp {
  animation: stamp-settle 900ms 520ms var(--ease-out-expo) both;
}

.hero h1 {
  clip-path: inset(0 0 calc((1 - var(--local-progress, 0)) * 100%) 0);
}

.comparison-card:nth-child(2) {
  --reveal-delay: 140ms;
}

.comparison-card:nth-child(3) {
  --reveal-delay: 280ms;
}

@keyframes hero-copy-in {
  from {
    opacity: 0;
    transform: translateY(34px);
    clip-path: inset(22% 0 0 0);
  }

  to {
    opacity: 1;
    transform: translateY(0);
    clip-path: inset(0);
  }
}

@keyframes stamp-settle {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.92);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes scroll-pulse {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(7px);
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .hero__photo,
  .reveal,
  .reveal-item,
  .hero__photo img,
  .photo-pair,
  .doing-collage,
  [data-parallax].reveal,
  [data-parallax].reveal.is-visible {
    clip-path: none;
    opacity: 1;
    transform: none;
    transition: none;
    filter: none;
  }
}

@media (max-width: 920px) {
  .chapter {
    padding: 28px;
  }

  .hero {
    min-height: 100svh;
    padding-block-end: 92px;
  }

  .hero__copy {
    padding-block-end: 72px;
  }

  .hero__photo {
    inset: 12px;
  }

  .hero__photo::after {
    background:
      linear-gradient(0deg, oklch(98% 0.025 86 / 0.96), oklch(98% 0.025 86 / 0.4) 72%, oklch(98% 0.025 86 / 0.16)),
      linear-gradient(90deg, oklch(98% 0.025 86 / 0.84), transparent);
  }

  h1 {
    font-size: clamp(3.05rem, 15vw, 5.8rem);
  }

  h2 {
    font-size: clamp(2.45rem, 12vw, 4.8rem);
  }

  .gallery,
  .gallery--two {
    grid-template-columns: 1fr;
  }

  .gallery--two .photo-pair {
    order: 2;
  }

  .gallery--two .doing-collage {
    order: 2;
  }

  .photo-pair {
    min-height: 620px;
  }

  .comparison-strip {
    grid-template-columns: 1fr;
    max-width: 620px;
  }

  .comparison-card--kg {
    grid-row: auto;
  }

  .comparison-card--husband {
    grid-template-columns: 0.76fr 1fr;
  }
}

@media (max-width: 560px) {
  .chapter {
    padding: 22px;
  }

  .stamp {
    min-width: 68px;
    min-height: 68px;
  }

  .scroll-cue {
    inset-inline-start: 22px;
    inset-block-end: 30px;
  }

  .scroll-cue span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .letter__sheet {
    padding: 28px;
  }

  .invested-duo {
    grid-template-columns: 1fr;
    width: 100%;
  }

  .invested-photo--balloons,
  .invested-photo--table {
    aspect-ratio: 1.35;
  }

  .skills-collage {
    grid-template-columns: 1fr 0.82fr;
    width: 100%;
  }

  .skills-photo {
    border-width: 7px;
  }

  .skills-photo--water,
  .skills-photo--train {
    aspect-ratio: 1.18;
  }

  .skills-photo--portrait {
    aspect-ratio: 0.72;
  }

  .mami-triptych {
    grid-template-columns: 1fr 0.86fr;
  }

  .mami-photo--mamacita {
    grid-column: 1 / -1;
    aspect-ratio: 1.55;
  }

  .mami-photo--mommy {
    translate: 0;
  }

  .photo-pair {
    min-height: 520px;
  }

  .print {
    border-width: 8px;
  }

  .print--large,
  .print--wide {
    width: 78%;
  }

  .print--small,
  .print--lifted {
    width: 58%;
  }

  .doing-collage {
    grid-template-columns: 1fr;
  }

  .doing-photo {
    border-width: 8px;
  }

  .doing-photo--packages,
  .doing-photo--coffee,
  .doing-photo--market {
    grid-column: auto;
    width: 100%;
    aspect-ratio: 1.28;
  }

  .kids-strip {
    grid-template-columns: 1fr 1fr;
    margin-block: 22px 28px;
  }

  .kids-photo {
    border-width: 6px;
  }

  .kids-photo--three {
    grid-column: 1 / -1;
    justify-self: center;
    width: 58%;
    aspect-ratio: 0.82;
  }

  .words {
    min-height: auto;
  }

  .comparison-card {
    padding: 14px;
  }

  .comparison-card--husband {
    grid-template-columns: 1fr;
  }

  .comparison-card p {
    font-size: 1.05rem;
  }

  .comparison-card figcaption {
    font-size: 0.82rem;
  }

  .husband-photo {
    aspect-ratio: 1.25;
  }

  .finale-photo {
    width: calc(100% - 8px);
    aspect-ratio: 0.9;
    border-width: 8px;
  }
}
