/* Feature 100/81: Production landing + homepage */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

[hidden] {
  display: none !important;
}

html,
body {
  width: 100%;
}

body {
  background: #ffffff;
  color: #070f52;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow-x: hidden;
}

img,
picture {
  display: block;
}

button {
  font-family: inherit;
}

ul {
  list-style: none;
}

:root {
  --kf-navy: #070f52;
  --kf-pink: #f42681;
  --kf-purple: #7e00b9;
  --kf-mint: #a9f3e3;
  --kf-sun: #f4fc81;
  --kf-cream: #f4f5de;
}

.homepage {
  min-height: 100vh;
}

.section-title {
  font-family: "Platypi", serif;
  font-style: italic;
  font-weight: 400;
  color: var(--kf-navy);
  text-align: center;
}

.section-subtitle {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  color: var(--kf-navy);
  text-align: center;
}

.section-body {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  color: var(--kf-navy);
}

.cta {
  border: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Inter", sans-serif;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  margin-left: auto;
  margin-right: auto;
}

.cta:focus-visible,
.hero-login:focus-visible,
.hero-burger:focus-visible {
  outline: 2px solid rgba(18, 100, 222, 0.5);
  outline-offset: 4px;
}

/* Burger menu drawer */
body.burger-menu-open {
  overflow: hidden;
}

body.modal-open {
  overflow: hidden;
}

.burger-menu {
  position: fixed;
  inset: 0;
  z-index: 900;
  display: flex;
}

.burger-menu[hidden] {
  display: none;
}

.burger-menu-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.44);
  pointer-events: none;
}

.burger-menu-drawer {
  width: 75vw;
  height: 100vh;
  transform: translateX(-100%);
  transition: transform 280ms ease;
  position: relative;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  background-image: linear-gradient(177.1108deg, #030720 0%, #070f52 100%);
}

.burger-menu-drawer::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/homepage/mobile/editorial-pattern.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-size: 133.74834215641022px 90px;
  background-repeat: repeat;
  opacity: 0.04;
  pointer-events: none;
}

.burger-menu-drawer::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/homepage/mobile/burger-menu-bg.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/burger-menu-bg.webp") type("image/webp"),
    url("/homepage/mobile/burger-menu-bg.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/burger-menu-bg.webp") type("image/webp"),
    url("/homepage/mobile/burger-menu-bg.png") type("image/png")
  );
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
}

.burger-menu-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 0 22px;
}

.burger-menu-header {
  padding-top: 35px;
  padding-bottom: 30px;
}

.burger-menu-logo picture,
.burger-menu-logo img {
  width: 133px;
  height: 16px;
}

.burger-menu-nav {
  width: 100%;
  max-width: 231px;
}

.burger-menu-group {
  display: flex;
  flex-direction: column;
}

.burger-menu-link {
  text-decoration: none;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  font-family: "Inter", sans-serif;
  font-size: 14px;
  line-height: 42px;
  font-weight: 600;
  color: #ffffff;
  cursor: pointer;
}

.burger-menu-link:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.65);
  outline-offset: 4px;
}

.burger-menu-separator {
  height: 40px;
  display: flex;
  align-items: center;
}

.burger-menu-separator::before {
  content: "";
  width: 100%;
  height: 1px;
  background: rgba(255, 255, 255, 0.4);
}

