@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500;1,9..144,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --red: #E01B22;
  --red-dark: #B0141A;
  --red-tint: #FCEDED;
  --blush: #FBEAE8;
  --ink: #26221F;
  --soft-ink: #3a342f;
  --paper: #FDFBF8;
  --cream: #FAF4EE;
  --cream-2: #F5EDE4;
  --white: #FFFFFF;
  --line: #ECE4DA;
  --line-strong: #DED4C7;
  --muted: #6E665D;
  --faint: #9A9186;
  --r: 10px;
  --r-lg: 16px;
  --r-xl: 24px;
  --sans: 'Hanken Grotesk', -apple-system, sans-serif;
  --serif: 'Fraunces', Georgia, serif;
  --maxw: 1180px;
  --shadow: 0 24px 60px -32px rgba(60, 40, 30, .28);
}

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

html {
  scroll-behavior: smooth
}

body {
  font-family: var(--sans);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  font-feature-settings: "liga" 0, "clig" 0, "dlig" 0, "calt" 0;
  -webkit-overflow-scrolling: touch;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none
}

input,
textarea {
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text
}

a {
  color: inherit;
  text-decoration: none
}

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

.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 28px
}

h1,
h2,
h3 {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.13;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-wrap: balance
}

.eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--red)
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0)
}

/* shared scene + animations */
.scene {
  position: absolute;
  inset: -5%;
  z-index: 0;
  animation: kenburns 38s ease-in-out infinite alternate;
  will-change: transform;
  transform: translate3d(0, 0, 0)
}

.scene svg {
  width: 100%;
  height: 100%;
  display: block
}

.scene video {
  width: 100%;
  height: 100%;
  object-fit: cover
}

@keyframes kenburns {
  from {
    transform: scale(1.03) translate(0, 0)
  }

  to {
    transform: scale(1.11) translate(-1.2%, -1.6%)
  }
}

.clouds {
  animation: drift 90s linear infinite
}

@keyframes drift {
  from {
    transform: translateX(-70px)
  }

  to {
    transform: translateX(140px)
  }
}

.shimmer {
  animation: shim 7s ease-in-out infinite
}

@keyframes shim {

  0%,
  100% {
    opacity: .3
  }

  50% {
    opacity: .85
  }
}

/* image placeholder system */
.imgph {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: linear-gradient(135deg, #EDE6DB, #E2D8C9);
  display: flex;
  align-items: flex-end;
  min-height: 120px
}

.imgph::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 72% 22%, rgba(255, 255, 255, .55), transparent 56%);
  pointer-events: none
}

.imgph .imgph-ic {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -62%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .82);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  font-size: 25px;
  box-shadow: 0 8px 22px -12px rgba(60, 40, 30, .4);
  z-index: 1
}

.imgph .imgph-cap {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 10px;
  padding: 13px 15px;
  background: linear-gradient(180deg, transparent, rgba(25, 18, 14, .34))
}

.imgph .imgph-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 13.5px;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0, 0, 0, .35);
  line-height: 1.3
}

.imgph .imgph-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(255, 255, 255, .2);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  padding: 4px 8px;
  border-radius: 6px;
  white-space: nowrap
}

.imgph.flush {
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--line)
}

.imgph.v-city {
  background: linear-gradient(135deg, #CBD9E4, #AEC4D6)
}

.imgph.v-mtn {
  background: linear-gradient(135deg, #C9DBE7, #9FBFD4)
}

.imgph.v-park {
  background: linear-gradient(135deg, #CCDCC4, #A4C29C)
}

.imgph.v-water {
  background: linear-gradient(135deg, #BFDDE6, #92C0D2)
}

.imgph.v-clinic {
  background: linear-gradient(135deg, #EFEAE3, #D9D0C4)
}

.imgph.v-life {
  background: linear-gradient(135deg, #F7E3D7, #E9C7B6)
}

.imgph.v-family {
  background: linear-gradient(135deg, #F4E8D0, #E6CFA6)
}

.imgph.v-doc {
  background: linear-gradient(135deg, #ECE7DE, #D7CEC0)
}

.imgph.v-home {
  background: linear-gradient(135deg, #F1E7D7, #DEC9AC)
}

/* updates bar */
.updates {
  background: linear-gradient(90deg, var(--cream), var(--blush), var(--cream));
  border-bottom: 1px solid var(--line);
  font-size: 13.5px
}

.updates .wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 42px;
  cursor: pointer;
  text-align: center
}

.updates .tag {
  background: var(--red);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 6px;
  white-space: nowrap
}

.updates .txt {
  color: var(--soft-ink);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap
}

.updates .more {
  color: var(--red);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap
}

.updates:hover .more {
  gap: 7px
}

/* header */
header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(253, 251, 248, .67);
  backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid var(--line)
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 74px;
  gap: 18px
}

.logo {
  display: flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0
}

.logo img {
  height: 38px;
  width: auto
}

.menu {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: auto
}

.menu>.item {
  position: relative
}

.menu>.item>a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 10px 13px;
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink);
  border-radius: 8px;
  cursor: pointer;
  transition: color .15s;
  white-space: nowrap
}

.menu>.item>a:hover,
.menu>.item>a.active {
  color: var(--red)
}

.caret {
  font-size: 14px;
  opacity: .55;
  transition: transform .2s
}

.item:hover .caret {
  transform: rotate(180deg)
}

.dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 266px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: all .18s ease;
  box-shadow: var(--shadow)
}

.item:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0)
}

.dropdown a {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  transition: background .14s
}

.dropdown a:hover {
  background: var(--cream)
}

.dropdown .di {
  color: var(--red);
  font-size: 19px;
  margin-top: 1px
}

.dropdown .dt {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3
}

.dropdown .dd {
  font-size: 12.5px;
  color: var(--faint);
  line-height: 1.35
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 14.5px;
  border: none;
  border-radius: 10px;
  padding: 11px 20px;
  cursor: pointer;
  transition: transform .12s, background .15s, box-shadow .15s, border-color .15s;
  text-align: left
}

.btn:active {
  transform: scale(.97)
}

.btn-red {
  background: linear-gradient(135deg, #EC2A30, #D0141A);
  color: #fff;
  box-shadow: 0 10px 26px -10px rgba(224, 27, 34, .6)
}

.btn-red:hover {
  box-shadow: 0 14px 30px -10px rgba(224, 27, 34, .75)
}

.btn-ghost {
  background: var(--white);
  border: 1.5px solid var(--line-strong);
  color: var(--ink)
}

.btn-ghost:hover {
  border-color: var(--red);
  color: var(--red)
}

.btn-lg {
  padding: 14px 26px;
  font-size: 15.5px
}

.hamburger {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  background: var(--white);
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  color: var(--ink);
  flex-shrink: 0
}

/* pages */
.page {
  display: none;
  animation: fade .45s ease
}

.page.show {
  display: block
}

@keyframes fade {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

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

section {
  padding: 88px 0
}

.tight {
  padding: 64px 0
}

/* hero */
.hero {
  position: relative;
  overflow: hidden;
  padding: 108px 0 128px;
  min-height: 88vh;
  display: flex;
  align-items: center;
  background: linear-gradient(180deg, #E6EFF4 0%, var(--cream) 100%)
}

.hero .scene-scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block
}

@media(min-width:901px) {
  .hero .scene-photo~.scene-scrim {
    background: linear-gradient(90deg, rgba(253, 251, 248, 0.85) 0%, rgba(253, 251, 248, 0.5) 45%, rgba(253, 251, 248, 0) 80%)
  }
}

.hero .wrap {
  position: relative;
  z-index: 2;
  width: 100%
}

.hero-loc {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--red);
  background: rgba(255, 255, 255, .72);
  border: 1px solid var(--line);
  padding: 8px 15px;
  border-radius: 30px;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  margin-bottom: 22px;
  box-shadow: 0 8px 20px -14px rgba(60, 40, 30, .45)
}

.hero-loc .ti {
  font-size: 16px
}

.hero h1 {
  font-size: clamp(42px, 6.4vw, 78px);
  max-width: 35ch;
  font-weight: 500;
  letter-spacing: -0.022em;
  line-height: 1.06;
}

.hero h1 em {
  font-style: normal;
  color: var(--red);
  font-weight: 500
}

.hero .sub {
  margin-top: 24px;
  font-size: clamp(16px, 1.5vw, 20px);
  color: var(--ink);
  font-weight: 500;
  max-width: 50ch;
  line-height: 1.62;
}

.hero .cta-row {
  margin-top: 36px;
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap
}

.hero .txtlink {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--soft-ink);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  border-bottom: 1.5px solid transparent;
  transition: border-color .15s, color .15s;
  padding-bottom: 2px
}

.hero .txtlink:hover {
  color: var(--red);
  border-color: var(--red)
}

/* reveal */
.rv {
  opacity: 0;
  transform: translateY(16px);
  will-change: transform, opacity
}

.show .rv {
  animation: rvIn .8s cubic-bezier(.2, .8, .2, 1) forwards
}

.show .rv.d1 {
  animation-delay: .05s
}

.show .rv.d2 {
  animation-delay: .18s
}

.show .rv.d3 {
  animation-delay: .31s
}

.show .rv.d4 {
  animation-delay: .44s
}

@keyframes rvIn {
  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* trust highlights */
.trust3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 56px
}

.tcard {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: 0 14px 38px -30px rgba(60, 40, 30, .5);
  transition: transform .2s, box-shadow .2s
}

.tcard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow)
}

