.happy-day-page {
  padding: 28px 0 96px;
}

.hero-happy-day {
  padding: 18px 0 38px;
}

.hero-happy-day__container {
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(420px, 1.06fr);
  gap: 20px;
  align-items: center;
}

.hero-happy-day__content {
  padding: 4px 0 0;
}

.hero-happy-day__eyebrow,
.happy-day-modes__eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #a07478;
}

.hero-happy-day__title {
  margin: 0;
  max-width: 8.9ch;
  font-size: clamp(50px, 6vw, 80px);
  line-height: 0.92;
  letter-spacing: -0.065em;
}

.hero-happy-day__title span {
  color: var(--site-accent);
}

.hero-happy-day__copy {
  margin-top: 22px;
  max-width: 430px;
}

.hero-happy-day__copy p {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.58;
  color: var(--site-muted);
}

.hero-happy-day__actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
  max-width: 760px;
}

.hero-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--site-accent);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.15;
  text-align: center;
  box-shadow: 0 10px 24px rgba(255, 45, 111, 0.22);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.hero-cta:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 40px rgba(255, 45, 111, 0.32);
}

.hero-happy-day__visual {
  min-width: 0;
}

.hero-visual-card {
  position: relative;
  min-height: 580px;
  border-radius: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

.hero-visual-card__image {
  display: block;
  width: min(100%, 790px);
  height: auto;
  margin-left: auto;
  transform: translate(44px, 8px);
  filter: drop-shadow(0 14px 30px rgba(27, 22, 48, 0.1));
}

.hero-visual-card__placeholder {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 760px;
  background:
    radial-gradient(circle at 82% 16%, #1152d5 0 7%, transparent 7.2%),
    radial-gradient(circle at 89% 8%, #0e2d7d 0 9%, transparent 9.2%),
    radial-gradient(circle at 94% 16%, #2a62e5 0 7%, transparent 7.2%),
    linear-gradient(135deg, rgba(255,255,255,0.42), rgba(255,255,255,0));
}

.balloon {
  position: absolute;
  border-radius: 999px;
  filter: drop-shadow(0 18px 20px rgba(27, 22, 48, 0.12));
}

.balloon--blue {
  width: 300px;
  height: 300px;
  right: -30px;
  top: 36px;
  background: radial-gradient(circle at 30% 25%, #4582ff, #0c2d7d 78%);
}

.balloon--pink {
  width: 390px;
  height: 390px;
  left: 140px;
  top: 248px;
  background: radial-gradient(circle at 40% 30%, #ff8ab2, #ff2d6f 65%, #e61f5b 100%);
}

.balloon--black {
  width: 520px;
  height: 160px;
  left: 18px;
  top: 220px;
  transform: rotate(-34deg);
  background: linear-gradient(90deg, #05060d, #1c2040 46%, #08090f);
  border-radius: 999px;
}

.balloon--stone {
  width: 280px;
  height: 180px;
  right: 14px;
  bottom: 22px;
  background: radial-gradient(circle at 35% 35%, #b2b5b3, #7f857c 65%, #676d64 100%);
  border-radius: 44% 56% 48% 52% / 47% 49% 51% 53%;
}

.placeholder-copy {
  position: absolute;
  left: 36px;
  right: 36px;
  bottom: 34px;
  z-index: 2;
  padding: 22px 24px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.76);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 38px rgba(27, 22, 48, 0.1);
}

.placeholder-copy strong {
  display: block;
  margin-bottom: 6px;
  font-size: 20px;
}

.placeholder-copy span {
  color: var(--site-muted);
  line-height: 1.55;
}

.happy-day-modes {
  padding: 8px 0 0;
}

.happy-day-modes__header {
  max-width: 820px;
  margin: 0 auto 24px;
  text-align: center;
}

.happy-day-modes__header h2 {
  margin: 0;
  font-size: clamp(28px, 3.6vw, 52px);
  line-height: 1.02;
  letter-spacing: -0.055em;
}

.happy-day-modes__header p {
  margin: 12px auto 0;
  max-width: 720px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--site-muted);
}

.happy-day-modes__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.business-card {
  border-radius: 20px;
  overflow: hidden;
  background: #fffdfa;
  border: 1px solid #efe4d8;
  box-shadow: 0 6px 18px rgba(27, 22, 48, 0.06);
}

.business-card__media {
  position: relative;
  min-height: 228px;
  display: flex;
  align-items: stretch;
  padding: 0;
}

.business-card__media-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.business-card__media--resale {
  background: #efe6dc;
}

.business-card__media--brand {
  background: #f7f3ef;
}

.business-card__media-tag {
  position: absolute;
  top: 18px;
  left: 18px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.9);
  color: var(--site-text);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.business-card__media-note {
  position: relative;
  z-index: 1;
  max-width: 260px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.84);
  color: var(--site-muted);
  font-size: 14px;
  line-height: 1.45;
}

.business-card__body {
  padding: 20px 20px 20px;
}

.business-card__kicker {
  margin-bottom: 10px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9b8a92;
}

.business-card__body h3 {
  margin: 0;
  max-width: 11ch;
  font-size: clamp(24px, 2.4vw, 38px);
  line-height: 0.98;
  letter-spacing: -0.055em;
}

.business-card__body p {
  margin: 12px 0 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--site-muted);
}

.business-card__list {
  list-style: none;
  margin: 18px 0 0;
  padding: 16px 0 0;
  border-top: 1px solid rgba(27, 22, 48, 0.08);
}

.business-card__list li {
  position: relative;
  padding-left: 16px;
  font-size: 13px;
  line-height: 1.45;
  color: #322d42;
}

.business-card__list li + li {
  margin-top: 10px;
}

.business-card__list li::before {
  content: "";
  position: absolute;
  top: 6px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 999px;
}

.business-card__list--teal li::before {
  background: #38c8c5;
}

.business-card__list--pink li::before {
  background: #ff4c8a;
}

.business-card__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  margin-top: 18px;
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--site-accent);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  text-align: center;
  box-shadow: 0 10px 24px rgba(255, 45, 111, 0.18);
}

.business-card__button:hover {
  transform: translateY(-2px);
}

.happy-day-catalog {
  padding: 54px 0 0;
}

.happy-day-catalog__header {
  margin: 0 auto 34px;
  max-width: 860px;
  text-align: center;
}

.happy-day-catalog__eyebrow {
  display: inline-block;
  margin-bottom: 16px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #a07478;
}

.happy-day-catalog__header h2 {
  margin: 0;
  font-size: clamp(36px, 4.2vw, 60px);
  line-height: 1.04;
  letter-spacing: -0.05em;
}

.happy-day-catalog__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.catalog-card {
  padding: 22px 18px 20px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(27, 22, 48, 0.08);
  box-shadow: 0 18px 34px rgba(27, 22, 48, 0.08);
  text-align: center;
}

.catalog-card__icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 132px;
  margin-bottom: 12px;
}

.catalog-card h3 {
  margin: 0;
  font-size: 24px;
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.catalog-card p {
  margin: 10px auto 0;
  max-width: 18ch;
  font-size: 15px;
  line-height: 1.5;
  color: var(--site-muted);
}

.catalog-balloon,
.catalog-bouquet-balloon,
.catalog-heart,
.catalog-pump,
.catalog-color-grid,
.catalog-brand-mark,
.catalog-streamer,
.catalog-star {
  position: absolute;
}

.catalog-balloon {
  border-radius: 999px;
  filter: drop-shadow(0 12px 18px rgba(27, 22, 48, 0.12));
}

.catalog-balloon::after,
.catalog-bouquet-balloon::after,
.catalog-heart::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  width: 1px;
  height: 26px;
  background: rgba(87, 78, 97, 0.36);
  transform: translateX(-50%);
}

.catalog-card--round .catalog-balloon--pink {
  width: 62px;
  height: 72px;
  left: calc(50% - 42px);
  top: 22px;
  background: radial-gradient(circle at 32% 30%, #ff9abc, #ff558b 72%, #f4306f 100%);
}

.catalog-card--round .catalog-balloon--white {
  width: 60px;
  height: 70px;
  left: calc(50% + 2px);
  top: 28px;
  background: radial-gradient(circle at 36% 30%, #ffffff, #eef0f4 78%, #d4dae3 100%);
}

.catalog-card--theme .catalog-balloon--yellow {
  width: 76px;
  height: 88px;
  top: 18px;
  left: calc(50% - 38px);
  background: radial-gradient(circle at 35% 30%, #ffe98a, #f6c94c 72%, #e7aa1c 100%);
}

.catalog-star {
  width: 22px;
  height: 22px;
  top: 24px;
  left: calc(50% + 22px);
  background: #ff8f4b;
  clip-path: polygon(50% 0%, 61% 35%, 100% 35%, 68% 57%, 79% 100%, 50% 74%, 21% 100%, 32% 57%, 0% 35%, 39% 35%);
}

.catalog-star--small {
  width: 14px;
  height: 14px;
  top: 54px;
  left: calc(50% - 42px);
  background: #7e5bff;
}

.catalog-heart {
  width: 58px;
  height: 52px;
  top: 28px;
  left: calc(50% - 12px);
  transform: rotate(-6deg);
  background: #2cc2b8;
  clip-path: path("M29 52C28 52 0 36 0 17C0 6 8 0 17 0C23 0 27 3 29 8C31 3 35 0 41 0C50 0 58 6 58 17C58 36 30 52 29 52Z");
}

.catalog-heart--small {
  width: 42px;
  height: 38px;
  top: 50px;
  left: calc(50% - 48px);
  background: #73ded8;
}

.catalog-card--party .catalog-balloon--violet {
  width: 74px;
  height: 84px;
  top: 20px;
  left: calc(50% - 34px);
  background: radial-gradient(circle at 30% 30%, #c39eff, #7f57f7 72%, #5d31e2 100%);
}

.catalog-streamer {
  width: 12px;
  height: 34px;
  top: 56px;
  left: calc(50% + 26px);
  border-radius: 999px;
  background: linear-gradient(180deg, #ffd056, #ff7c47);
  transform: rotate(22deg);
}

.catalog-streamer--alt {
  height: 28px;
  top: 64px;
  left: calc(50% - 38px);
  background: linear-gradient(180deg, #2ed2c4, #1285e9);
  transform: rotate(-18deg);
}

.catalog-bouquet-balloon {
  border-radius: 999px;
  filter: drop-shadow(0 10px 16px rgba(27, 22, 48, 0.1));
}

.catalog-bouquet-balloon--pink {
  width: 44px;
  height: 54px;
  top: 32px;
  left: calc(50% - 48px);
  background: radial-gradient(circle at 30% 30%, #ff9ab8, #ff588c 75%, #f43170 100%);
}

.catalog-bouquet-balloon--yellow {
  width: 46px;
  height: 56px;
  top: 18px;
  left: calc(50% - 5px);
  background: radial-gradient(circle at 30% 30%, #fff0a1, #ffd45d 74%, #f6b124 100%);
}

.catalog-bouquet-balloon--teal {
  width: 44px;
  height: 54px;
  top: 34px;
  left: calc(50% + 34px);
  background: radial-gradient(circle at 30% 30%, #91efe6, #31c9b6 74%, #13a598 100%);
}

.catalog-pump {
  width: 88px;
  height: 22px;
  top: 58px;
  left: calc(50% - 44px);
  border-radius: 999px;
  background: linear-gradient(90deg, #242b56 0 52%, #6f77a8 52% 100%);
}

.catalog-pump::before,
.catalog-pump::after {
  content: "";
  position: absolute;
}

.catalog-pump::before {
  width: 12px;
  height: 40px;
  left: 38px;
  top: -28px;
  border-radius: 10px;
  background: linear-gradient(180deg, #1f253d, #69739f);
}

.catalog-pump::after {
  width: 26px;
  height: 6px;
  left: 31px;
  top: -32px;
  border-radius: 999px;
  background: #2c3255;
}

.catalog-color-grid {
  width: 96px;
  height: 96px;
  top: 18px;
  left: calc(50% - 48px);
  border-radius: 20px;
  background:
    linear-gradient(90deg, #fa4e81 0 33.333%, #ffbf45 33.333% 66.666%, #2dd3c5 66.666% 100%),
    linear-gradient(90deg, #5d7dff 0 33.333%, #915cff 33.333% 66.666%, #6bc866 66.666% 100%);
  background-size: 100% 50%, 100% 50%;
  background-position: top, bottom;
  background-repeat: no-repeat;
  box-shadow: inset 0 0 0 6px rgba(255,255,255,0.58);
}

.catalog-card--custom .catalog-balloon--brand {
  width: 82px;
  height: 96px;
  top: 16px;
  left: calc(50% - 41px);
  background: radial-gradient(circle at 30% 30%, #ff9ab8, #ff5c91 75%, #f23271 100%);
}

.catalog-brand-mark {
  top: 48px;
  left: calc(50% - 34px);
  z-index: 1;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #e33b75;
}

.happy-day-catalog__download {
  display: grid;
  grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
  gap: 34px;
  align-items: center;
  margin-top: 34px;
  padding: 34px;
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(255,255,255,0.88), rgba(255,248,239,0.94));
  border: 1px solid rgba(27, 22, 48, 0.08);
  box-shadow: var(--site-shadow);
}

.catalog-mockup {
  position: relative;
  min-height: 250px;
}

.catalog-mockup__book {
  position: absolute;
  border-radius: 22px;
  box-shadow: 0 18px 34px rgba(27, 22, 48, 0.18);
}

.catalog-mockup__book--open {
  width: 290px;
  height: 198px;
  left: 10px;
  top: 38px;
  background: linear-gradient(135deg, #ffffff, #f1ebe2);
  transform: rotate(-9deg);
}

.catalog-mockup__spread {
  position: absolute;
  inset: 14px;
  border-radius: 16px;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.95) 0 48%, rgba(240,233,224,0.96) 48% 52%, rgba(255,255,255,0.95) 52% 100%),
    linear-gradient(180deg, rgba(255,92,145,0.16), rgba(255,92,145,0));
}

.catalog-mockup__book--cover {
  width: 146px;
  height: 198px;
  right: 12px;
  top: 16px;
  background: linear-gradient(180deg, #eb396e, #c51b52);
  transform: rotate(10deg);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 20px 16px;
}

.catalog-mockup__book--cover span {
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.1;
  text-align: center;
}

.catalog-download-copy p {
  margin: 0;
  max-width: 32ch;
  font-size: clamp(24px, 2.6vw, 34px);
  line-height: 1.22;
  letter-spacing: -0.03em;
}

.catalog-download-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 24px;
}

.catalog-download-button {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 108px;
  padding: 18px 24px;
  border-radius: 999px;
  background: var(--site-accent);
  color: #fff;
  text-align: center;
  box-shadow: 0 16px 34px rgba(255, 45, 111, 0.24);
}

.catalog-download-button strong {
  font-size: 20px;
  line-height: 1.1;
}

.catalog-download-button span {
  margin-top: 6px;
  font-size: 14px;
  font-weight: 700;
  opacity: 0.92;
}

/* Fidelity pass: align catalog section closer to the reference screenshot */
.happy-day-catalog {
  padding: 72px 0 0;
}

.happy-day-catalog__header {
  margin: 0 auto 30px;
  max-width: 1160px;
}

.happy-day-catalog__eyebrow {
  margin-bottom: 12px;
  font-size: 10px;
  letter-spacing: 0.22em;
  color: #c06472;
}

.happy-day-catalog__header h2 {
  font-size: clamp(32px, 3.9vw, 62px);
  line-height: 1.02;
  font-weight: 900;
}

.happy-day-catalog__grid {
  gap: 16px;
}

.catalog-card {
  min-height: 168px;
  padding: 14px 14px 12px;
  border-radius: 18px;
  background: #fffdfa;
  border: 1px solid #efe4d8;
  box-shadow: 0 2px 8px rgba(62, 44, 40, 0.04);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.catalog-card__icon {
  min-height: 78px;
  margin-bottom: 8px;
}

.catalog-icon-svg {
  width: 92px;
  height: 78px;
  display: block;
}

.catalog-card h3 {
  font-size: 22px;
  font-weight: 900;
  line-height: 1.05;
}

.catalog-card p {
  margin-top: 6px;
  max-width: 20ch;
  font-size: 13px;
  line-height: 1.25;
  color: #6c6771;
}

.happy-day-catalog__download {
  grid-template-columns: minmax(340px, 0.86fr) minmax(0, 1.14fr);
  gap: 24px;
  margin-top: 26px;
  padding: 10px 8px 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.catalog-mockup {
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.catalog-mockup img {
  display: block;
  width: min(100%, 360px);
  height: auto;
}

.catalog-download-copy {
  padding-top: 2px;
}

.catalog-download-copy p {
  max-width: 18ch;
  font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.14;
  letter-spacing: -0.03em;
  color: #4d4952;
}

.catalog-download-actions {
  gap: 18px;
  margin-top: 18px;
}

.catalog-download-button {
  min-height: 84px;
  padding: 12px 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, #ff3079, #ff2b72);
  box-shadow: 0 8px 18px rgba(255, 45, 111, 0.18);
}

.catalog-download-button strong {
  font-size: 16px;
  font-weight: 900;
}

.catalog-download-button span {
  margin-top: 4px;
  font-size: 12px;
  font-weight: 800;
  opacity: 0.96;
}

@media (max-width: 1120px) {
  .hero-happy-day__container {
    grid-template-columns: 1fr;
  }

  .hero-happy-day__title {
    max-width: 12ch;
  }

  .hero-happy-day__actions {
    grid-template-columns: 1fr;
    max-width: 480px;
  }

  .happy-day-modes__grid {
    grid-template-columns: 1fr;
  }

  .happy-day-catalog__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .happy-day-catalog__download {
    grid-template-columns: 1fr;
  }

  .catalog-download-copy p {
    max-width: none;
  }
}

@media (max-width: 720px) {
  .happy-day-page {
    padding: 12px 0 68px;
  }

  .hero-happy-day {
    padding: 20px 0 42px;
  }

  .hero-happy-day__title {
    font-size: clamp(42px, 12vw, 64px);
    max-width: 11ch;
  }

  .hero-happy-day__copy p,
  .happy-day-modes__header p,
  .business-card__body p {
    font-size: 16px;
  }

  .hero-visual-card,
  .hero-visual-card__placeholder {
    min-height: 460px;
  }

  .balloon--blue {
    width: 160px;
    height: 160px;
    right: -20px;
    top: 14px;
  }

  .balloon--pink {
    width: 220px;
    height: 220px;
    left: 50px;
    top: 165px;
  }

  .balloon--black {
    width: 300px;
    height: 92px;
    top: 138px;
  }

  .balloon--stone {
    width: 170px;
    height: 120px;
  }

  .placeholder-copy {
    left: 18px;
    right: 18px;
    bottom: 18px;
  }

  .business-card__media {
    min-height: 220px;
  }

  .business-card__body {
    padding: 22px 20px 24px;
  }

  .business-card__body h3 {
    max-width: none;
    font-size: clamp(28px, 9vw, 38px);
  }

  .happy-day-catalog {
    padding-top: 42px;
  }

  .happy-day-catalog__grid,
  .catalog-download-actions {
    grid-template-columns: 1fr;
  }

  .catalog-card {
    padding: 20px 16px 18px;
  }

  .happy-day-catalog__download {
    gap: 22px;
    padding: 22px 18px;
  }

  .catalog-mockup {
    min-height: 214px;
  }

  .catalog-mockup__book--open {
    width: 220px;
    height: 150px;
    left: 0;
    top: 40px;
  }

  .catalog-mockup__book--cover {
    width: 110px;
    height: 150px;
    right: 4px;
    top: 20px;
  }

  .catalog-download-copy p {
    font-size: clamp(22px, 7vw, 30px);
  }

  .happy-day-proof {
    padding: 56px 0 36px;
  }

  .happy-day-proof__header h2 {
    font-size: clamp(34px, 11vw, 52px);
  }

  .happy-day-proof__benefits {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .proof-card {
    padding: 0 0 20px;
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  }

  .happy-day-proof__palette {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px 12px;
    padding: 24px 18px;
  }
}

.happy-day-proof {
  margin-top: 54px;
  padding: 72px 0 56px;
  background: linear-gradient(180deg, #201230 0%, #120a1d 100%);
  color: #fff;
}

.happy-day-proof__container {
  display: flex;
  flex-direction: column;
}

.happy-day-proof__header {
  max-width: 760px;
}

.happy-day-proof__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #c6b7dc;
}

.happy-day-proof__header h2 {
  margin: 0;
  font-size: clamp(42px, 4.8vw, 72px);
  line-height: 0.96;
  letter-spacing: -0.065em;
  color: #ffffff;
}

.happy-day-proof__benefits {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-top: 34px;
}

.proof-card {
  padding: 0 28px 0 0;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.proof-card:last-child {
  border-right: 0;
  padding-right: 0;
}

.proof-card__icon {
  display: flex;
  align-items: center;
  min-height: 72px;
  margin-bottom: 14px;
}

.proof-icon {
  position: relative;
  width: 56px;
  height: 56px;
}

.proof-icon--balloon::before {
  content: "";
  position: absolute;
  inset: 4px 10px 10px 10px;
  border-radius: 50% 50% 48% 48%;
  background: radial-gradient(circle at 34% 30%, #ffb0cb 0, #ff5b95 58%, #f22d71 100%);
}

.proof-icon--balloon::after {
  content: "";
  position: absolute;
  left: 28px;
  top: 44px;
  width: 1px;
  height: 16px;
  background: rgba(255,255,255,0.5);
}

.proof-icon--powder::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 14px;
  width: 34px;
  height: 24px;
  border-radius: 10px 10px 14px 14px;
  background: linear-gradient(180deg, #ffcf63, #ff8e2e);
  transform: rotate(-18deg);
}

.proof-icon--powder::after {
  content: "";
  position: absolute;
  right: 6px;
  top: 30px;
  width: 14px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 229, 164, 0.95);
  box-shadow: -10px -6px 0 0 rgba(255, 229, 164, 0.55), -16px 2px 0 0 rgba(255, 229, 164, 0.35);
}

.proof-icon--uniform::before,
.proof-icon--uniform::after {
  content: "";
  position: absolute;
  border-radius: 50% 50% 48% 48%;
  background: radial-gradient(circle at 34% 30%, #8af6f1 0, #34d6d1 58%, #19a6b7 100%);
}

.proof-icon--uniform::before {
  width: 20px;
  height: 26px;
  left: 4px;
  top: 14px;
}

.proof-icon--uniform::after {
  width: 20px;
  height: 26px;
  left: 18px;
  top: 10px;
  box-shadow: 16px 4px 0 0 #21c5ca;
}

.proof-icon--seal::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  background: radial-gradient(circle at 34% 30%, #d9b8ff 0, #9960ea 58%, #723ac8 100%);
}

.proof-icon--seal::after {
  content: "✓";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 24px;
  font-weight: 900;
}

.proof-card h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.08;
  letter-spacing: -0.04em;
  color: #ffffff;
}

.proof-card p {
  margin: 10px 0 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.76);
}

.happy-day-proof__palette-wrap {
  margin-top: 40px;
}

.happy-day-proof__palette {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px 14px;
  padding: 30px 28px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.palette-balloon {
  position: relative;
  display: block;
  aspect-ratio: 0.84 / 1;
  border-radius: 50% 50% 46% 46%;
  box-shadow: inset -8px -10px 18px rgba(0,0,0,0.1), 0 10px 18px rgba(0,0,0,0.16);
}

.palette-balloon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% - 1px);
  width: 1px;
  height: 18px;
  background: rgba(255,255,255,0.28);
  transform: translateX(-50%);
}

.palette-balloon--cream { background: radial-gradient(circle at 34% 28%, #fff3d8 0, #f0debf 68%, #d7be98 100%); }
.palette-balloon--yellow { background: radial-gradient(circle at 34% 28%, #fff2a6 0, #ffd54a 68%, #f0b125 100%); }
.palette-balloon--orange { background: radial-gradient(circle at 34% 28%, #ffd39e 0, #ff9e43 68%, #ef6e1f 100%); }
.palette-balloon--coral { background: radial-gradient(circle at 34% 28%, #ffb6a7 0, #ff7b5b 68%, #e4583b 100%); }
.palette-balloon--pink { background: radial-gradient(circle at 34% 28%, #ffb4cf 0, #ff5b92 68%, #e53173 100%); }
.palette-balloon--magenta { background: radial-gradient(circle at 34% 28%, #ff9bd7 0, #d94ac0 68%, #a92b8d 100%); }
.palette-balloon--violet { background: radial-gradient(circle at 34% 28%, #d6b6ff 0, #9a60ed 68%, #6a33bf 100%); }
.palette-balloon--lime { background: radial-gradient(circle at 34% 28%, #e8ff9e 0, #b5df42 68%, #84a81f 100%); }
.palette-balloon--green { background: radial-gradient(circle at 34% 28%, #b5f4b9 0, #5ecb67 68%, #31923f 100%); }
.palette-balloon--mint { background: radial-gradient(circle at 34% 28%, #aaf4e8 0, #4fd5bf 68%, #219b84 100%); }
.palette-balloon--sky { background: radial-gradient(circle at 34% 28%, #b6ecff 0, #62c9f7 68%, #2b91c8 100%); }
.palette-balloon--blue { background: radial-gradient(circle at 34% 28%, #9fc8ff 0, #4f8ef7 68%, #275fd0 100%); }
.palette-balloon--navy { background: radial-gradient(circle at 34% 28%, #88a3db 0, #334f96 68%, #1b2b59 100%); }
.palette-balloon--charcoal { background: radial-gradient(circle at 34% 28%, #6d6f81 0, #2d3040 68%, #171922 100%); }
.palette-balloon--white { background: radial-gradient(circle at 34% 28%, #ffffff 0, #eaedf3 68%, #cdd3dc 100%); }

.happy-day-proof__caption {
  margin: 18px 0 0;
  text-align: center;
  font-size: 16px;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.9);
}