.burger-menu-overlay {
  width: 25vw;
  height: 100vh;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

.burger-menu[data-open="true"] .burger-menu-drawer {
  transform: translateX(0);
}

@media (prefers-reduced-motion: reduce) {
  .burger-menu-drawer {
    transition: none;
  }
}

@media (min-width: 1024px) {
  .burger-menu-drawer::after {
    background-image: url("/homepage/desktop/burger-menu-bg.png");
    background-image: -webkit-image-set(
      url("/homepage/desktop/burger-menu-bg.webp") type("image/webp"),
      url("/homepage/desktop/burger-menu-bg.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/desktop/burger-menu-bg.webp") type("image/webp"),
      url("/homepage/desktop/burger-menu-bg.png") type("image/png")
    );
  }

  .burger-menu-logo picture,
  .burger-menu-logo img {
    width: 150px;
    height: 18px;
  }

  .burger-menu-nav {
    max-width: 400px;
  }

  .burger-menu-link {
    font-size: 16px;
    line-height: 48px;
  }
}

/* Hero */
.hero {
  position: relative;
  width: 100%;
  height: 676.7436px;
}

@media (max-width: 375px) {
  .hero {
    height: clamp(676.7436px, calc(847.1976px - 45.4545vw), 701.7436px);
  }
}

@media (max-width: 360px) {
  .hero-subtitle {
    white-space: nowrap;
  }
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

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

.hero-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
  height: 100%;
}

.hero-top {
  width: 100%;
  padding: 32px 22px 11px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.hero-nav {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.hero-burger {
  width: 24px;
  height: 21px;
  padding-top: 3px;
  background: transparent;
  border: 0;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.hero-burger picture,
.hero-burger img {
  width: 24px;
  height: 16px;
}

.hero-logo picture,
.hero-logo img {
  width: 133px;
  height: 16px;
}

.hero-login {
  width: 26px;
  height: 21px;
  padding: 5px 3px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  white-space: nowrap;
  font-size: 12px;
  line-height: 10px;
  letter-spacing: -0.3125px;
  text-decoration: underline;
  background: transparent;
  border: 0;
  color: var(--kf-navy);
}

.hero-content {
  width: 100%;
  text-align: center;
}

.hero-title {
  margin: 46px 0 30px;
  font-family: "Inter", sans-serif;
  font-size: 97px;
  line-height: 80px;
  font-weight: 700;
  letter-spacing: -3px;
  color: var(--kf-navy);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hero-title-line {
  display: block;
}

.hero-subtitle {
  font-family: "Platypi", serif;
  font-style: italic;
  font-size: 45px;
  line-height: 32px;
  letter-spacing: -1px;
  color: var(--kf-navy);
}

.hero-tagline {
  margin: 51px 0 38px;
  font-size: 17px;
  line-height: 25px;
  letter-spacing: 1px;
  font-weight: 500;
  background-image: linear-gradient(130.83650073229958deg,
      rgb(244, 37, 129) 42.927%,
      rgb(167, 13, 166) 100.14%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  width: 100%;
}

.cta-primary {
  width: 100%;
  max-width: 300px;
  height: 46px;
  background: linear-gradient(135.0555287947857deg, #f42581 11.5%, #7e00b9 43.797%);
  color: #ffffff;
  font-size: 14px;
  font-weight: 700;
  margin: 0 auto;
}

.hero-kid {
  width: 100%;
  max-width: 350px;
  margin-top: auto;
}

.hero-kid img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Editorial logos */
.editorial-logos {
  position: relative;
  padding: 50px 22px;
  display: flex;
  justify-content: center;
}

.editorial-bg {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(134.60256482373578deg,
      rgb(1, 21, 68) 42.412%,
      rgb(11, 24, 130) 90.202%,
      rgb(16, 34, 184) 105.49%);
}

.editorial-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/homepage/mobile/editorial-pattern.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-size: 133.74834215641022px 90px;
  background-repeat: repeat;
  opacity: 0.07;
}

.editorial-list {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 63px;
  width: 100%;
  max-width: 350px;
}

.editorial-logo img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Method */
.method {
  background: #ffffff;
  padding-top: 50px;
}

.method-inner {
  max-width: 400px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.method-heading {
  width: 100%;
  padding: 0 22px;
  text-align: center;
}

.method-title {
  font-size: 39px;
  line-height: 53.664px;
  letter-spacing: -1.3px;
}

.method-break-narrow {
  display: inline;
}

@media (min-width: 390px) {
  .method-break-narrow {
    display: none;
  }
}

.method-chart {
  padding: 40px 22px 0;
  width: 100%;
  height: clamp(199.9879px, calc(14.4947px + 57.9666vw), 246.3611px);
}

.method-chart picture {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.method-chart img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.method-copy {
  width: 100%;
  padding: 30px 22px 4px;
  text-align: center;
}

.method-copy .section-body {
  margin-top: 0;
  font-size: 16px;
  line-height: 24px;
  text-align: left;
}

.cta-sun {
  width: 297px;
  max-width: 100%;
  height: 46px;
  margin: 40px auto 50px;
  background: var(--kf-sun);
  color: var(--kf-navy);
  font-size: 14px;
  font-weight: 600;
}

/* Smoothing */
.smoothing {
  background: var(--kf-cream);
  padding-top: 50px;
}

.smoothing-inner {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.smoothing-inner .section-title {
  font-size: 40px;
  line-height: normal;
  letter-spacing: -1px;
}

.smoothing-title-desktop {
  display: none;
}

.smoothing-content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.smoothing-visual {
  position: relative;
  width: 100%;
  height: clamp(368.8159px, calc(57px + 97.4425vw), 640.6804px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.smoothing-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.smoothing-bg img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.smoothing-phone {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
}

.smoothing-phone img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

@media (max-width: 1023px) {
  .smoothing-phone img {
    object-position: center bottom;
  }
}

.smoothing-copy {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  background-image: url("/homepage/mobile/stc-hand-bg.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/stc-hand-bg.webp") type("image/webp"),
    url("/homepage/mobile/stc-hand-bg.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/stc-hand-bg.webp") type("image/webp"),
    url("/homepage/mobile/stc-hand-bg.png") type("image/png")
  );
  background-size: cover; /* 100/81: Figma fill */
  background-position: center;
  background-repeat: no-repeat;
  padding: 30px 22px 4px;
}

.smoothing-body {
  font-size: 16px;
  line-height: 24px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cta-mint {
  width: 297px;
  max-width: 100%;
  height: 46px;
  margin: 40px auto 50px;
  background: var(--kf-mint);
  color: var(--kf-navy);
  font-size: 14px;
  font-weight: 600;
}

/* Whole-child */
.whole-child {
  background: #ffffff;
  padding-top: 50px;
}

.whole-child-inner {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.whole-child-title {
  width: 100%;
  font-size: 40px;
  line-height: 55.04px;
  letter-spacing: -1px;
}

.whole-child-visual {
  position: relative;
  width: 100%;
  height: clamp(430.8159px, calc(119px + 97.4425vw), 557.4911px);
  text-align: center;
}

.whole-child-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.whole-child-bg img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.whole-child-bg-heading {
  padding: 0 22px 20px;
  width: 320px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  z-index: 1;
}

.whole-child-bg-title {
  font-size: 40px;
  line-height: 55.04px;
  letter-spacing: -1px;
}

.whole-child-bg-subtitle {
  font-size: 20px;
  line-height: 24px;
  letter-spacing: -1px;
}

.whole-child-image {
  width: min(450px, 100%);
  aspect-ratio: 450 / 438.491;
  height: auto;
  margin: 0 auto;
  padding-bottom: 0;
  position: relative;
  z-index: 1;
}

.whole-child-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.whole-child-copy {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  padding: 30px 22px 0;
  text-align: center;
}

.whole-child-copy .section-body {
  margin-top: 0;
  font-size: 16px;
  line-height: 24px;
  text-align: left;
}

.cta-outline {
  width: 297px;
  max-width: 100%;
  height: 50px;
  margin: 40px auto 50px;
  background: #ffffff;
  border: 1px solid var(--kf-navy);
  color: var(--kf-navy);
  font-size: 16px;
  font-weight: 400;
  letter-spacing: -0.2px;
}

@media (min-width: 390px) and (max-width: 390px) {
  .whole-child-copy .section-body {
    letter-spacing: -0.1px;
  }
}


.whole-child-title-desktop,
.whole-child-subtitle-desktop {
  display: none;
}

/* Who it is for */
.who-for {
  position: relative;
  padding: 50px 0;
}

.who-for-bg {
  position: absolute;
  inset: 0;
  background: var(--kf-cream);
  background-image: url("/homepage/mobile/wiif-bg.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/wiif-bg.webp") type("image/webp"),
    url("/homepage/mobile/wiif-bg.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/wiif-bg.webp") type("image/webp"),
    url("/homepage/mobile/wiif-bg.png") type("image/png")
  );
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.who-for .section-title {
  position: relative;
  z-index: 1;
  font-size: 40px;
  letter-spacing: -1px;
  padding-bottom: 30px;
}

.who-for-icons {
  position: relative;
  z-index: 1;
  padding: 0 22px;
  height: 126px;
}

.who-for-icons img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Peace of mind */
.peace {
  position: relative;
  padding: 40px 22px 0;
}

.peace-bg {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(-72.41033951742443deg, rgb(126, 0, 185) 2.3247%, rgb(13, 27, 149) 82.344%);
}

.peace-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/homepage/mobile/editorial-pattern.png");
  background-image: -webkit-image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-image: image-set(
    url("/homepage/mobile/editorial-pattern.webp") type("image/webp"),
    url("/homepage/mobile/editorial-pattern.png") type("image/png")
  );
  background-size: 133.74834215641022px 90px;
  background-repeat: repeat;
  opacity: 0.07;
}

.peace-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-areas:
    "main"
    "security"
    "cta";
  gap: 20px;
  max-width: 400px;
  margin: 0 auto;
}

.peace-main {
  grid-area: main;
  width: 100%;
  min-width: 0;
}

.peace-security {
  grid-area: security;
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch; /* KID-90: children stretch to fill width, align content via text-align */
  gap: 26px;
  text-align: center;
}

.peace-shield {
  width: 100%;
  display: flex;
  justify-content: center;
}

.peace-cta-wrap {
  grid-area: cta;
  width: 100%;
  min-width: 0;
  display: flex;
  justify-content: center;
  padding: 40px 17px 54px;
}

.peace-cta {
  width: 100%;
  max-width: 297px;
  margin: 0;
  height: 46px;
  font-size: 14px;
  font-weight: 600;
}

.peace-main .section-title {
  font-size: 45px;
  line-height: 61.92px;
  color: #ffffff;
  letter-spacing: -1px;
  padding-bottom: 30px;
  max-width: 307px;
  margin: 0 auto;
}

.peace-list {
  display: flex;
  flex-direction: column;
  gap: 28px;
  width: 100%;
  min-width: 0;
  margin-top: 20px;
  padding-bottom: 20px;
}

.peace-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

@media (max-width: 1023px) {
  .peace-list li:first-child {
    align-items: center;
  }
}

.peace-list span {
  font-size: 16px;
  color: #ffffff;
  line-height: 19px;
  min-width: 0;
}

.peace-list .peace-cta-inline {
  display: none;
}

.peace-bullet {
  flex: 0 0 34px;
}

.peace-bullet img {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.peace-shield img {
  width: 52px;
  height: 63px;
}

.peace-security .section-subtitle {
  color: #ffffff;
  font-family: "Platypi", serif;
  font-style: italic;
  font-size: 25px;
  line-height: 34.4px;
  padding-bottom: 10px;
}

.peace-subtitle-break {
  display: none;
}

.peace-safe-list {
  display: flex;
  flex-direction: column;
  gap: 11px;
  align-items: flex-start;
}

.peace-safe-list li {
  display: flex;
  gap: 12px;
  align-items: center;
}

.peace-safe-list span {
  color: #ffffff;
  font-size: 16px;
}

.peace-check {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.peace-check img {
  width: 21px;
  height: 23px;
}

/* Footer */
.site-footer {
  background-image: linear-gradient(84.81738596752022deg, rgb(3, 7, 32) 4.6751%, rgb(7, 15, 82) 83.461%);
  color: #ffffff;
}

.footer-inner {
  max-width: 400px;
  margin: 0 auto;
  padding: 0 22px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.footer-tagline {
  font-family: "Platypi", serif;
  font-style: italic;
  font-size: 20px;
  line-height: 41.6px;
  padding-top: 30px;
}

.footer-links {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 19.3636px;
  display: flex;
  justify-content: center;
  gap: 8px;
  padding-top: 28px;
}

.footer-links a {
  color: #ffffff;
  text-decoration: underline;
}

.footer-bottom {
  display: flex;
  flex-direction: column-reverse;
  gap: 10px;
  align-items: center;
  padding: 30px 0;
}

.footer-copy {
  font-size: 16px;
  line-height: 41.6px;
}

.footer-social {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 251px;
  height: 50px;
}

/* KID-101: Hide social icons (code kept for future use) */
.footer-social {
  display: none;
}

.footer-social a {
  pointer-events: none;
  cursor: default;
}

.footer-social img {
  width: 20px;
  height: 20px;
}

.footer-social a:nth-child(3) img {
  width: 11px;
}

.footer-social a:nth-child(4) img {
  width: 36px;
}

.footer-social a:nth-child(5) img {
  width: 27px;
}

.footer-social a:nth-child(6) img {
  width: 16px;
}

/* Tablet breakpoint */
@media (min-width: 600px) {

  .cta-sun,
  .cta-mint,
  .cta-outline {
    width: 400px;
  }

  .peace-security {
    padding: 0 22px;
  }

  .peace-cta {
    max-width: 400px;
  }

  .hero {
    height: clamp(788.6667px, calc(798.6301px - 1.2973vw), 790.8462px);
  }

  .hero-tagline {
    background-image: linear-gradient(165.18536996832836deg,
        rgb(244, 37, 129) 42.927%,
        rgb(167, 13, 166) 100.14%);
  }

  .hero-kid {
    width: 100%;
    max-width: 650px;
  }

  .editorial-logos {
    padding: 30px 48px;
  }

  .smoothing-visual {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
  }

  .smoothing-bg img {
    object-fit: cover;
    object-position: center;
  }

  .editorial-bg {
    background-image: linear-gradient(173.40731347093708deg,
        rgb(1, 21, 68) 42.412%,
        rgb(11, 24, 130) 90.202%,
        rgb(16, 34, 184) 105.49%);
  }

  .editorial-bg::after {
    background-image: url("/homepage/tablet/editorial-pattern.png");
    background-image: -webkit-image-set(
      url("/homepage/tablet/editorial-pattern.webp") type("image/webp"),
      url("/homepage/tablet/editorial-pattern.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/tablet/editorial-pattern.webp") type("image/webp"),
      url("/homepage/tablet/editorial-pattern.png") type("image/png")
    );
  }

  .editorial-list {
    flex-direction: row;
    max-width: 1760px;
  }

  .method-inner,
  .peace-inner,
  .footer-inner {
    max-width: 650px;
  }

  .method-chart {
    height: clamp(362.2944px, calc(14.4947px + 57.9666vw), 391.2777px);
  }

  .smoothing-visual {
    height: clamp(641.6548px, calc(57px + 97.4425vw), 836.5397px);
  }

  .smoothing-copy {
    max-width: 650px;
    background-image: url("/homepage/tablet/stc-hand-bg.png");
    background-image: -webkit-image-set(
      url("/homepage/tablet/stc-hand-bg.webp") type("image/webp"),
      url("/homepage/tablet/stc-hand-bg.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/tablet/stc-hand-bg.webp") type("image/webp"),
      url("/homepage/tablet/stc-hand-bg.png") type("image/png")
    );
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }

  .whole-child-bg-heading {
    width: calc(100% - 62px);
  }

  .whole-child-copy {
    max-width: 650px;
  }

  .who-for {
    padding: 50px 0;
  }

  .who-for-bg {
    background-image: url("/homepage/tablet/wiif-bg.png");
    background-image: -webkit-image-set(
      url("/homepage/tablet/wiif-bg.webp") type("image/webp"),
      url("/homepage/tablet/wiif-bg.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/tablet/wiif-bg.webp") type("image/webp"),
      url("/homepage/tablet/wiif-bg.png") type("image/png")
    );
  }

  .peace-bg::after {
    background-image: url("/homepage/tablet/editorial-pattern.png");
    background-image: -webkit-image-set(
      url("/homepage/tablet/editorial-pattern.webp") type("image/webp"),
      url("/homepage/tablet/editorial-pattern.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/tablet/editorial-pattern.webp") type("image/webp"),
      url("/homepage/tablet/editorial-pattern.png") type("image/png")
    );
  }

  .peace-main {
    padding: 0 22px;
  }

  .peace-cta-wrap {
    padding: 40px 39px 54px;
  }

  .footer-inner {
    max-width: 400px;
  }
}

/* Desktop breakpoint */
@media (min-width: 768px) {
  .hero {
    height: 788.6667px;
  }
}

@media (min-width: 1024px) {
  .hero {
    height: 802px;
  }

  .hero-top {
    padding: 25px 80px 0;
  }

  .hero-burger {
    width: 100px;
    height: 22px;
  }

  .hero-logo picture,
  .hero-logo img {
    width: 182.876px;
    height: 22px;
  }

  .hero-login {
    width: 100px;
    height: 21px;
    padding: 5px 3px;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    font-size: 16px;
    line-height: 7px;
    letter-spacing: 0;
    text-align: right;
  }

  .hero-title {
    margin-top: 105px;
    margin-bottom: 0;
    font-size: 164px;
    line-height: 111px;
    flex-direction: row;
    gap: 12px;
    justify-content: center;
  }

  .hero-title-line {
    display: inline;
  }

  .hero-title-line+.hero-title-line {
    margin-left: 12px;
  }

  .hero-subtitle {
    margin-top: 39px;
    font-size: 70px;
    line-height: 96.32px;
    letter-spacing: -2.75px;
  }

  .hero-tagline {
    margin: 47px 0;
    font-size: 25.5px;
    line-height: 35px;
    letter-spacing: 1.12px;
    background-image: linear-gradient(168.1710245479063deg,
        rgb(244, 37, 129) 42.927%,
        rgb(167, 13, 166) 100.14%);
  }

  .cta-primary {
    width: 242px;
    height: 45px;
    font-size: 16px;
    margin-bottom: 35px;
    background: linear-gradient(129.56326105242582deg, #f42581 11.5%, #7e00b9 43.797%);
  }

  .hero-kid {
    width: 100%;
    height: 165px;
    max-width: none;
    margin-top: 0;
  }

  .hero-kid picture {
    width: 100%;
    height: 100%;
  }

  .hero-kid img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
  }

  .editorial-logos {
    padding: 60px 80px;
  }

  .editorial-bg {
    background-image: linear-gradient(172.77594594202827deg,
        rgb(1, 21, 68) 42.412%,
        rgb(11, 24, 130) 90.202%,
        rgb(16, 34, 184) 105.49%);
  }

  .editorial-bg::after {
    background-image: url("/homepage/desktop/editorial-pattern.png");
    background-image: -webkit-image-set(
      url("/homepage/desktop/editorial-pattern.webp") type("image/webp"),
      url("/homepage/desktop/editorial-pattern.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/desktop/editorial-pattern.webp") type("image/webp"),
      url("/homepage/desktop/editorial-pattern.png") type("image/png")
    );
  }

  .method {
    padding: 125px 80px;
  }

  .method-inner {
    max-width: 1920px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 0;
    align-items: start;
  }

  .method-heading {
    grid-column: 2;
    grid-row: 1;
    padding: 0;
  }

  .method-chart {
    grid-column: 1;
    grid-row: 1 / span 2;
    padding: 0;
    margin-top: 0;
    align-self: center;
    width: 100%;
    height: clamp(243.4598px, calc(-53.3293px + 28.9833vw), 503.1502px);
  }

  .method-copy {
    grid-column: 2;
    grid-row: 2;
    padding: 0;
    width: 100%;
    text-align: center;
  }

  .method-title {
    font-size: 65px;
    line-height: 89.44px;
  }

  .method-copy .section-body {
    margin-top: 70px;
    font-size: 18px;
    line-height: 30px;
  }

  .cta-sun {
    width: 260px;
    height: 60px;
    margin: 100px auto 0;
    font-size: 18px;
  }

  .smoothing {
    padding: 50px 0;
  }

  .smoothing-inner {
    max-width: 1920px;
    padding: 0;
    align-items: stretch;
  }

  .smoothing-inner .section-title {
    font-size: 65px;
  }

  .smoothing-title-mobile {
    display: none;
  }

  .smoothing-title-desktop {
    display: block;
    margin-bottom: 0;
  }

  .smoothing-content {
    max-width: 1920px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 24px;
    align-items: center; /* KID-88: Figma has counterAxisAlignItems=CENTER */
  }

  .smoothing-visual {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    max-width: none;
    margin: 0;
    overflow: visible;
    height: clamp(668.4911px, calc(169.5858px + 48.7212vw), 1105.0332px);
  }

  .smoothing-copy {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    max-width: none;
    margin: 0;
    background-image: url("/homepage/desktop/stc-bg-left.png");
    background-image: -webkit-image-set(
      url("/homepage/desktop/stc-bg-left.webp") type("image/webp"),
      url("/homepage/desktop/stc-bg-left.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/desktop/stc-bg-left.webp") type("image/webp"),
      url("/homepage/desktop/stc-bg-left.png") type("image/png")
    );
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 0 0 0 80px;
  }

  .smoothing-body {
    font-size: 18px;
    line-height: 30px;
    padding: 70px 0 0;
  }

  .smoothing-bg {
    inset: 0;
  }

  .smoothing-bg img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: contain; /* KID-88: Figma STC right bg is scaleMode=FIT */
    object-position: center;
  }

  .smoothing-phone {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 50px 50px 0; /* KID-88: Figma has paddingRight=50, paddingLeft=0 */
    height: auto;
  }

  .smoothing-phone::before {
    content: "";
    display: block;
    height: 40px;
  }

  .smoothing-phone img {
    height: auto;
    margin: 50px 0;
  }

  .smoothing-copy .cta-mint {
    width: 260px;
    height: 60px;
    margin: 100px auto 0;
    font-size: 14px;
  }

  .whole-child {
    padding: 125px 0;
  }

  .whole-child-inner {
    max-width: 1920px;
    padding: 0;
    flex-direction: row;
    align-items: center;
    gap: 24px;
  }

  .whole-child-title,
  .whole-child-bg-heading {
    display: none;
  }

  .whole-child-bg {
    display: none;
  }

  .whole-child-title-desktop,
  .whole-child-subtitle-desktop {
    display: block;
  }

  .whole-child-visual,
  .whole-child-copy {
    width: calc((100% - 24px) / 2);
    flex: 0 0 calc((100% - 24px) / 2);
    min-width: 0;
  }

  .whole-child-visual {
    padding-left: 20px;
    height: clamp(521.7238px, calc(22.8184px + 48.7212vw), 958.2661px);
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .whole-child-visual::before {
    content: "";
    display: block;
    height: 54px;
    flex: 0 0 54px;
    opacity: 0;
  }

  .whole-child-image {
    padding-bottom: 0;
    width: 100%;
    height: auto;
    aspect-ratio: auto;
    flex: 1;
    display: block;
  }

  .whole-child-image img {
    max-width: none;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
  }

  .whole-child-copy {
    padding: 0 80px 0 0;
    max-width: none;
    margin: 0;
  }

  .whole-child-title-desktop {
    font-size: 65px;
    line-height: 89.44px;
    letter-spacing: -1px;
  }

  .whole-child-subtitle-desktop {
    font-size: 45px;
    line-height: 54.46px;
    letter-spacing: -1px;
    margin-top: 30px;
  }

  .whole-child-copy .section-body {
    margin-top: 70px;
    font-size: 18px;
    line-height: 30px;
  }

  .cta-outline {
    width: 280px;
    height: 60px;
    margin: 80px auto 0;
    font-size: 18px;
  }

  .who-for {
    padding: 150px 0;
  }

  .who-for-bg {
    background-image: url("/homepage/desktop/wiif-bg.png");
    background-image: -webkit-image-set(
      url("/homepage/desktop/wiif-bg.webp") type("image/webp"),
      url("/homepage/desktop/wiif-bg.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/desktop/wiif-bg.webp") type("image/webp"),
      url("/homepage/desktop/wiif-bg.png") type("image/png")
    );
  }

  .who-for .section-title {
    font-size: 65px;
    padding-bottom: 80px;
  }

  .who-for-icons {
    padding: 0 80px;
    height: 250px;
  }

  .peace {
    padding: 125px 0;
  }

  .peace-bg {
    background-image: linear-gradient(-40.40686478904624deg, rgb(126, 0, 185) 2.3247%, rgb(13, 27, 149) 82.344%);
  }

  .peace-bg::after {
    background-image: url("/homepage/desktop/editorial-pattern.png");
    background-image: -webkit-image-set(
      url("/homepage/desktop/editorial-pattern.webp") type("image/webp"),
      url("/homepage/desktop/editorial-pattern.png") type("image/png")
    );
    background-image: image-set(
      url("/homepage/desktop/editorial-pattern.webp") type("image/webp"),
      url("/homepage/desktop/editorial-pattern.png") type("image/png")
    );
  }

  .peace-inner {
    max-width: 1920px;
    padding: 0;
    grid-template-areas: "main security";
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 0;
    row-gap: 0;
  }

  .peace-main {
    padding: 0 0 0 80px;
  }

  .peace-security {
    align-self: center;
  }

  .peace-main .section-title {
    font-size: 65px;
    line-height: 89.44px;
    max-width: none;
    margin: 0;
    padding-bottom: 70px;
  }

  .peace-list {
    gap: 40px;
    margin-top: 0;
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .peace-list li {
    gap: 20px;
  }

  .peace-list li:nth-child(2) .peace-bullet,
  .peace-list li:nth-child(3) .peace-bullet {
    padding: 5px 0;
  }

  .peace-list span {
    font-size: 18px;
    line-height: 30px;
    flex: 1;
    min-width: 0;
  }

  .peace-cta-wrap {
    display: none;
  }

  .peace-list .peace-cta-inline {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 140px;
    padding: 60px 39px 0;
    width: 100%;
  }

  .peace-cta {
    width: 260px;
    height: 60px;
    margin: 0;
    font-size: 18px;
    line-height: 20px;
    padding: 0 10px;
  }

  .peace-shield img {
    width: 123px;
    height: 150px;
  }

  .peace-security .section-subtitle {
    font-size: 50px;
    line-height: 68.8px;
  }

  .peace-subtitle-break {
    display: block;
  }

  .peace-safe-list {
    gap: 30px;
    align-items: center;
  }

  .peace-safe-list li {
    gap: 14px;
  }

  .peace-check {
    width: 21px;
    height: 23px;
    flex: 0 0 21px;
  }

  .peace-check img {
    width: 21px;
    height: 23px;
  }

  .peace-safe-list span {
    font-size: 18px;
    line-height: 21.7841px;
  }

  .site-footer {
    background-image: linear-gradient(77.54816258039095deg, rgb(3, 7, 32) 4.6751%, rgb(7, 15, 82) 83.461%);
  }

  .footer-inner {
    max-width: 1920px;
    padding: 0 80px;
    gap: 5px;
  }

  .footer-tagline {
    font-size: 40px;
    padding: 125px 0 100px;
  }

  .footer-links {
    font-size: 18px;
    line-height: 21.7841px;
    padding: 0;
  }

  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    padding: 60px 0 50px;
  }

  .footer-copy {
    font-size: 18px;
  }

  .footer-social {
    width: 304px;
  }

  .footer-social img {
    width: 25px;
    height: 25px;
  }

  .footer-social a:nth-child(3) img {
    width: 13px;
  }

  .footer-social a:nth-child(4) img {
    width: 36px;
  }

  .footer-social a:nth-child(5) img {
    width: 27px;
  }

  .footer-social a:nth-child(6) img {
    width: 21px;
  }
}


@media (min-width: 1921px) {
  .homepage {
    max-width: 1920px;
    margin: 0 auto;
  }

  .hero-inner {
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
  }

  .hero-bg {
    width: 100%;
    max-width: 1920px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }

  .method {
    padding-left: 0;
    padding-right: 0;
  }

  .method-inner {
    max-width: 1920px;
    padding: 0 80px;
  }

}

/* ================================
   Modal Styles (Figma 15053:596)
   Desktop: 450px width
   Mobile (<=480px): 360px width
   ================================ */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 16px;
}

.modal-backdrop[hidden] {
  display: none;
}

.modal {
  position: relative;
  width: 450px;
  max-width: 100%;
  background: #fff;
  border-radius: 8px;
  padding: 20px 20px 50px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.modal-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.modal-top-row {
  width: 100%;
  height: 14.142px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
}

.modal-close {
  width: 14.142px;
  height: 14.142px;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
}

.modal-close:focus {
  outline: none;
}

.modal-close:focus-visible {
  outline: 2px solid rgba(18, 100, 222, 0.5);
  outline-offset: 4px;
  border-radius: 2px;
}

.modal-close-icon {
  display: block;
  width: 14.142px;
  height: 14.142px;
}

.modal-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-logo-img {
  width: 171px;
  height: 20px;
}

.modal-header {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.modal-heading {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 15px 0 35px;
}

.modal-title {
  margin: 0;
  font-family: "Platypi", serif;
  font-style: italic;
  font-size: 25px;
  font-weight: 400;
  line-height: normal;
  color: #070f52;
  width: 100%;
  text-align: center;
  white-space: pre-line;
}

.modal-body {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 9px;
  padding-left: 10px;
  padding-right: 10px;
}

.modal-intro {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 19px;
  color: #070f52;
  text-align: left;
  padding-bottom: 15px;
}

.modal-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 9px;
  text-align: left;
}

.form-label {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 16px;
  color: #070f52;
}

.modal-form input[type="email"] {
  width: 100%;
  height: 49px;
  padding: 15px 0 15px 20px;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 19px;
  color: #1264de;
  border: 1px solid rgba(7, 15, 82, 0.3);
  border-radius: 3px;
  outline: none;
  background: #fff;
  font-style: normal;
}

.modal-form input[type="email"]::placeholder {
  color: #c6c8d7;
  font-style: italic;
  opacity: 1;
}

.modal-form input[type="email"]:focus {
  border-color: rgba(7, 15, 82, 0.6);
}

.form-terms {
  margin: 0;
  padding-bottom: 20px;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 18px;
  color: #070f52;
}

.form-terms-link {
  color: #1264de;
  text-decoration: none;
}

.form-terms-link:hover,
.form-terms-link:focus-visible {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.modal-submit {
  width: 100%;
  height: 50px;
  padding: 15px 0;
  text-align: center;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 13px;
  font-weight: 600;
  line-height: 20px;
  letter-spacing: -0.2px;
  color: #fff;
  background: linear-gradient(140.1549deg, #f42581 11.5%, #7e00b9 43.797%);
  border: 0;
  border-radius: 0;
  cursor: pointer;
}

.modal-submit:disabled {
  background: #c6c8d7;
  cursor: not-allowed;
}

.form-status {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 18px;
  color: #070f52;
}

.form-status:empty {
  display: none;
}

.modal--completed {
  padding-bottom: 75px;
}

.modal--completed .modal-heading {
  padding-top: 30px;
}

.modal--completed .modal-intro {
  text-align: center;
}

.modal-email-display {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px 0 70px;
  border-radius: 3px;
}

.modal-email-value {
  margin: 0;
  width: 100%;
  text-align: center;
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-style: italic;
  line-height: 19px;
  color: #1264de;
}

@media (max-width: 480px) {
  .modal {
    width: 360px;
  }

  .modal-intro {
    font-size: 12px;
    line-height: 17px;
  }

  .form-label {
    font-size: 11px;
  }

  .modal-form input[type="email"] {
    height: 39px;
    padding: 10px;
  }

  .form-terms,
  .form-status {
    font-size: 11px;
  }

  .modal-submit {
    height: 40px;
    padding: 10px 0;
    background: linear-gradient(139.0459deg, #f42581 11.5%, #7e00b9 43.797%);
  }
}
/* ================================
   Content Pages (Feature 105)
   Static content pages: /privacy, /terms, /about, /contact
   ================================ */

.content-page {
  min-height: 100vh;
  background: #ffffff;
  padding-top: 120px;
  padding-bottom: 80px;
}

.content-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 22px;
  color: var(--kf-navy);
}

.content-container h1 {
  font-family: "Platypi", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 40px;
  line-height: 1.2;
  letter-spacing: -1px;
  margin-bottom: 40px;
  text-align: center;
}

.content-container h2 {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 1.3;
  margin-top: 48px;
  margin-bottom: 16px;
}

.content-container h3 {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.4;
  margin-top: 32px;
  margin-bottom: 12px;
}

.content-container p {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  margin-bottom: 16px;
}

.content-container ul,
.content-container ol {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  margin-bottom: 16px;
  padding-left: 24px;
  list-style: disc;
}

.content-container ol {
  list-style: decimal;
}

.content-container li {
  margin-bottom: 8px;
}

.content-container a {
  color: #1264de;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.content-container a:hover,
.content-container a:focus-visible {
  text-decoration-thickness: 2px;
}

.content-container strong {
  font-weight: 600;
}

.content-container em {
  font-style: italic;
}

/* Tablet breakpoint */
@media (min-width: 600px) {
  .content-page {
    padding-top: 140px;
    padding-bottom: 100px;
  }

  .content-container {
    padding: 0 48px;
  }

  .content-container h1 {
    font-size: 50px;
    margin-bottom: 50px;
  }

  .content-container p,
  .content-container ul,
  .content-container ol {
    font-size: 17px;
  }
}

/* Desktop breakpoint */
@media (min-width: 1024px) {
  .content-page {
    padding-top: 160px;
    padding-bottom: 125px;
  }

  .content-container {
    padding: 0 80px;
  }

  .content-container h1 {
    font-size: 60px;
    margin-bottom: 60px;
  }

  .content-container h2 {
    font-size: 28px;
    margin-top: 56px;
  }

  .content-container p,
  .content-container ul,
  .content-container ol {
    font-size: 18px;
    line-height: 1.8;
  }
}