.tcard .band {
  aspect-ratio: 16/9
}

.tcard .pad {
  padding: 20px 22px 24px
}

.tcard .ic {
  width: 42px;
  height: 42px;
  border-radius: 11px;
  background: var(--blush);
  color: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 21px;
  margin-bottom: 12px
}

.tcard h3 {
  font-size: 17.5px;
  margin-bottom: 6px;
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: 0
}

.tcard p {
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.55
}

/* fork */
.fork-sec {
  background: var(--cream)
}

.fork {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 46px
}

.door {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  overflow: hidden;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  position: relative;
  box-shadow: 0 14px 40px -30px rgba(60, 40, 30, .5)
}

.door .banner {
  aspect-ratio: 16/7
}

.door:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow)
}

.door .pad {
  padding: 30px 32px 32px;
  position: relative
}

.door .ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--blush);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  font-size: 25px;
  margin: -58px 0 16px;
  position: relative;
  border: 4px solid var(--white)
}

.door .flag {
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--faint)
}

.door h3 {
  font-size: 26px;
  margin: 8px 0 12px
}

.door p {
  color: var(--muted);
  font-size: 15px;
  margin-bottom: 22px;
  line-height: 1.6
}

.door .go {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--red);
  font-weight: 600;
  font-size: 15px
}

.door:hover .go .ti {
  transform: translateX(5px)
}

.door .go .ti {
  transition: transform .2s
}

/* section heads */
.shead {
  max-width: 960px
}

.shead h2 {
  font-size: clamp(28px, 3.5vw, 44px);
  margin: 12px 0 0
}

.shead p {
  margin-top: 15px;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.6;
  max-width: 65ch
}

.shead.center p {
  margin-left: auto;
  margin-right: auto
}

.center {
  margin-left: auto;
  margin-right: auto;
  text-align: center
}

/* differentiators */
.diff {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 48px
}

.dcard {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 12px 36px -32px rgba(60, 40, 30, .5)
}

.dcard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow)
}

.dcard .band {
  aspect-ratio: 3/2
}

.dcard .pad {
  padding: 24px 26px 28px;
  position: relative
}

.dcard .n {
  font-family: var(--serif);
  font-size: 14px;
  color: var(--red);
  font-weight: 600
}

.dcard .ico {
  font-size: 26px;
  color: var(--ink);
  margin: 4px 0 12px
}

.dcard h3 {
  font-size: 20px;
  margin-bottom: 9px
}

.dcard p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6
}

.diff-2 {
  grid-template-columns: repeat(2, 1fr);
  margin-top: 22px
}

/* promise */
.promise {
  display: grid;
  grid-template-columns: 1.25fr .92fr;
  gap: 42px;
  align-items: center;
  background: linear-gradient(135deg, var(--cream), var(--cream-2));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 48px;
  position: relative;
  overflow: hidden
}

.promise::before {
  content: "";
  position: absolute;
  top: -30%;
  right: -8%;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(224, 27, 34, .08), transparent 62%)
}

.promise .inner {
  position: relative;
  z-index: 2
}

.promise h2 {
  font-size: clamp(26px, 3vw, 38px)
}

.promise .lead {
  color: var(--muted);
  margin-top: 14px;
  max-width: 50ch;
  font-size: 16px
}

.evgrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 30px
}

.ev {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 13px;
  padding: 16px 16px;
  transition: transform .18s, box-shadow .18s
}

.ev:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow)
}

.ev .ti {
  font-size: 23px;
  color: var(--red);
  margin-bottom: 8px;
  display: block
}

.ev b {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 2px
}

.ev span {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.4
}

.promise-img {
  aspect-ratio: 3/4;
  position: relative;
  z-index: 2
}

/* clinics */
.clinics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 44px
}

.clinic {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .2s, box-shadow .2s;
  cursor: pointer
}

.clinic:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow)
}

.clinic .band {
  aspect-ratio: 4/3
}

.clinic .body {
  padding: 20px 22px 22px
}

.clinic h3 {
  font-size: 19px;
  margin-bottom: 3px
}

.clinic .loc {
  font-size: 13px;
  color: var(--faint);
  margin-bottom: 13px;
  display: flex;
  align-items: center;
  gap: 6px
}

.clinic .foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px
}

.clinic .tg {
  font-size: 11.5px;
  background: var(--cream);
  color: var(--muted);
  padding: 5px 10px;
  border-radius: 7px;
  font-weight: 600
}

.clinic .vc {
  font-size: 13px;
  font-weight: 600;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 5px
}

.clinic:hover .vc .ti {
  transform: translateX(4px)
}

.clinic .vc .ti {
  transition: transform .2s
}

.clinic.more {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: linear-gradient(135deg, var(--cream), var(--cream-2));
  border-style: dashed
}

.clinic.more .inner {
  padding: 30px
}

.clinic.more .ti {
  font-size: 30px;
  color: var(--red);
  margin-bottom: 10px
}

.clinic.more h3 {
  margin-bottom: 6px
}

.clinic.more p {
  font-size: 13.5px;
  color: var(--muted)
}

/* news */
.news {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 42px
}

.ncard {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s
}

.ncard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow)
}

.ncard .band {
  aspect-ratio: 16/9
}

.ncard .body {
  padding: 20px 22px 22px
}

.ncard .meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--faint);
  margin-bottom: 11px
}

.ncard .pill {
  background: var(--blush);
  color: var(--red-dark);
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 6px;
  font-size: 11.5px
}

.ncard h3 {
  font-size: 18px;
  line-height: 1.25;
  margin-bottom: 8px
}

.ncard p {
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.55
}

.ncard .rd {
  margin-top: 14px;
  color: var(--red);
  font-weight: 600;
  font-size: 13.5px;
  display: inline-flex;
  align-items: center;
  gap: 6px
}

/* closing */
.closing {
  position: relative;
  overflow: hidden;
  text-align: center;
  background: linear-gradient(135deg, var(--blush), var(--cream))
}

.closing.scene-bg .scene-scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(250, 244, 238, .67), rgba(251, 234, 232, .75))
}

.closing .wrap {
  position: relative;
  z-index: 2
}

.closing h2 {
  font-size: clamp(30px, 4vw, 48px);
  max-width: 800px;
  margin: 0 auto
}

.closing p {
  color: var(--muted);
  margin: 18px auto 30px;
  max-width: 52ch;
  font-size: 17px
}

/* testimonials */
.testi {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 24px;
  margin-top: 44px;
  align-items: stretch
}

.testi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 44px;
  align-items: stretch
}

.videoph {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: linear-gradient(135deg, #C9DBE7, #9FBFD4);
  min-height: 300px;
  display: flex;
  align-items: flex-end
}

.videoph::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 42%, rgba(255, 255, 255, .45), transparent 55%)
}

.videoph .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 74px;
  height: 74px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .9);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  font-size: 30px;
  z-index: 2;
  box-shadow: 0 14px 36px -14px rgba(60, 40, 30, .5);
  transition: transform .2s
}

.videoph:hover .play {
  transform: translate(-50%, -50%) scale(1.08)
}

.videoph .vcap {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 10px;
  padding: 14px 16px;
  background: linear-gradient(180deg, transparent, rgba(25, 18, 14, .4))
}

.videoph .imgph-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0, 0, 0, .35)
}

.videoph .imgph-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(255, 255, 255, .2);
  padding: 4px 8px;
  border-radius: 6px
}

.tquotes {
  display: grid;
  gap: 18px
}

.tquote {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: 0 12px 36px -32px rgba(60, 40, 30, .5);
  transition: transform 0.3s ease, box-shadow 0.3s ease
}

.tquote:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px -28px rgba(60, 40, 30, .7)
}

.tquote .q {
  font-size: 26px;
  color: var(--red);
  opacity: .5
}

.tquote p {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.5;
  color: var(--ink);
  margin: 8px 0 16px
}

.tquote .who {
  display: flex;
  align-items: center;
  gap: 12px
}

.tquote .av {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cream-2);
  color: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0
}

.tquote .who b {
  display: block;
  font-size: 14px;
  color: var(--ink)
}

.tquote .who span {
  font-size: 12.5px;
  color: var(--muted)
}

/* governing bodies */
.govwrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
  align-items: center;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 36px 40px;
  box-shadow: 0 14px 40px -34px rgba(60, 40, 30, .5)
}

.govtxt h3 {
  font-size: 23px;
  margin: 10px 0 10px
}

.govtxt p {
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.6
}

.gov {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px
}

.govlogo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 20px 12px;
  text-align: center;
  min-height: 96px
}

.govlogo .ti {
  font-size: 26px;
  color: var(--red)
}

.govlogo span {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--soft-ink);
  letter-spacing: .02em
}

/* fears prompt */
.fearbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  background: linear-gradient(135deg, var(--blush), var(--cream));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 36px 40px;
  flex-wrap: wrap
}

.fearbar h3 {
  font-size: 24px;
  margin: 8px 0 8px
}

.fearbar p {
  color: var(--muted);
  font-size: 15px;
  margin-bottom: 16px;
  max-width: 54ch
}

.qchips {
  display: flex;
  flex-wrap: wrap;
  gap: 9px
}

.qchips span {
  font-size: 13px;
  font-weight: 500;
  color: var(--soft-ink);
  background: rgba(255, 255, 255, .75);
  border: 1px solid var(--line);
  padding: 8px 14px;
  border-radius: 30px
}

/* team faces (closing) */
.facerow {
  display: flex;
  justify-content: center;
  gap: 34px;
  flex-wrap: wrap;
  margin: 18px 0 26px
}

.face {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px
}

.face .fav {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .85);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  font-size: 28px;
  box-shadow: 0 10px 26px -16px rgba(60, 40, 30, .5)
}

.face b {
  font-size: 15px;
  color: var(--ink)
}

.face span {
  font-size: 12px;
  color: var(--muted)
}

.clinic .bio {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
  margin-top: 6px
}

/* footer */
footer {
  background: var(--cream-2);
  border-top: 1px solid var(--line);
  padding: 56px 0 30px;
  color: var(--muted)
}

.fgrid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 30px;
  margin-bottom: 40px
}

footer h4 {
  font-family: var(--sans);
  color: var(--ink);
  font-size: 12.5px;
  letter-spacing: .09em;
  text-transform: uppercase;
  margin-bottom: 16px;
  font-weight: 700
}

footer a {
  display: block;
  color: var(--muted);
  font-size: 14px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: color .14s
}

footer a:hover {
  color: var(--red)
}

footer .blurb {
  font-size: 14px;
  color: var(--muted);
  max-width: 34ch;
  margin-top: 14px;
  line-height: 1.6
}

.fbar {
  border-top: 1px solid var(--line-strong);
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 12.5px;
  color: var(--faint)
}

/* subnav */
.subnav {
  position: sticky;
  top: 74px;
  z-index: 40;
  background: rgba(253, 251, 248, .77);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line)
}

.subnav .row {
  display: flex;
  gap: 6px;
  height: 56px;
  align-items: center;
  overflow-x: auto
}

.subnav a {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
  white-space: nowrap;
  transition: background .14s, color .14s
}

.subnav a:hover {
  background: var(--cream);
  color: var(--red)
}

.subnav a.active {
  background: var(--cream);
  color: var(--red);
  border-color: var(--red)
}

/* landing hero */
.lhero {
  position: relative;
  overflow: hidden;
  padding: 88px 0 72px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  min-height: 50vh
}

.lhero .scene-scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(95deg, rgba(253, 251, 248, .86) 0%, rgba(253, 251, 248, .72) 45%, rgba(253, 251, 248, .25) 70%, rgba(253, 251, 248, .00) 90%), linear-gradient(180deg, rgba(253, 251, 248, .15) 0%, rgba(253, 251, 248, 0) 26%, rgba(253, 251, 248, 0) 68%, rgba(250, 244, 238, .35) 100%)
}

.lhero .wrap {
  position: relative;
  z-index: 2
}

.lhero .eyebrow {
  margin-bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(255, 255, 255, .7);
  border: 1px solid var(--line);
  padding: 7px 14px;
  border-radius: 30px
}

.lhero h1 {
  font-size: clamp(34px, 5vw, 60px);
  max-width: 800px;
  text-shadow: 0 1px 4px rgba(253, 251, 248, 0.9), 0 0 12px rgba(253, 251, 248, 0.6)
}

.lhero h1 em {
  color: var(--red);
  font-style: italic;
  font-weight: 400
}

.lhero p {
  margin-top: 20px;
  font-size: 18px;
  color: var(--ink);
  font-weight: 500;
  max-width: 56ch;
  line-height: 1.6;
  text-shadow: 0 1px 4px rgba(253, 251, 248, 0.95), 0 0 8px rgba(253, 251, 248, 0.6)
}

.lhero .cta-row {
  margin-top: 30px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap
}

/* steps */
.steps {
  margin-top: 46px;
  display: grid;
  gap: 18px
}

.step {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 22px;
  align-items: start;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 26px 30px;
  box-shadow: 0 12px 36px -30px rgba(60, 40, 30, .5)
}

.step .num {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-family: var(--serif);
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center
}

.step h3 {
  font-size: 21px;
  margin-bottom: 8px
}

.step p {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6
}

.step .who {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--red-dark);
  background: var(--blush);
  padding: 5px 11px;
  border-radius: 7px
}

.step.has-img {
  grid-template-columns: 48px 1fr 230px
}

.step .step-thumb {
  border-radius: var(--r);
  overflow: hidden;
  align-self: stretch;
  min-height: 140px
}

/* mentor / human callout */
.callout {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  background: linear-gradient(135deg, var(--blush), var(--cream));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 26px 30px;
  margin-top: 30px
}

.callout .ic {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px
}

.callout h3 {
  font-size: 20px;
  margin-bottom: 8px
}

.callout p {
  color: var(--soft-ink);
  font-size: 15px;
  line-height: 1.65
}

.cta-contact {
  margin-top: 24px;
  display: flex;
  justify-content: center;
  gap: 26px;
  flex-wrap: wrap;
  position: relative;
  z-index: 2
}

.cta-contact a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink)
}

.cta-contact a .ti {
  color: var(--red);
  font-size: 18px
}

/* split */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: center
}

.split.rev .col-txt {
  order: 2
}

.split h2 {
  font-size: clamp(26px, 3vw, 38px);
  margin-bottom: 14px
}

.split p {
  color: var(--muted);
  font-size: 16px;
  margin-bottom: 14px;
  line-height: 1.6
}

.split .col-img {
  aspect-ratio: 5/4
}

.checks {
  list-style: none;
  margin-top: 16px;
  display: grid;
  gap: 11px
}

.checks li {
  display: flex;
  gap: 11px;
  font-size: 15px;
  color: var(--ink)
}

.checks .ti {
  color: var(--red);
  font-size: 20px;
  margin-top: 1px
}

/* stats */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 44px
}

.stat {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 26px;
  text-align: center
}

.stat .big {
  font-family: var(--serif);
  font-size: 38px;
  color: var(--red);
  line-height: 1;
  font-weight: 600
}

.stat .lab {
  margin-top: 9px;
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.4
}

.stats .stat {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .55s ease, transform .35s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform, opacity
}

.stats .stat.in {
  opacity: 1;
  transform: none
}

.stats .stat.in:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 44px -28px rgba(60, 40, 30, .5);
  border-color: var(--blush)
}

.note {
  margin-top: 18px;
  font-size: 12.5px;
  color: var(--faint);
  text-align: center
}

/* compare */
.compare {
  margin-top: 42px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: 0 16px 44px -34px rgba(60, 40, 30, .5)
}

.compare .crow {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  border-bottom: 1px solid var(--line)
}

.compare .crow:last-child {
  border-bottom: none
}

.compare .crow>div {
  padding: 16px 20px;
  font-size: 14.5px
}

.compare .chead>div {
  font-weight: 700;
  background: var(--cream);
  font-size: 12.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted)
}

.compare .chead .us {
  background: var(--red);
  color: #fff
}

.compare .feat {
  color: var(--ink);
  font-weight: 600
}

.compare .us {
  background: #FFF6F5
}

.compare .us .ti {
  color: var(--red)
}

.compare .them {
  color: var(--faint)
}

.compare .them .ti {
  color: #cfc7bb
}

/* faq */
.faq {
  margin-top: 40px;
  display: grid;
  gap: 12px;
  max-width: 820px
}

.q {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden
}

.q summary {
  cursor: pointer;
  padding: 18px 22px;
  font-weight: 600;
  font-size: 16px;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px
}

.q summary::-webkit-details-marker {
  display: none
}

.q summary .ti {
  color: var(--red);
  transition: transform .2s;
  font-size: 20px
}

.q[open] summary .ti {
  transform: rotate(45deg)
}

.q .ans {
  padding: 0 22px 20px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6
}

/* about values */
.vals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 44px
}

.val {
  padding: 28px;
  border-left: 3px solid var(--red);
  background: var(--white);
  border-radius: 0 var(--r) var(--r) 0;
  box-shadow: 0 12px 36px -32px rgba(60, 40, 30, .5)
}

.val .ti {
  font-size: 28px;
  color: var(--red);
  margin-bottom: 12px
}

.val h3 {
  font-size: 19px;
  margin-bottom: 8px
}

.val p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.6
}

/* contact */
.contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px
}

.field {
  margin-bottom: 16px
}

.field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 6px
}

.field input,
.field select,
.field textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  font-family: var(--sans);
  font-size: 14.5px;
  background: var(--white);
  color: var(--ink)
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--red);
  box-shadow: 0 0 0 3px var(--red-tint)
}

.cinfo {
  background: linear-gradient(135deg, var(--cream), var(--cream-2));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 30px;
  margin-bottom: 20px
}

.cinfo h3 {
  font-size: 24px;
  margin-bottom: 8px
}

.cinfo p {
  color: var(--muted);
  font-size: 15px;
  margin-bottom: 24px
}

.cinfo .ln {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 20px
}

.cinfo .ln .ti {
  color: var(--red);
  font-size: 22px
}

.cinfo .ln .lbl {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--faint);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
  line-height: 1.2
}

.cinfo .ln b {
  display: block;
  color: var(--ink);
  font-size: 14.5px
}

.cinfo .ln span {
  font-size: 13.5px;
  color: var(--muted)
}

.cinfo a.ln {
  text-decoration: none;
  transition: transform .18s ease
}

.cinfo a.ln:hover {
  transform: translateX(3px)
}

.cinfo a.ln:hover b {
  color: var(--red)
}

.fcontact {
  margin-top: 18px
}

.fcontact a {
  display: flex;
  align-items: center;
  gap: 9px;
  color: var(--ink);
  font-size: 14px;
  margin-bottom: 9px;
  font-weight: 500
}

.fcontact a .ti {
  color: var(--red);
  font-size: 17px
}

.fcontact a:hover {
  color: var(--red)
}

.cnote {
  margin-top: 6px;
  font-size: 13px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 7px
}

.cnote .ti {
  color: var(--red);
  font-size: 16px
}

/* resources */
.rlist {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px
}

.rcat {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 30px 0 36px
}

.rcat span {
  font-size: 13px;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 30px;
  border: 1px solid var(--line-strong);
  cursor: pointer;
  transition: all .15s
}

.rcat span.on,
.rcat span:hover {
  background: var(--red);
  color: #fff;
  border-color: var(--red)
}

.signup {
  margin-top: 60px;
  background: linear-gradient(135deg, var(--blush), var(--cream));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 50px;
  text-align: center
}

.signup h2 {
  font-size: 30px;
  margin-bottom: 10px
}

.signup p {
  color: var(--muted);
  max-width: 50ch;
  margin: 0 auto 24px
}

.signup .row {
  display: flex;
  gap: 12px;
  max-width: 480px;
  margin: 0 auto;
  flex-wrap: wrap
}

.signup input {
  flex: 1;
  min-width: 200px;
  padding: 13px 16px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  font-family: var(--sans);
  font-size: 15px;
  background: #fff
}

/* modal */
.modal-bg {
  position: fixed;
  inset: 0;
  background: rgba(60, 40, 30, .35);
  backdrop-filter: blur(5px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s, visibility .3s
}

.modal-bg.show {
  opacity: 1;
  visibility: visible
}

.modal {
  background: var(--paper);
  border-radius: var(--r-xl);
  max-width: 560px;
  width: 100%;
  overflow: hidden;
  transform: none;
  transition: opacity .2s ease;
  position: relative;
  box-shadow: 0 40px 90px -40px rgba(60, 40, 30, .55);
  border: 1px solid var(--line)
}

.modal-bg.show .modal {
  transform: none
}

.modal .head {
  padding: 36px 40px 30px;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  background: var(--cream);
}

.modal .head::before {
  content: "";
  position: absolute;
  inset: -10%;
  z-index: 0;
  background-image:
    linear-gradient(95deg,
      rgba(253, 251, 248, 0.95) 0%,
      rgba(253, 251, 248, 0.91) 40%,
      rgba(253, 251, 248, 0.80) 70%,
      rgba(253, 251, 248, 0.68) 100%),
    url('assets/hero-slider/slide3.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  animation: modalKenBurns 28s ease-in-out infinite alternate;
  will-change: transform;
  pointer-events: none;
}

.modal .head::after {
  content: "";
  position: absolute;
  top: -40%;
  right: -5%;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(224, 27, 34, 0.12), transparent 60%);
  z-index: 1;
  pointer-events: none;
}

@keyframes modalKenBurns {
  0% {
    transform: scale(1.02) translate(0, 0);
  }

  100% {
    transform: scale(1.10) translate(-1.2%, -0.8%);
  }
}

.modal .head .eyebrow {
  position: relative;
  z-index: 2;
}

.modal .head h2 {
  font-size: 28px;
  margin-top: 10px;
  position: relative;
  z-index: 2;
  max-width: 100%;
}

.modal .head p {
  color: var(--muted);
  margin-top: 10px;
  font-size: 14.5px;
  position: relative;
  z-index: 2;
  max-width: 44ch;
}

.modal .body {
  padding: 30px 40px 36px
}

.modal .body {
  position: relative;
  z-index: 1
}

.modal .body .row {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
  flex-wrap: wrap
}

.modal .body input:not([type="radio"]) {
  flex: 1;
  min-width: 180px;
  padding: 13px 15px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  font-family: var(--sans);
  font-size: 14.5px;
  background: #fff
}

.modal .body input:not([type="radio"]):focus {
  outline: none;
  border-color: var(--red);
  box-shadow: 0 0 0 3px var(--red-tint)
}

.newsletter-options {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 16px 24px;
}

.newsletter-options label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  cursor: pointer;
  user-select: none;
  font-weight: 500;
}

.newsletter-options input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid var(--line-strong);
  border-radius: 50%;
  outline: none;
  margin: 0 !important;
  padding: 0 !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: border-color 0.2s, background-color 0.2s;
  background-color: #fff !important;
  flex-shrink: 0;
  box-shadow: none !important;
  flex: none !important;
  min-width: 0 !important;
}

.newsletter-options input[type="radio"]:checked {
  border-color: var(--red) !important;
  background-color: #fff !important;
}

.newsletter-options input[type="radio"]:checked::after {
  content: "";
  width: 10px;
  height: 10px;
  background-color: var(--red);
  border-radius: 50%;
  display: block;
}

.newsletter-options label:hover input[type="radio"] {
  border-color: var(--red) !important;
}

.modal .or {
  text-align: center;
  font-size: 13px;
  color: var(--faint);
  margin: 16px 0
}

.modal .fine {
  margin-top: 16px;
  font-size: 12px;
  color: var(--faint);
  text-align: center
}

.modal .close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--red);
  border: none;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, transform .15s;
  box-shadow: 0 6px 16px -6px rgba(224, 27, 34, .65)
}

.modal .close:hover {
  background: var(--red-dark);
  transform: scale(1.06)
}

.modal-newsletter-container {
  overflow: visible;
  position: relative;
  z-index: 10;
  pointer-events: auto
}

.modal-newsletter-container iframe {
  display: block;
  position: relative;
  z-index: 11;
  pointer-events: auto;
  -webkit-overflow-scrolling: touch;
  min-height: 260px
}

.modal .body.modal-newsletter-container * {
  pointer-events: auto
}

.modal .head::before {
  pointer-events: none
}

.modal-bg.show {
  pointer-events: auto
}

.modal-bg.show,
.modal-bg.show *,
.modal-bg.show iframe {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important
}

.modal-bg.show .modal {
  pointer-events: auto
}

.modal-bg.show .modal .body {
  pointer-events: auto
}

.toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--ink);
  color: #fff;
  padding: 13px 22px;
  border-radius: 10px;
  font-size: 14px;
  z-index: 300;
  opacity: 0;
  transition: all .3s;
  pointer-events: none
}

.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0)
}

/* splash */
.no-splash #splash {
  display: none !important
}

.no-splash .site {
  opacity: 1 !important;
  transition: none !important
}

#splash {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: radial-gradient(circle at 22% 28%, rgba(224, 27, 34, .1), transparent 40%), radial-gradient(circle at 80% 72%, rgba(251, 180, 170, .22), transparent 42%), linear-gradient(135deg, #FFFFFF 0%, #FBF4EF 55%, #F7EBE6 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: opacity .9s ease, transform 1s cubic-bezier(.7, 0, .3, 1)
}

#splash.gone {
  opacity: 0;
  transform: translateY(-40px);
  pointer-events: none
}

.splash-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(46px);
  opacity: .5
}

.b1 {
  width: 340px;
  height: 340px;
  background: rgba(224, 27, 34, .12);
  top: -60px;
  left: -60px;
  animation: floatb 9s ease-in-out infinite
}

.b2 {
  width: 300px;
  height: 300px;
  background: rgba(255, 170, 160, .28);
  bottom: -50px;
  right: -40px;
  animation: floatb 11s ease-in-out infinite reverse
}

@keyframes floatb {

  0%,
  100% {
    transform: translate(0, 0)
  }

  50% {
    transform: translate(26px, -22px)
  }
}

.splash-ring {
  position: absolute;
  border: 1px solid rgba(224, 27, 34, .12);
  border-radius: 50%
}

.splash-ring.r1 {
  width: 440px;
  height: 440px;
  animation: pulse 6s ease-in-out infinite
}

.splash-ring.r2 {
  width: 620px;
  height: 620px;
  animation: pulse 6s ease-in-out infinite .6s
}

@keyframes pulse {

  0%,
  100% {
    transform: scale(1);
    opacity: .5
  }

  50% {
    transform: scale(1.05);
    opacity: .2
  }
}

.splash-logo {
  position: relative;
  z-index: 2;
  width: min(420px, 72vw);
  opacity: 0;
  transform: scale(.92) translateY(8px);
  animation: logoIn 1.1s cubic-bezier(.2, .8, .2, 1) .15s forwards
}

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

.splash-tag {
  position: relative;
  z-index: 2;
  margin-top: 26px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(17px, 2.2vw, 23px);
  color: var(--soft-ink);
  opacity: 0;
  animation: tagIn 1s ease 1s forwards
}

.splash-tag b {
  color: var(--red);
  font-style: normal;
  font-weight: 500
}

@keyframes tagIn {
  to {
    opacity: 1
  }
}

.splash-line {
  position: relative;
  z-index: 2;
  width: 0;
  height: 2px;
  background: var(--red);
  margin-top: 26px;
  border-radius: 2px;
  animation: lineIn 1.4s ease 1.2s forwards
}

@keyframes lineIn {
  to {
    width: 120px
  }
}

.site {
  opacity: 0;
  transition: opacity .9s ease .15s
}

.site.in {
  opacity: 1
}


/* Mobile footer & form fixes */
footer a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, .1);
  touch-action: manipulation
}

.fgrid a,
.mnav-links a,
.fcontact a {
  position: relative;
  z-index: 2
}

.contact iframe {
  position: relative;
  z-index: 10;
  pointer-events: auto;
  -webkit-overflow-scrolling: touch
}

.contact {
  position: relative;
  z-index: 1
}

@media(max-width:900px) {
  .fgrid {
    gap: 20px;
    padding-bottom: 20px
  }

  .fgrid a {
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 4px 0
  }

  .fbar {
    flex-direction: column;
    text-align: center;
    gap: 6px
  }

  .contact iframe {
    min-height: 600px !important
  }
}

/* mobile nav drawer */
body.menu-open {
  overflow: hidden
}

.mnav-bg {
  position: fixed;
  inset: 0;
  background: rgba(38, 34, 31, .56);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s ease, visibility .25s ease;
  z-index: 200
}

.mnav-bg.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto
}

.mnav {
  position: fixed;
  top: 0;
  right: 0;
  height: 100dvh;
  width: min(88vw, 380px);
  background: var(--paper);
  z-index: 201;
  transform: translateX(105%);
  transition: transform .28s cubic-bezier(.2, .8, .2, 1);
  display: flex;
  flex-direction: column;
  padding: 18px 22px 26px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: -30px 0 70px -40px rgba(60, 40, 30, .6);
  border-left: 1px solid var(--line)
}

.mnav.show {
  transform: translateX(0)
}

.mnav-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line)
}

.mnav-logo {
  height: 30px;
  width: auto;
  max-width: 190px
}

.mnav-x {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--red);
  border: none;
  color: #fff;
  font-size: 21px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex: none
}

.mnav-links {
  display: flex;
  flex-direction: column;
  gap: 2px
}

.mnav-links a {
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 10px 6px;
  font-size: 16px;
  color: var(--ink);
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  font-weight: 600
}

.mnav-links a:active {
  color: var(--red)
}

.mnav-group {
  font-size: 11px;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--red);
  font-weight: 700;
  padding: 17px 6px 4px
}

.mnav-cta {
  width: 100%;
  justify-content: center;
  margin-top: 20px;
  min-height: 48px;
  text-align: center
}

.mnav-contact {
  display: flex;
  gap: 10px;
  margin-top: 13px
}

.mnav-contact a {
  flex: 1;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 10px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
  text-decoration: none
}

.mnav-contact a .ti {
  color: var(--red)
}

.mnav-x:focus-visible,
.mnav-links a:focus-visible,
.mnav-contact a:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 3px
}

@media(max-width:420px) {
  .mnav {
    width: 100vw;
    border-left: 0
  }

  .mnav-contact {
    flex-direction: column
  }
}

/* pathway router */
.router {
  background: linear-gradient(135deg, var(--blush), var(--cream));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 38px 34px;
  text-align: center;
  position: relative;
  overflow: hidden
}

.router h2 {
  font-size: 26px
}

.router .rq {
  color: var(--muted);
  max-width: 46ch;
  margin: 8px auto 22px
}

.router .ropts {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  max-width: 700px;
  margin: 0 auto
}

.router .ropt {
  background: #fff;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 11px 18px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  transition: border-color .16s, color .16s, transform .16s;
  font-family: var(--sans)
}

.router .ropt:hover {
  border-color: var(--red);
  color: var(--red);
  transform: translateY(-2px)
}

.router .rresult {
  margin: 22px auto 0;
  max-width: 560px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  text-align: left;
  display: none
}

.router .rresult.show {
  display: block;
  animation: fadeUp .4s ease
}

.router .rresult h3 {
  font-size: 18px;
  margin-bottom: 6px
}

.router .rresult p {
  color: var(--muted);
  font-size: 14.5px;
  margin-bottom: 16px
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

  to {
    opacity: 1;
    transform: none
  }
}

/* specialties */
.specwrap {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 24px;
  align-items: start
}

.speclead {
  display: flex;
  flex-direction: column;
  gap: 16px
}

.specbox {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px 24px
}

.specbox.lead {
  background: linear-gradient(135deg, var(--blush), var(--cream))
}

.specbox h3 {
  font-size: 17px;
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 6px
}

.specbox h3 .ti {
  color: var(--red);
  font-size: 21px
}

.specbox p {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 12px
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px
}

.chip {
  background: #fff;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink)
}

.chip.soft {
  background: transparent;
  color: var(--muted);
  font-weight: 500
}

/* timeline */
.tl {
  position: relative;
  margin-top: 26px
}

.tl .titem {
  position: relative;
  padding: 0 0 26px 34px;
  border-left: 2px solid var(--line-strong)
}

.tl .titem:last-child {
  border-left-color: transparent;
  padding-bottom: 0
}

.tl .tdot {
  position: absolute;
  left: -9px;
  top: 1px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--red);
  border: 3px solid var(--paper)
}

.tl .twhen {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--red)
}

.tl .tt {
  font-size: 16px;
  margin: 3px 0 4px;
  font-weight: 600;
  color: var(--ink)
}

.tl .td {
  font-size: 14px;
  color: var(--muted);
  max-width: 62ch
}

/* demand callout */
.demand {
  display: flex;
  gap: 24px;
  align-items: center;
  background: linear-gradient(135deg, var(--blush), var(--cream));
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 30px 34px;
  flex-wrap: wrap
}

.demand .dnum {
  font-family: var(--serif);
  font-size: 54px;
  color: var(--red);
  line-height: 1;
  font-weight: 600
}

.demand .dtx {
  flex: 1;
  min-width: 240px
}

.demand .dtx h3 {
  font-size: 20px;
  margin-bottom: 6px
}

.demand .dtx p {
  color: var(--muted);
  font-size: 14.5px
}

.demand .dtx .src {
  font-size: 11.5px;
  color: var(--faint);
  margin-top: 8px
}

@media(max-width:900px) {
  .menu {
    display: none
  }

  .hamburger {
    display: flex
  }

  .subnav .row {
    height: 58px;
    gap: 8px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch
  }

  .subnav .row::-webkit-scrollbar {
    display: none
  }

  .subnav a {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    min-height: 38px;
    padding: 8px 13px;
    background: var(--white);
    border: 1px solid var(--line);
    box-shadow: 0 8px 18px -16px rgba(60, 40, 30, .35)
  }

  .specwrap {
    grid-template-columns: 1fr !important
  }

  .demand {
    flex-direction: column;
    text-align: center
  }

  .trust3,
  .fork,
  .diff,
  .diff-2,
  .news,
  .clinics,
  .split,
  .vals,
  .contact,
  .rlist,
  .fgrid,
  .compare .crow,
  .promise,
  .evgrid,
  .testi,
  .testi-grid,
  .govwrap {
    grid-template-columns: 1fr !important
  }

  .gov {
    grid-template-columns: 1fr 1fr !important
  }

  .step.has-img {
    grid-template-columns: 48px 1fr !important
  }

  .step .step-thumb {
    display: none
  }

  .callout {
    flex-direction: column;
    gap: 14px
  }

  .stats {
    grid-template-columns: 1fr 1fr !important
  }

  .split.rev .col-txt {
    order: 0
  }

  .hero {
    min-height: auto;
    padding: 72px 0 84px
  }

  .hero .scene-photo~.scene-scrim {
    background: none
  }

  .lhero .scene-scrim {
    background: linear-gradient(180deg, rgba(253, 251, 248, .75), rgba(253, 251, 248, .45))
  }

  .promise {
    padding: 30px 22px
  }

  section {
    padding: 60px 0
  }

  .updates .txt {
    display: none
  }

  .signup {
    padding: 36px 20px !important;
  }

  .fearbar {
    padding: 24px 20px !important;
  }
}

@media(max-width: 600px) {
  .modal .head {
    padding: 28px 24px 20px !important;
  }

  .modal .head h2 {
    font-size: 22px !important;
  }

  #bookingModal .modal {
    height: 100% !important;
    max-height: 100% !important;
    border-radius: 0 !important;
  }
}

.scene-photo {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat
}

.scene-photo~.scene-scrim {
  background: linear-gradient(180deg, rgba(253, 251, 248, .45) 0%, rgba(253, 251, 248, .20) 45%, rgba(253, 251, 248, .45) 100%)
}

.imgph .phimg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1)
}

.imgph:hover .phimg {
  transform: scale(1.06)
}

.imgph:has(.phimg) .imgph-ic {
  display: none
}

.imgph:has(.phimg) .imgph-cap {
  display: none
}

.imgph:has(.phimg)::after {
  display: none !important
}

.scene:has(.bgvideo),
.scene:has(.hero-slider) {
  animation: none;
  inset: 0
}

.bgvideo,
.hero-slider {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0
}

.bgvideo iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120vw;
  height: 67.5vw;
  min-height: 120%;
  min-width: 213.34vh;
  transform: translate(-50%, -50%);
  border: 0;
  pointer-events: none
}

.bgvideo video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none
}

.hero-slider .slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1.5s ease-in-out, transform 5.5s linear;
  transform: scale(1.0);
  z-index: 0
}

.hero-slider .slide.active {
  opacity: 1;
  z-index: 2;
  transform: scale(1.06)
}

.hero-slider .slide.previous {
  opacity: 1;
  z-index: 1
}

.hero-canadaplace {
  background-image: url('assets/bg_hero-canadaplace_59f878017fa9e689f4097055432ff6ed.jpg')
}

.hero-marina {
  background-image: url('assets/bg_hero-marina_f046b5d79bfa7320a47e4868e19858e0.jpg')
}

.hero-aerial {
  background-image: url('assets/bg_hero-aerial_aa6d59bceb0317720d37ab2f54b0e65f.jpg')
}

.hero-privacy {
  background-image: url('assets/hero-slider/slide5.jpg')
}

.hero-terms {
  background-image: url('assets/hero-slider/slide10.jpg')
}

.hero-mtnlake {
  background-image: url('assets/bg_hero-mtnlake_5c0ea464c9ca7ff5d2fba68c96939044.jpg')
}

.hero-mtnmisty {
  background-image: url('assets/bg_hero-mtnmisty_e14a81703b62c92dbd480664dcfd61d6.jpg')
}

.hero-mtnfoggy {
  background-image: url('assets/bg_hero-mtnfoggy_c586c54263e676c09365b1a48491fec8.jpg')
}

.hero-seawall {
  background-image: url('assets/bg_hero-seawall_1097e5ef7fc5610e9daa3da919f45bd3.jpg')
}


.season-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.season-header i {
  font-size: 28px;
  color: var(--red);
}

.season-header h3 {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 500;
  margin: 0;
}

.season-row p {
  color: var(--muted);
  font-size: 16px;
  line-height: 1.6;
  max-width: 70ch;
  margin: 0 0 24px 0;
}

.carousel-track-wrapper {
  overflow: hidden;
  width: 100%;
  border-radius: 20px;
  position: relative;
  background: var(--cream);
  padding: 16px 0;
}

.carousel-track {
  display: flex;
  width: max-content;
  will-change: transform;
}

.carousel-item {
  flex: 0 0 220px;
  height: 320px;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  margin-right: 16px;
  transition: flex-basis 0.4s cubic-bezier(0.25, 0.8, 0.25, 1),
    filter 0.4s ease,
    transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.carousel-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@media(min-width: 901px) {
  .carousel-track-wrapper:hover .carousel-track {
    animation-play-state: paused !important;
  }

  .carousel-track:hover .carousel-item {
    flex-basis: 150px;
    filter: brightness(0.75) grayscale(0.2);
  }

  .carousel-track .carousel-item:hover {
    flex-basis: 380px;
    filter: brightness(1) grayscale(0);
  }

  .carousel-track .carousel-item:hover img {
    transform: scale(1.05);
  }
}

.scroll-winter {
  animation: scroll-left 35s linear infinite;
}

.scroll-spring {
  animation: scroll-left 42s linear infinite;
}

.scroll-summer {
  animation: scroll-left 38s linear infinite;
}

.scroll-autumn {
  animation: scroll-left 45s linear infinite;
}

@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@media(max-width: 900px) {
  .carousel-item {
    flex: 0 0 150px;
    height: 220px;
    margin-right: 12px;
  }

  .season-header h3 {
    font-size: 24px;
  }

  .season-row p {
    font-size: 14.5px;
    margin-bottom: 16px;
  }

  .season-row {
    margin-bottom: 40px;
  }

  .carousel-track-wrapper {
    padding: 12px 0;
    border-radius: 16px;
  }
}

/* Automatic image zooming effect */
.auto-zoom .phimg {
  animation: autoZoom 20s ease-in-out infinite alternate;
}

@keyframes autoZoom {
  0% {
    transform: scale(1.0);
  }

  100% {
    transform: scale(1.08);
  }
}

/* Legal & Policy Content Formatting */
.legal-content h2 {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 500;
  margin: 36px 0 16px;
  color: var(--ink);
}

.legal-content h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 20px;
  margin: 24px 0 10px;
  color: var(--ink);
}

.legal-content p {
  font-family: var(--sans);
  font-size: 16px;
  color: var(--soft-ink);
  line-height: 1.68;
  margin-bottom: 18px;
}

.legal-content ul {
  margin-left: 24px;
  margin-bottom: 24px;
  list-style-type: disc;
}

.legal-content li {
  font-family: var(--sans);
  font-size: 16px;
  color: var(--soft-ink);
  margin-bottom: 10px;
  line-height: 1.68;
}

.legal-content strong {
  color: var(--ink);
  font-weight: 600;
}