/* Lighter membership page design to match the current homepage direction. */
:root {
  --ics-deep: #08283a;
  --ics-navy: #082f49;
  --ics-text: #315064;
  --ics-muted: #526b7c;
  --ics-green: #009b45;
  --ics-green-dark: #07833c;
  --ics-teal: #6faab6;
  --ics-teal-soft: #eaf8fa;
  --ics-green-soft: #edf8f0;
  --ics-bg: #f8fcfd;
  --ics-border: #e4edf0;
  --ics-shadow: 0 18px 42px rgba(8, 40, 58, .10);
  --ics-shadow-strong: 0 22px 56px rgba(8, 40, 58, .12);
  --ics-radius: 22px;
}

html {
  scroll-padding-top: 100px;
  scroll-behavior: smooth;
}

body.membership-page {
  margin: 0;
  color: var(--ics-deep);
  background: #ffffff;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.65;
}

h1,
h2,
h3 {
  color: var(--ics-deep);
  font-weight: 800;
  letter-spacing: -.035em;
}

/* Light nav copied to match the current homepage treatment */
.site-header {
  background: rgba(255, 255, 255, .97) !important;
  box-shadow: 0 1px 0 rgba(6, 27, 44, .08), 0 8px 28px rgba(6, 27, 44, .06) !important;
  backdrop-filter: blur(10px);
}

.site-header .navbar {
  background: transparent !important;
}

.nav-wrap {
  min-height: 94px !important;
  padding: .7rem clamp(1rem, 4vw, 3.8rem) !important;
}

.brand-lockup {
  color: #0b2737 !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  letter-spacing: .045em;
  line-height: 1.15;
  text-decoration: none;
  text-transform: uppercase;
}

.brand-lockup:hover,
.brand-lockup:focus {
  color: #0b2737 !important;
}

.brand-logo {
  width: 72px !important;
  height: 72px !important;
  display: block;
  flex: 0 0 auto;
}

.brand-name span {
  display: block;
}

.navbar .nav-link {
  color: #0b2737 !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  padding: .82rem .9rem !important;
  position: relative;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus,
.navbar .nav-link.active {
  color: var(--ics-green) !important;
}

.navbar .nav-link.active::after {
  content: "";
  position: absolute;
  left: .9rem;
  right: .9rem;
  bottom: .28rem;
  height: 2px;
  background: var(--ics-green);
  border-radius: 999px;
}

.nav-cta {
  background: var(--ics-green) !important;
  color: #fff !important;
  border: 1px solid var(--ics-green) !important;
  border-radius: .4rem !important;
  padding: .78rem 1.18rem !important;
  font-weight: 600 !important;
  box-shadow: 0 8px 18px rgba(0, 155, 69, .16) !important;
}

.nav-cta:hover,
.nav-cta:focus {
  background: var(--ics-green-dark) !important;
  border-color: var(--ics-green-dark) !important;
  color: #fff !important;
}

.navbar-toggler,
.navbar-toggler.bg-light {
  background: #fff !important;
  border: 1px solid rgba(6, 27, 44, .16) !important;
  border-radius: .55rem !important;
  padding: .65rem .85rem !important;
  box-shadow: none !important;
}

.navbar-toggler-icon {
  width: 1.7rem !important;
  height: 1.7rem !important;
  opacity: 1 !important;
  filter: none !important;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2852,64,77,0.92%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Buttons */
.btn-ics-primary,
.btn-ics-secondary,
.btn-ics-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  border-radius: 12px;
  padding: .9rem 1.35rem;
  font-weight: 600;
  text-decoration: none;
  line-height: 1.2;
  transition: transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}

.btn-ics-primary {
  background: var(--ics-green);
  color: #fff;
  border: 1px solid var(--ics-green);
  box-shadow: 0 12px 26px rgba(0, 155, 69, .18);
}

.btn-ics-primary:hover,
.btn-ics-primary:focus {
  background: var(--ics-green-dark);
  border-color: var(--ics-green-dark);
  color: #fff;
  transform: translateY(-1px);
}

.btn-ics-secondary,
.btn-ics-outline {
  background: #fff;
  color: #2d7048;
  border: 1px solid #b8d7c0;
}

.btn-ics-secondary:hover,
.btn-ics-secondary:focus,
.btn-ics-outline:hover,
.btn-ics-outline:focus {
  background: #f8fcf9;
  color: #235b39;
  border-color: #9cc7a8;
  transform: translateY(-1px);
}

/* Hero */
.membership-hero {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(243, 249, 250, .98) 0%, rgba(243, 249, 250, .92) 38%, rgba(243, 249, 250, .64) 58%, rgba(243, 249, 250, .22) 78%, rgba(243, 249, 250, 0) 100%),
    radial-gradient(circle at 82% 16%, rgba(111, 170, 182, .18), transparent 26%),
    radial-gradient(circle at 78% 84%, rgba(0, 155, 69, .11), transparent 32%),
    linear-gradient(180deg, #f8fcfd 0%, #edf8f8 100%);
  border-bottom: 1px solid rgba(8, 47, 73, .08);
}

.membership-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgba(246, 251, 252, 1) 0%, rgba(246, 251, 252, .98) 20%, rgba(246, 251, 252, .88) 38%, rgba(246, 251, 252, .56) 56%, rgba(246, 251, 252, .18) 70%, rgba(246, 251, 252, 0) 84%),
    url('../images/membership-hero-hills-fade.png');
  background-repeat: no-repeat;
  background-position: left top, right bottom;
  background-size: 100% 100%, min(74vw, 980px) auto;
  opacity: .98;
  pointer-events: none;
}

.membership-hero::after {
  content: "";
  position: absolute;
  right: -90px;
  top: 54px;
  width: 350px;
  height: 350px;
  border-radius: 50%;
  border: 42px solid rgba(111, 170, 182, .10);
  pointer-events: none;
}

.membership-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .68fr);
  gap: clamp(2rem, 4vw, 4.4rem);
  align-items: center;
  padding: clamp(4rem, 6vw, 5.4rem) 0 clamp(4.8rem, 6.5vw, 5.8rem);
}

.membership-kicker,
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 1.15rem;
  padding: .78rem 1.45rem;
  border-radius: 999px;
  background: linear-gradient(180deg, #e7f4fb 0%, #dcedf8 100%);
  border: 1px solid #bcd9ed;
  color: #2b6c9b;
  font-size: 1.04rem;
  font-weight: 800;
  letter-spacing: .01em;
  box-shadow: 0 10px 22px rgba(43, 108, 155, .12);
}

.membership-hero h1 {
  margin: 0 0 1.15rem;
  max-width: 760px;
  font-family: "Libre Baskerville", Georgia, serif;
  font-size: clamp(2.35rem, 4.55vw, 4.45rem);
  line-height: 1.06;
  letter-spacing: -.055em;
}

.membership-hero-copy {
  max-width: 620px;
  margin: 0 0 1.6rem;
  color: #35576b;
  font-size: clamp(1.04rem, 1.28vw, 1.2rem);
  line-height: 1.58;
}

.hero-actions,
.join-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
}

.membership-hero-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(111, 170, 182, .30);
  border-radius: 28px;
  background:
    radial-gradient(circle at 94% 10%, rgba(255,255,255,.88), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(240, 249, 248, .98) 100%);
  box-shadow: var(--ics-shadow-strong);
  padding: clamp(1.7rem, 3vw, 2.45rem);
}

.membership-hero-card-icon,
.membership-card-icon,
.membership-feature-icon {
  width: 68px;
  height: 68px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  background: linear-gradient(180deg, #eff8f2 0%, #e4f3ea 100%);
  color: var(--ics-green);
  box-shadow: inset 0 0 0 1px rgba(0, 155, 69, .08);
}

.membership-hero-card-icon {
  margin-bottom: 1.35rem;
}

.membership-hero-card svg,
.membership-card-icon svg,
.membership-feature-icon svg {
  width: 36px;
  height: 36px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 3.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.membership-hero-card h2 {
  margin: 0 0 .75rem;
  font-size: clamp(1.6rem, 2vw, 2.05rem);
  line-height: 1.12;
}

.membership-hero-card p {
  margin: 0 0 1rem;
  color: #4d6879;
}

.membership-hero-card ul {
  display: grid;
  gap: .65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.membership-hero-card li {
  position: relative;
  padding-left: 1.65rem;
  color: var(--ics-deep);
  font-weight: 800;
}

.membership-hero-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .43rem;
  width: .72rem;
  height: .72rem;
  border-radius: 50%;
  background: var(--ics-green);
}

/* Feature strip */
.membership-feature-strip {
  position: relative;
  z-index: 2;
  margin-top: -46px;
  padding-bottom: clamp(2.4rem, 4vw, 3.4rem);
}

.membership-feature-strip-inner {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid rgba(8, 40, 58, .10);
  border-radius: 18px;
  background: rgba(255,255,255,.99);
  box-shadow: 0 18px 42px rgba(8, 40, 58, .12);
}

.membership-feature-item {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  min-height: 112px;
  padding: 1.45rem 1.55rem;
}

.membership-feature-item + .membership-feature-item {
  border-left: 1px solid rgba(8, 40, 58, .09);
}

.membership-feature-item strong {
  color: var(--ics-deep);
  font-size: 1rem;
  line-height: 1.35;
  font-weight: 800;
}

.membership-feature-icon {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  border-radius: 0;
  background: transparent;
  color: var(--ics-green);
}

.membership-feature-item-teal .membership-feature-icon {
  color: var(--ics-teal);
}

.membership-feature-icon svg {
  width: 48px;
  height: 48px;
  stroke-width: 3;
}

/* Sections */
.section-block {
  padding: clamp(3rem, 5vw, 4.8rem) 0;
}

.section-heading {
  max-width: 790px;
  margin: 0 auto 2.1rem;
  text-align: center;
}

.section-heading h2,
.join-panel h2 {
  margin: 0 0 .85rem;
  font-size: clamp(2rem, 3.5vw, 3.25rem);
  line-height: 1.08;
}

.section-heading p,
.join-panel p {
  margin: 0;
  color: var(--ics-muted);
  font-size: clamp(1rem, 1.25vw, 1.1rem);
}

.membership-routes {
  background: #ffffff;
}

.membership-route-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.membership-route-card,
.benefit-card {
  height: 100%;
  border: 1px solid var(--ics-border);
  border-radius: var(--ics-radius);
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(8, 40, 58, .045);
  padding: clamp(1.45rem, 2.5vw, 2rem);
}

.membership-route-card-featured {
  background: linear-gradient(135deg, #ffffff 0%, #f4fbfb 100%);
  border-color: rgba(111, 170, 182, .22);
}

.membership-card-icon {
  margin-bottom: 1.1rem;
}

.membership-route-card h3,
.benefit-card h3 {
  margin: 0 0 .65rem;
  font-size: clamp(1.35rem, 2vw, 1.75rem);
}

.membership-route-card p,
.benefit-card p {
  margin: 0;
  color: var(--ics-muted);
}

.membership-benefits {
  background:
    radial-gradient(circle at 12% 18%, rgba(111, 170, 182, .13), transparent 30%),
    linear-gradient(180deg, #f6fbfc 0%, #ffffff 100%);
}

.benefit-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.benefit-card {
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.benefit-card h3 {
  font-size: 1.15rem;
  line-height: 1.2;
}

/* Join panel */
.membership-join {
  background: #ffffff;
}

.join-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .42fr);
  gap: 2rem;
  align-items: center;
  border: 1px solid rgba(111, 170, 182, .22);
  border-radius: 30px;
  background:
    radial-gradient(circle at 88% 15%, rgba(111, 170, 182, .20), transparent 28%),
    linear-gradient(135deg, #eff9fb 0%, #eef9f1 100%);
  box-shadow: var(--ics-shadow-strong);
  padding: clamp(1.8rem, 4vw, 3rem);
}

.join-panel p {
  max-width: 650px;
  margin-bottom: 1.4rem;
}

.join-panel-note {
  border-radius: 22px;
  border: 1px solid rgba(8, 47, 73, .08);
  background: rgba(255, 255, 255, .72);
  padding: 1.4rem;
  color: var(--ics-muted);
}

.join-panel-note strong,
.join-panel-note span {
  display: block;
}

.join-panel-note strong {
  color: var(--ics-deep);
  font-size: 1.1rem;
  margin-bottom: .35rem;
}

/* Footer copied to match homepage */
.site-footer {
  background: #3f4854;
  color: #fff;
  padding: 2.75rem 0 1.4rem;
}

.footer-grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.5fr) repeat(3, minmax(150px, 1fr));
  gap: 2rem;
  align-items: start;
}

.footer-brand {
  display: inline-flex;
  align-items: center;
  gap: .85rem;
  color: #fff;
  text-decoration: none;
  font-size: 1.05rem;
  line-height: 1.15;
}

.footer-brand:hover,
.footer-brand:focus {
  color: #fff;
}

.footer-logo {
  width: 56px;
  height: 56px;
  flex: 0 0 auto;
}

.footer-summary {
  color: rgba(255, 255, 255, .78);
  margin: 1rem 0 0;
  max-width: 340px;
  line-height: 1.6;
}

.footer-column h2 {
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 .9rem;
  padding-bottom: .55rem;
  border-bottom: 2px solid rgba(78, 171, 86, .65);
}

.footer-column a,
.footer-column span {
  display: block;
  color: rgba(255, 255, 255, .82);
  text-decoration: none;
  margin-bottom: .55rem;
  line-height: 1.45;
}

.footer-column a:hover,
.footer-column a:focus {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: .18em;
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: .75rem 1rem;
  border-top: 1px solid rgba(255, 255, 255, .16);
  margin-top: 2.25rem;
  padding-top: 1rem;
  color: rgba(255, 255, 255, .72);
  font-size: .92rem;
}

.footer-bottom p {
  margin: 0;
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 50;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: var(--ics-green);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
}

.back-to-top:hover,
.back-to-top:focus {
  color: #fff;
  background: var(--ics-green-dark);
}

@media (max-width: 1199.98px) {
  .membership-feature-item {
    padding: 1.25rem;
  }

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

@media (max-width: 991.98px) {
  .membership-hero::before {
    background-size: 100% 100%, min(100vw, 860px) auto;
    background-position: left top, right bottom;
    opacity: .92;
  }

  .nav-wrap {
    min-height: 78px !important;
    padding: .55rem 1rem !important;
  }

  .brand-logo {
    width: 58px !important;
    height: 58px !important;
  }

  .navbar-collapse {
    background: #fff;
    border: 1px solid rgba(6, 27, 44, .08);
    border-radius: 1rem;
    box-shadow: 0 18px 38px rgba(6, 27, 44, .12);
    margin-top: .8rem;
    padding: .75rem;
  }

  .navbar .nav-link {
    padding: .75rem .85rem !important;
  }

  .navbar .nav-link.active::after {
    left: .85rem;
    right: auto;
    width: 42px;
    bottom: .35rem;
  }

  .membership-hero-inner,
  .join-panel {
    grid-template-columns: 1fr;
  }

  .membership-hero-inner {
    padding-top: 3.2rem;
    padding-bottom: 4.4rem;
  }

  .membership-feature-strip {
    margin-top: -36px;
  }

  .membership-feature-strip-inner,
  .membership-route-grid {
    grid-template-columns: 1fr;
  }

  .membership-feature-item + .membership-feature-item {
    border-left: 0;
    border-top: 1px solid rgba(8, 40, 58, .09);
  }

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

  .footer-brand-block {
    grid-column: 1 / -1;
  }
}

@media (max-width: 575.98px) {
  .membership-hero::before {
    background-size: 100% 100%, 140% auto;
    background-position: left top, 68% bottom;
    opacity: .88;
  }

  .membership-kicker,
  .section-eyebrow {
    font-size: .96rem;
    padding: .72rem 1.2rem;
  }

  .membership-hero h1 {
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  .hero-actions,
  .join-actions {
    display: grid;
  }

  .btn-ics-primary,
  .btn-ics-secondary,
  .btn-ics-outline {
    width: 100%;
  }

  .membership-feature-strip {
    margin-top: -24px;
  }

  .membership-feature-item {
    min-height: 98px;
  }

  .benefit-grid {
    grid-template-columns: 1fr;
  }

  .section-block {
    padding: 3rem 0;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .footer-bottom {
    display: block;
  }

  .footer-bottom p + p {
    margin-top: .45rem;
  }
}


/* =========================================================
   MEMBERSHIP HERO REVISION: GREEN PILL + SOFTER HILLS
   Makes the badge more prominent again, fades the hills further
   and prevents the illustration feeling cut off behind the card.
   ========================================================= */
body.membership-page .membership-hero {
  overflow: hidden;
  background:
    linear-gradient(90deg,
      rgba(246, 251, 252, .98) 0%,
      rgba(246, 251, 252, .96) 34%,
      rgba(246, 251, 252, .82) 54%,
      rgba(246, 251, 252, .58) 68%,
      rgba(246, 251, 252, .36) 82%,
      rgba(246, 251, 252, .22) 100%),
    radial-gradient(circle at 80% 20%, rgba(111, 170, 182, .14), transparent 30%),
    radial-gradient(circle at 78% 82%, rgba(0, 155, 69, .10), transparent 34%),
    linear-gradient(180deg, #f9fcfd 0%, #eef8f7 100%) !important;
}

body.membership-page .membership-hero::before {
  opacity: .46 !important;
  background-image:
    linear-gradient(90deg,
      rgba(246, 251, 252, 1) 0%,
      rgba(246, 251, 252, .99) 24%,
      rgba(246, 251, 252, .94) 42%,
      rgba(246, 251, 252, .76) 58%,
      rgba(246, 251, 252, .58) 74%,
      rgba(246, 251, 252, .45) 100%),
    linear-gradient(180deg,
      rgba(246, 251, 252, .20) 0%,
      rgba(246, 251, 252, .10) 42%,
      rgba(246, 251, 252, .28) 100%),
    url('../images/membership-hero-hills-fade.png') !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: left top, left top, right bottom !important;
  background-size: 100% 100%, 100% 100%, min(68vw, 1020px) auto !important;
  filter: saturate(.82) brightness(1.06);
}

body.membership-page .membership-hero::after {
  opacity: .72;
}

body.membership-page .membership-kicker {
  margin-bottom: 1.2rem !important;
  padding: .78rem 1.65rem !important;
  min-height: 48px;
  background: linear-gradient(180deg, #e9f8ed 0%, #dff3e5 100%) !important;
  border: 1px solid #bce1c7 !important;
  color: #24823a !important;
  font-size: 1.08rem !important;
  font-weight: 850 !important;
  box-shadow: 0 12px 24px rgba(0, 155, 69, .13) !important;
}

body.membership-page .membership-hero h1 {
  font-size: clamp(2.25rem, 4.25vw, 4.15rem) !important;
  line-height: 1.07 !important;
  max-width: 730px !important;
}

body.membership-page .membership-hero-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.90) 100%) !important;
  backdrop-filter: blur(2px);
  border-color: rgba(8, 47, 73, .10) !important;
  box-shadow: 0 22px 56px rgba(8, 40, 58, .11) !important;
}

/* Keep the hills visible but gentle on tablet/mobile without cutting hard through the card. */
@media (max-width: 991.98px) {
  body.membership-page .membership-hero::before {
    opacity: .34 !important;
    background-size: 100% 100%, 100% 100%, 1150px auto !important;
    background-position: left top, left top, 58% bottom !important;
  }

  body.membership-page .membership-kicker {
    font-size: 1rem !important;
    padding: .72rem 1.35rem !important;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-hero::before {
    opacity: .24 !important;
    background-size: 100% 100%, 100% 100%, 980px auto !important;
    background-position: left top, left top, 62% bottom !important;
  }

  body.membership-page .membership-hero h1 {
    font-size: clamp(2rem, 10vw, 2.75rem) !important;
  }
}


/* =========================================================
   MEMBERSHIP HERO REVISION 2: remove leftover arc and soften/fix hills
   ========================================================= */
body.membership-page .membership-hero::after {
  display: none !important;
}

body.membership-page .membership-hero {
  background:
    linear-gradient(90deg,
      rgba(246, 251, 252, .99) 0%,
      rgba(246, 251, 252, .98) 32%,
      rgba(246, 251, 252, .92) 50%,
      rgba(246, 251, 252, .82) 64%,
      rgba(246, 251, 252, .72) 78%,
      rgba(246, 251, 252, .66) 100%),
    linear-gradient(180deg, #f9fcfd 0%, #eef7f7 100%) !important;
}

body.membership-page .membership-hero::before {
  opacity: .30 !important;
  background-image:
    linear-gradient(90deg,
      rgba(246, 251, 252, 1) 0%,
      rgba(246, 251, 252, .995) 20%,
      rgba(246, 251, 252, .95) 38%,
      rgba(246, 251, 252, .82) 52%,
      rgba(246, 251, 252, .68) 66%,
      rgba(246, 251, 252, .56) 80%,
      rgba(246, 251, 252, .50) 100%),
    linear-gradient(180deg,
      rgba(246, 251, 252, .92) 0%,
      rgba(246, 251, 252, .76) 34%,
      rgba(246, 251, 252, .48) 66%,
      rgba(246, 251, 252, .30) 100%),
    url('../images/membership-hero-hills-fade.png') !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: left top, left top, center bottom !important;
  background-size: 100% 100%, 100% 100%, 1240px auto !important;
  filter: saturate(.72) brightness(1.08) !important;
}

body.membership-page .membership-hero-card {
  background: linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(255,255,255,.93) 100%) !important;
}

@media (max-width: 1199.98px) {
  body.membership-page .membership-hero::before {
    background-size: 100% 100%, 100% 100%, 1120px auto !important;
    background-position: left top, left top, 62% bottom !important;
    opacity: .28 !important;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-hero::before {
    background-size: 100% 100%, 100% 100%, 1020px auto !important;
    background-position: left top, left top, 58% bottom !important;
    opacity: .24 !important;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-hero::before {
    background-size: 100% 100%, 100% 100%, 900px auto !important;
    background-position: left top, left top, 56% bottom !important;
    opacity: .18 !important;
  }
}


/* =========================================================
   MEMBERSHIP HERO REVISION 3: rebalance hills image visibility
   A middle ground between too strong and too faint.
   ========================================================= */
body.membership-page .membership-hero {
  background:
    linear-gradient(180deg, #f8fcfc 0%, #eef7f6 100%) !important;
}

body.membership-page .membership-hero::before {
  opacity: .40 !important;
  background-image:
    linear-gradient(90deg,
      rgba(246, 251, 252, .99) 0%,
      rgba(246, 251, 252, .97) 26%,
      rgba(246, 251, 252, .90) 44%,
      rgba(246, 251, 252, .72) 58%,
      rgba(246, 251, 252, .52) 72%,
      rgba(246, 251, 252, .34) 84%,
      rgba(246, 251, 252, .24) 100%),
    linear-gradient(180deg,
      rgba(246, 251, 252, .34) 0%,
      rgba(246, 251, 252, .14) 42%,
      rgba(246, 251, 252, .08) 70%,
      rgba(246, 251, 252, .18) 100%),
    url('../images/membership-hero-hills-fade.png') !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: left top, left top, 88% 100% !important;
  background-size: 100% 100%, 100% 100%, 980px auto !important;
  filter: saturate(.84) brightness(1.03) !important;
}

body.membership-page .membership-hero-card {
  background: linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(255,255,255,.94) 100%) !important;
}

@media (max-width: 1399.98px) {
  body.membership-page .membership-hero::before {
    background-position: left top, left top, 92% 100% !important;
    background-size: 100% 100%, 100% 100%, 900px auto !important;
    opacity: .38 !important;
  }
}

@media (max-width: 1199.98px) {
  body.membership-page .membership-hero::before {
    background-position: left top, left top, 100% 100% !important;
    background-size: 100% 100%, 100% 100%, 820px auto !important;
    opacity: .34 !important;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-hero::before {
    background-position: left top, left top, 70% 100% !important;
    background-size: 100% 100%, 100% 100%, 900px auto !important;
    opacity: .28 !important;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-hero::before {
    background-position: left top, left top, 68% 100% !important;
    background-size: 100% 100%, 100% 100%, 760px auto !important;
    opacity: .20 !important;
  }
}


/* =========================================================
   MEMBERSHIP HERO REVISION 4: full-width faded hills background
   Spans the entire hero background so it no longer appears cut off.
   ========================================================= */
body.membership-page .membership-hero {
  background: linear-gradient(180deg, #f8fcfc 0%, #eef7f6 100%) !important;
}

body.membership-page .membership-hero::after {
  display: none !important;
}

body.membership-page .membership-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .38 !important;
  background-image:
    linear-gradient(90deg,
      rgba(247, 251, 252, .985) 0%,
      rgba(247, 251, 252, .97) 18%,
      rgba(247, 251, 252, .92) 34%,
      rgba(247, 251, 252, .78) 48%,
      rgba(247, 251, 252, .56) 64%,
      rgba(247, 251, 252, .34) 80%,
      rgba(247, 251, 252, .22) 100%),
    linear-gradient(180deg,
      rgba(247, 251, 252, .18) 0%,
      rgba(247, 251, 252, .06) 48%,
      rgba(247, 251, 252, .16) 100%),
    url('../images/membership-hero-hills-fade.png') !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: left top, left top, center center !important;
  background-size: 100% 100%, 100% 100%, cover !important;
  filter: saturate(.86) brightness(1.04) !important;
  pointer-events: none;
}

body.membership-page .membership-hero-card {
  background: linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(255,255,255,.945) 100%) !important;
  box-shadow: 0 22px 56px rgba(8, 40, 58, .10) !important;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-hero::before {
    opacity: .30 !important;
    background-position: left top, left top, 58% center !important;
    background-size: 100% 100%, 100% 100%, cover !important;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-hero::before {
    opacity: .24 !important;
    background-position: left top, left top, 62% center !important;
  }
}


/* =========================================================
   MEMBERSHIP SECTION PROMINENCE TRIAL
   Stronger section pills, darker text, clearer cards.
   ========================================================= */
body.membership-page .section-eyebrow {
  margin-bottom: 1.15rem !important;
  padding: .82rem 1.6rem !important;
  background: linear-gradient(180deg, #e9f8ed 0%, #dff3e5 100%) !important;
  border: 1px solid #bce1c7 !important;
  color: #24823a !important;
  font-size: 1.06rem !important;
  font-weight: 850 !important;
  box-shadow: 0 12px 24px rgba(0, 155, 69, .13) !important;
}

body.membership-page .section-heading {
  margin-bottom: 2.35rem;
}

body.membership-page .section-heading p,
body.membership-page .join-panel p,
body.membership-page .membership-route-card p,
body.membership-page .benefit-card p {
  color: #4a6678 !important;
}

body.membership-page .section-heading p {
  font-size: clamp(1.02rem, 1.28vw, 1.16rem) !important;
  line-height: 1.55;
}

body.membership-page .membership-routes {
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfc 100%);
}

body.membership-page .membership-route-grid {
  gap: 1.65rem;
}

body.membership-page .membership-route-card {
  border: 1px solid rgba(8, 47, 73, .10) !important;
  border-radius: 30px !important;
  box-shadow: 0 16px 36px rgba(8, 40, 58, .065) !important;
  padding: clamp(1.7rem, 2.7vw, 2.25rem) !important;
  position: relative;
}

body.membership-page .membership-route-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 5px;
  border-radius: 30px 30px 0 0;
  background: linear-gradient(90deg, #18a34a 0%, #6bb7c1 100%);
  opacity: .9;
}

body.membership-page .membership-route-card-featured {
  background: linear-gradient(135deg, #fbfefe 0%, #f1f9f7 100%) !important;
  border-color: rgba(0, 155, 69, .18) !important;
}

body.membership-page .membership-card-icon,
body.membership-page .benefit-card-icon {
  width: 80px;
  height: 80px;
  border-radius: 22px;
  background: linear-gradient(180deg, #eef8f1 0%, #e4f4ea 100%);
  box-shadow: inset 0 0 0 1px rgba(0, 155, 69, .09);
  color: var(--ics-green);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.membership-page .membership-route-card svg,
body.membership-page .benefit-card svg {
  width: 40px;
  height: 40px;
  stroke-width: 3;
}

body.membership-page .membership-route-card h3,
body.membership-page .benefit-card h3 {
  margin: .15rem 0 .75rem;
  color: var(--ics-deep);
}

body.membership-page .membership-route-card p {
  font-size: 1.04rem;
  line-height: 1.55;
}

body.membership-page .membership-benefits {
  background:
    radial-gradient(circle at 12% 16%, rgba(111, 170, 182, .16), transparent 28%),
    linear-gradient(180deg, #f7fbfc 0%, #ffffff 100%) !important;
}

body.membership-page .benefit-grid {
  gap: 1.15rem;
}

body.membership-page .benefit-card {
  min-height: 255px;
  border: 1px solid rgba(8, 47, 73, .09) !important;
  border-radius: 26px !important;
  background: #ffffff !important;
  box-shadow: 0 16px 36px rgba(8, 40, 58, .05) !important;
  padding: 1.55rem 1.45rem 1.5rem !important;
  position: relative;
}

body.membership-page .benefit-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 4px;
  border-radius: 26px 26px 0 0;
  background: linear-gradient(90deg, rgba(0,155,69,.95) 0%, rgba(111,170,182,.85) 100%);
}

body.membership-page .benefit-card h3 {
  font-size: 1.3rem !important;
  line-height: 1.22 !important;
  margin-top: 1rem !important;
}

body.membership-page .benefit-card p {
  font-size: 1.02rem !important;
  line-height: 1.58 !important;
}

@media (max-width: 991.98px) {
  body.membership-page .benefit-card,
  body.membership-page .membership-route-card {
    border-radius: 24px !important;
  }

  body.membership-page .benefit-card::before,
  body.membership-page .membership-route-card::before {
    border-radius: 24px 24px 0 0;
  }
}


/* =========================================================
   SOFTEN BENEFIT/ROUTE CARD TOP ACCENTS
   Removes the strong green lines and replaces them with a softer treatment.
   ========================================================= */
body.membership-page .membership-route-card::before,
body.membership-page .benefit-card::before {
  height: 0 !important;
  background: none !important;
}

body.membership-page .membership-route-card,
body.membership-page .benefit-card {
  border-color: rgba(8, 47, 73, .08) !important;
  box-shadow: 0 14px 32px rgba(8, 40, 58, .045) !important;
}

body.membership-page .membership-route-card-featured {
  border-color: rgba(111, 170, 182, .18) !important;
  background: linear-gradient(135deg, #ffffff 0%, #f5fbf9 100%) !important;
}

body.membership-page .benefit-card {
  background:
    linear-gradient(180deg, rgba(243, 250, 247, .55) 0%, rgba(255, 255, 255, 0) 22%),
    #ffffff !important;
}


/* =========================================================
   ROUTES / BENEFITS CLARITY + CTA
   Reduce washed-out gradients and add a stronger CTA panel.
   ========================================================= */
body.membership-page .membership-route-card,
body.membership-page .benefit-card {
  background: #ffffff !important;
}

body.membership-page .membership-route-card-featured {
  background: linear-gradient(180deg, #fdfefe 0%, #f6fbf9 100%) !important;
  border-color: rgba(0, 155, 69, .10) !important;
}

body.membership-page .membership-route-card h3,
body.membership-page .benefit-card h3 {
  color: #0b2f47 !important;
}

body.membership-page .membership-route-card p,
body.membership-page .benefit-card p,
body.membership-page .section-heading p {
  color: #4c6678 !important;
}

body.membership-page .benefit-card {
  background-image: none !important;
}

body.membership-page .membership-routes-cta {
  margin-top: 1.55rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem 1.5rem;
  padding: 1.2rem 1.35rem;
  border: 1px solid rgba(8, 47, 73, .08);
  border-radius: 22px;
  background: linear-gradient(135deg, #ffffff 0%, #f3faf7 100%);
  box-shadow: 0 14px 32px rgba(8, 40, 58, .05);
}

body.membership-page .membership-routes-cta-copy {
  display: grid;
  gap: .25rem;
}

body.membership-page .membership-routes-cta-copy strong {
  color: var(--ics-deep);
  font-size: 1.08rem;
  font-weight: 800;
}

body.membership-page .membership-routes-cta-copy span {
  color: #4c6678;
  font-size: .98rem;
  line-height: 1.5;
}

body.membership-page .membership-routes-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  justify-content: flex-end;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-routes-cta {
    flex-direction: column;
    align-items: flex-start;
  }

  body.membership-page .membership-routes-cta-actions {
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-routes-cta-actions {
    flex-direction: column;
    width: 100%;
  }

  body.membership-page .membership-routes-cta-actions .btn-ics-primary,
  body.membership-page .membership-routes-cta-actions .btn-ics-outline {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}


/* =========================================================
   ROUTES CTA STRONGER CONTRAST TRIAL
   Reduce washed-out feel and introduce stronger button choices.
   ========================================================= */
body.membership-page .membership-routes {
  background: linear-gradient(180deg, #ffffff 0%, #f7fbfb 100%) !important;
}

body.membership-page .section-heading p,
body.membership-page .membership-route-card p,
body.membership-page .benefit-card p,
body.membership-page .membership-routes-cta-copy span {
  color: #486477 !important;
}

body.membership-page .membership-route-card,
body.membership-page .benefit-card {
  background: #ffffff !important;
  border: 1px solid rgba(8, 47, 73, .10) !important;
  box-shadow: 0 16px 34px rgba(8, 40, 58, .06) !important;
}

body.membership-page .membership-route-card-featured {
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%) !important;
  border-color: rgba(0, 155, 69, .12) !important;
}

body.membership-page .membership-card-icon,
body.membership-page .benefit-card-icon {
  background: linear-gradient(180deg, #edf8f2 0%, #e4f3ea 100%) !important;
  box-shadow: inset 0 0 0 1px rgba(0, 155, 69, .08) !important;
}

body.membership-page .membership-routes-cta {
  margin-top: 1.8rem !important;
  padding: 1.35rem 1.5rem !important;
  border: 1px solid rgba(8, 47, 73, .10) !important;
  border-radius: 24px !important;
  background: linear-gradient(135deg, #ffffff 0%, #eef7f5 100%) !important;
  box-shadow: 0 16px 34px rgba(8, 40, 58, .06) !important;
}

body.membership-page .membership-routes-cta-copy strong {
  color: var(--ics-deep) !important;
  font-size: 1.15rem !important;
}

body.membership-page .membership-routes-cta-actions .btn-ics-primary,
body.membership-page .membership-routes-cta-actions .btn-ics-outline {
  min-width: 230px;
  justify-content: center;
  text-align: center;
}

/* Swap out the very green CTA for a deeper navy button */
body.membership-page .membership-routes-cta-actions .btn-ics-primary {
  background: #0b2f47 !important;
  border-color: #0b2f47 !important;
  color: #ffffff !important;
  box-shadow: 0 14px 24px rgba(11, 47, 71, .18) !important;
}

body.membership-page .membership-routes-cta-actions .btn-ics-primary:hover,
body.membership-page .membership-routes-cta-actions .btn-ics-primary:focus {
  background: #144563 !important;
  border-color: #144563 !important;
}

/* Make the secondary CTA feel intentional rather than faded */
body.membership-page .membership-routes-cta-actions .btn-ics-outline {
  background: #dff1ec !important;
  border-color: #c1e1d8 !important;
  color: #216c5c !important;
  box-shadow: none !important;
}

body.membership-page .membership-routes-cta-actions .btn-ics-outline:hover,
body.membership-page .membership-routes-cta-actions .btn-ics-outline:focus {
  background: #d4ebe5 !important;
  border-color: #b3d8cd !important;
  color: #1b5a4d !important;
}

@media (max-width: 575.98px) {
  body.membership-page .membership-routes-cta {
    padding: 1.15rem !important;
  }

  body.membership-page .membership-routes-cta-actions .btn-ics-primary,
  body.membership-page .membership-routes-cta-actions .btn-ics-outline {
    min-width: 0;
  }
}


/* =========================================================
   ICON STYLE TRIAL
   Circular filled icons inspired by the homeowner advice cards.
   ========================================================= */
body.membership-page .membership-route-card {
  padding: 2rem 2.2rem 2rem !important;
  min-height: 285px;
}

body.membership-page .membership-route-card .membership-route-icon {
  display: inline-flex !important;
  width: 94px;
  height: 94px;
  border-radius: 999px;
  margin: 0 0 1.35rem 0;
  box-shadow: none !important;
  color: #ffffff !important;
  background: #4EA654 !important;
  align-items: center;
  justify-content: center;
}

body.membership-page .membership-route-card-teal .membership-route-icon {
  background: #78B8BF !important;
}

body.membership-page .membership-route-card-gold .membership-route-icon {
  background: #BFBC7A !important;
}

body.membership-page .membership-route-card .membership-route-icon svg {
  width: 44px;
  height: 44px;
  stroke: currentColor !important;
  stroke-width: 3.2;
}

body.membership-page .membership-route-card h3 {
  font-size: clamp(1.8rem, 1.9vw, 2.15rem) !important;
  line-height: 1.08 !important;
  margin: 0 0 .9rem !important;
}

body.membership-page .membership-route-card p {
  font-size: clamp(1.08rem, 1.05vw, 1.16rem) !important;
  line-height: 1.58 !important;
  max-width: 34ch;
}

/* Apply the same filled-circle icon treatment to the benefits cards */
body.membership-page .benefit-card .benefit-card-icon {
  width: 92px !important;
  height: 92px !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  margin-bottom: 1rem;
  color: #ffffff !important;
}

body.membership-page .benefit-card-support .benefit-card-icon {
  background: #78B8BF !important;
}

body.membership-page .benefit-card-promotion .benefit-card-icon,
body.membership-page .benefit-card-certification .benefit-card-icon {
  background: #4EA654 !important;
}

body.membership-page .benefit-card-training .benefit-card-icon {
  background: #BFBC7A !important;
}

body.membership-page .benefit-card .benefit-card-icon svg {
  width: 42px !important;
  height: 42px !important;
  stroke: currentColor !important;
  stroke-width: 3.1;
}

body.membership-page .benefit-card h3 {
  font-size: 1.46rem !important;
  line-height: 1.16 !important;
}

body.membership-page .benefit-card p {
  font-size: 1.04rem !important;
  line-height: 1.58 !important;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-route-card {
    min-height: auto;
    padding: 1.8rem !important;
  }

  body.membership-page .membership-route-card .membership-route-icon {
    width: 82px;
    height: 82px;
    margin-bottom: 1.1rem;
  }

  body.membership-page .benefit-card .benefit-card-icon {
    width: 82px !important;
    height: 82px !important;
  }
}


/* =========================================================
   BENEFITS SECTION TRIAL
   Mid-blue pill + 2-across layout + icon on the left.
   ========================================================= */
body.membership-page .membership-benefits .section-eyebrow {
  background: #e4f1f4 !important;
  border-color: rgba(120, 184, 191, .35) !important;
  color: #2c6b78 !important;
  box-shadow: 0 10px 22px rgba(120, 184, 191, .14) !important;
}

body.membership-page .membership-benefits .benefit-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1.6rem !important;
}

body.membership-page .membership-benefits .benefit-card {
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr) !important;
  grid-template-areas:
    "icon title"
    "icon text" !important;
  column-gap: 1.4rem;
  row-gap: .45rem;
  align-items: start;
  min-height: 225px;
  padding: 1.9rem 2rem !important;
}

body.membership-page .membership-benefits .benefit-card .benefit-card-icon {
  grid-area: icon;
  margin: 0 !important;
  align-self: start;
}

body.membership-page .membership-benefits .benefit-card h3 {
  grid-area: title;
  margin: .2rem 0 0 !important;
  font-size: clamp(1.55rem, 1.8vw, 1.8rem) !important;
  line-height: 1.14 !important;
}

body.membership-page .membership-benefits .benefit-card p {
  grid-area: text;
  margin: 0 !important;
  font-size: 1.08rem !important;
  line-height: 1.6 !important;
  max-width: 30ch;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-benefits .benefit-grid {
    grid-template-columns: 1fr !important;
  }

  body.membership-page .membership-benefits .benefit-card {
    grid-template-columns: 80px minmax(0, 1fr) !important;
    padding: 1.6rem !important;
    min-height: auto;
  }

  body.membership-page .membership-benefits .benefit-card .benefit-card-icon {
    width: 80px !important;
    height: 80px !important;
  }

  body.membership-page .membership-benefits .benefit-card h3 {
    font-size: 1.45rem !important;
  }

  body.membership-page .membership-benefits .benefit-card p {
    max-width: none;
    font-size: 1.03rem !important;
  }
}


/* =========================================================
   BENEFITS PILL: SOLID MID BLUE WITH WHITE TEXT
   ========================================================= */
body.membership-page .membership-benefits .section-eyebrow {
  background: #78B8BF !important;
  border-color: #78B8BF !important;
  color: #ffffff !important;
  box-shadow: 0 10px 22px rgba(120, 184, 191, .22) !important;
}


/* =========================================================
   MATCHED SECTION TREATMENT
   Apply the same softer rounded panel language across routes and benefits.
   ========================================================= */
body.membership-page .membership-routes > .container,
body.membership-page .membership-benefits > .container {
  border-radius: 36px;
  padding: 3.2rem 2.4rem 2.5rem;
  border: 1px solid rgba(9, 48, 64, .06);
  box-shadow: 0 24px 54px rgba(9, 48, 64, .05);
  position: relative;
  overflow: hidden;
}

body.membership-page .membership-routes > .container {
  background: linear-gradient(180deg, #f3faf8 0%, #eef7f5 100%);
}

body.membership-page .membership-benefits > .container {
  background: linear-gradient(180deg, #f2f8f9 0%, #eef5f6 100%);
}

body.membership-page .membership-routes > .container::before,
body.membership-page .membership-benefits > .container::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 26%;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(120, 184, 191, .08), rgba(120, 184, 191, 0));
}

body.membership-page .membership-routes .section-heading,
body.membership-page .membership-benefits .section-heading {
  position: relative;
  z-index: 1;
  margin-bottom: 2.2rem;
}

body.membership-page .membership-routes .membership-route-grid,
body.membership-page .membership-benefits .benefit-grid,
body.membership-page .membership-routes .membership-routes-cta {
  position: relative;
  z-index: 1;
}

body.membership-page .membership-routes .membership-route-card,
body.membership-page .membership-benefits .benefit-card {
  background: #ffffff !important;
  border: 1px solid rgba(9, 48, 64, .07) !important;
  box-shadow: 0 14px 34px rgba(9, 48, 64, .06) !important;
}

body.membership-page .membership-routes .membership-routes-cta {
  background: rgba(255, 255, 255, .78) !important;
  border: 1px solid rgba(9, 48, 64, .07) !important;
  box-shadow: 0 14px 30px rgba(9, 48, 64, .05) !important;
  backdrop-filter: blur(2px);
}

body.membership-page .membership-routes .membership-routes-cta-copy strong {
  font-size: 1.35rem !important;
}

body.membership-page .membership-routes .membership-routes-cta-copy span {
  font-size: 1.06rem !important;
}

body.membership-page .membership-routes .membership-route-card p,
body.membership-page .membership-benefits .benefit-card p {
  color: #466276 !important;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-routes > .container,
  body.membership-page .membership-benefits > .container {
    padding: 2.3rem 1.2rem 1.8rem;
    border-radius: 26px;
  }

  body.membership-page .membership-routes > .container::before,
  body.membership-page .membership-benefits > .container::before {
    width: 42%;
  }
}


/* =========================================================
   ROUTES SECTION: MATCH BENEFITS SECTION
   Solid mid-blue pill and filled circular icons.
   ========================================================= */
body.membership-page .membership-routes .section-eyebrow {
  background: #78B8BF !important;
  border-color: #78B8BF !important;
  color: #ffffff !important;
  box-shadow: 0 10px 22px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-routes .membership-card-icon {
  display: inline-flex !important;
  width: 92px;
  height: 92px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  margin: 0 0 1.35rem 0 !important;
  color: #ffffff !important;
  background: #78B8BF !important;
  box-shadow: none !important;
}

body.membership-page .membership-routes .membership-route-card:nth-child(2) .membership-card-icon {
  background: #4EA654 !important;
}

body.membership-page .membership-routes .membership-card-icon svg {
  width: 44px;
  height: 44px;
  stroke: currentColor !important;
  stroke-width: 3.2;
}

body.membership-page .membership-routes .membership-route-card h3 {
  margin-top: .1rem !important;
}

@media (max-width: 991.98px) {
  body.membership-page .membership-routes .membership-card-icon {
    width: 80px;
    height: 80px;
  }
}


/* =========================================================
   JOIN ICS SECTION REFRESH
   Bring the Join panel in line with the cleaner benefits styling.
   ========================================================= */
body.membership-page .membership-join {
  background: #ffffff !important;
}

body.membership-page .membership-join .join-panel {
  display: grid !important;
  grid-template-columns: minmax(0, 1.08fr) minmax(370px, .74fr) !important;
  grid-template-areas:
    "header header"
    "content note" !important;
  gap: 1.8rem 2.6rem !important;
  align-items: stretch !important;
  padding: clamp(2.25rem, 4vw, 3.2rem) !important;
  border-radius: 36px !important;
  border: 1px solid rgba(9, 48, 64, .06) !important;
  background: linear-gradient(180deg, #f2f8f9 0%, #eef5f6 100%) !important;
  box-shadow: 0 24px 54px rgba(9, 48, 64, .05) !important;
  position: relative;
  overflow: hidden;
}

body.membership-page .membership-join .join-panel::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 24%;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(120, 184, 191, .09), rgba(120, 184, 191, 0));
}

body.membership-page .membership-join .join-panel-header,
body.membership-page .membership-join .join-panel-content,
body.membership-page .membership-join .join-panel-note {
  position: relative;
  z-index: 1;
}

body.membership-page .membership-join .join-panel-header {
  grid-area: header;
  display: flex;
  justify-content: center;
  padding-top: .15rem;
}

body.membership-page .membership-join .join-panel-content {
  grid-area: content;
  align-self: center;
  max-width: 740px;
}

body.membership-page .membership-join .join-panel-note {
  grid-area: note;
}

body.membership-page .membership-join .section-eyebrow {
  margin: 0 !important;
  padding: .92rem 1.8rem !important;
  background: #78B8BF !important;
  border: 1px solid #78B8BF !important;
  color: #ffffff !important;
  font-size: 1.02rem !important;
  font-weight: 850 !important;
  box-shadow: 0 10px 22px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-join h2 {
  font-size: clamp(2.85rem, 4.15vw, 4.5rem) !important;
  line-height: 0.99 !important;
  letter-spacing: -0.045em;
  max-width: 9ch;
  margin: 0 0 1.15rem !important;
}

body.membership-page .membership-join p {
  font-size: clamp(1.08rem, 1.28vw, 1.24rem) !important;
  line-height: 1.58 !important;
  color: #4f687c !important;
  max-width: 33ch !important;
  margin-bottom: 1.55rem !important;
}

body.membership-page .membership-join .join-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

body.membership-page .membership-join .join-actions .btn-ics-primary,
body.membership-page .membership-join .join-actions .btn-ics-outline {
  min-width: 0 !important;
  padding: 1rem 1.6rem !important;
  font-size: 1.04rem !important;
  border-radius: 16px !important;
}

body.membership-page .membership-join .join-actions .btn-ics-primary {
  box-shadow: 0 14px 24px rgba(15, 166, 68, .22) !important;
}

body.membership-page .membership-join .join-panel-note {
  align-self: stretch;
  justify-self: stretch;
  width: 100%;
  min-height: 100%;
  border-radius: 32px !important;
  border: 1px solid rgba(9, 48, 64, .07) !important;
  background: rgba(255, 255, 255, .94) !important;
  box-shadow: 0 16px 32px rgba(9, 48, 64, .06) !important;
  padding: 1.85rem 1.85rem 1.8rem !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

body.membership-page .membership-join .join-panel-note::after {
  content: "";
  position: absolute;
  right: -18px;
  bottom: -18px;
  width: 160px;
  height: 160px;
  background: url('../images/ICS_Logo_HillsSq_3.svg') center/contain no-repeat;
  opacity: .08;
  pointer-events: none;
}

body.membership-page .membership-join .join-panel-note-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  margin-bottom: .9rem;
  padding: .72rem 1.2rem;
  border-radius: 999px;
  background: rgba(120, 184, 191, .14);
  color: #2e6f79;
  font-size: 1.08rem;
  font-weight: 850;
  line-height: 1;
}

body.membership-page .membership-join .join-panel-note strong {
  display: block;
  color: #093040 !important;
  font-size: 1.85rem !important;
  line-height: 1.12 !important;
  margin-bottom: .75rem !important;
}

body.membership-page .membership-join .join-panel-note > span:not(.join-panel-note-tag) {
  display: block;
  color: #516b7d !important;
  font-size: 1.1rem !important;
  line-height: 1.7 !important;
  max-width: 26ch;
}

body.membership-page .membership-join .join-panel-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  margin-top: 1.25rem;
  padding: .95rem 1.15rem;
  border-radius: 14px;
  border: 1px solid rgba(9, 48, 64, .12);
  background: #ffffff;
  color: #093040;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

body.membership-page .membership-join .join-panel-link:hover,
body.membership-page .membership-join .join-panel-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(120, 184, 191, .55);
  box-shadow: 0 10px 18px rgba(9, 48, 64, .08);
}

@media (max-width: 991.98px) {
  body.membership-page .membership-join .join-panel {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "header"
      "content"
      "note" !important;
    gap: 1.5rem !important;
  }

  body.membership-page .membership-join .join-panel::before {
    width: 42%;
  }

  body.membership-page .membership-join h2 {
    max-width: none;
  }

  body.membership-page .membership-join .join-panel-note {
    min-height: 0;
  }
}




/* =========================================================
   JOIN ICS GRAPHIC-LED TRIAL
   Graphic-led CTA inspired by the latest mockup.
   ========================================================= */
body.membership-page .membership-join {
  background: #ffffff !important;
  padding-top: clamp(3rem, 5vw, 4.8rem) !important;
}

body.membership-page .membership-join .join-panel.join-panel-graphic {
  position: relative;
  display: grid !important;
  grid-template-columns: minmax(0, .86fr) minmax(420px, .96fr) !important;
  grid-template-areas: "content note" !important;
  gap: clamp(1.8rem, 4vw, 3.6rem) !important;
  align-items: center !important;
  min-height: 560px;
  overflow: hidden;
  padding: clamp(2.2rem, 5vw, 4.2rem) !important;
  border-radius: 38px !important;
  border: 1px solid rgba(9, 48, 64, .07) !important;
  background:
    linear-gradient(90deg, rgba(240, 249, 250, .98) 0%, rgba(240, 249, 250, .9) 42%, rgba(240, 249, 250, .42) 64%, rgba(240, 249, 250, 0) 100%),
    linear-gradient(180deg, rgba(239, 248, 249, .9) 0%, rgba(232, 245, 245, .9) 100%) !important;
  box-shadow: 0 24px 54px rgba(9, 48, 64, .06) !important;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(58%, 850px);
  height: 100%;
  background:
    linear-gradient(90deg, rgba(240, 249, 250, .72) 0%, rgba(240, 249, 250, .18) 22%, rgba(240, 249, 250, 0) 42%),
    url('../images/membership-join-graphic.png') right bottom / contain no-repeat;
  opacity: .98;
  pointer-events: none;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::after {
  content: "";
  position: absolute;
  left: clamp(2rem, 5vw, 4rem);
  top: 50%;
  width: 82px;
  height: 3px;
  border-radius: 999px;
  background: #78B8BF;
  transform: translateY(42px);
  pointer-events: none;
}

body.membership-page .membership-join .join-panel-content,
body.membership-page .membership-join .join-panel-note {
  position: relative;
  z-index: 2;
}

body.membership-page .membership-join .join-panel-content {
  grid-area: content;
  max-width: 640px !important;
  align-self: center;
}

body.membership-page .membership-join .join-panel-graphic .section-eyebrow {
  display: inline-flex !important;
  margin: 0 0 clamp(1.7rem, 3vw, 2.4rem) !important;
  padding: .95rem 1.85rem !important;
  background: #78B8BF !important;
  border: 1px solid #78B8BF !important;
  color: #ffffff !important;
  font-size: 1.08rem !important;
  font-weight: 850 !important;
  box-shadow: 0 12px 24px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-join .join-panel-graphic h2 {
  max-width: 10.5ch !important;
  margin: 0 0 1.65rem !important;
  font-family: var(--ics-serif, "Libre Baskerville", serif) !important;
  font-size: clamp(3rem, 5.5vw, 5.2rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.055em;
  color: var(--ics-deep) !important;
}

body.membership-page .membership-join .join-panel-graphic > .join-panel-content > p {
  max-width: 34ch !important;
  margin: 0 0 1.9rem !important;
  color: #456477 !important;
  font-size: clamp(1.1rem, 1.35vw, 1.28rem) !important;
  line-height: 1.62 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

body.membership-page .membership-join .join-panel-graphic .join-actions .btn-ics-primary,
body.membership-page .membership-join .join-panel-graphic .join-actions .btn-ics-outline {
  padding: 1rem 1.55rem !important;
  border-radius: 16px !important;
  font-size: 1.05rem !important;
  min-width: 0 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note {
  grid-area: note;
  align-self: start;
  justify-self: stretch;
  margin-top: clamp(.2rem, 2vw, 1.2rem);
  max-width: 680px !important;
  min-height: 0 !important;
  padding: clamp(1.45rem, 2.5vw, 2rem) clamp(1.55rem, 3vw, 2.2rem) !important;
  border-radius: 26px !important;
  border: 1px solid rgba(9, 48, 64, .08) !important;
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 18px 34px rgba(9, 48, 64, .08) !important;
  backdrop-filter: blur(2px);
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note::after,
body.membership-page .membership-join .join-panel-graphic .join-panel-note::before {
  display: none !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note h3 {
  margin: 0 0 .55rem !important;
  color: var(--ics-deep) !important;
  font-family: var(--ics-sans, "Inter", sans-serif) !important;
  font-size: clamp(1.45rem, 2vw, 1.9rem) !important;
  line-height: 1.18 !important;
  letter-spacing: -.035em;
  font-weight: 850;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note p {
  max-width: none !important;
  margin: 0 0 1.15rem !important;
  color: #456477 !important;
  font-size: clamp(1rem, 1.2vw, 1.16rem) !important;
  line-height: 1.5 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-link {
  display: inline-flex !important;
  align-items: center;
  gap: .65rem;
  margin: 0 !important;
  padding: .95rem 1.2rem !important;
  border-radius: 14px !important;
  border: 1px solid #78B8BF !important;
  background: #78B8BF !important;
  color: #ffffff !important;
  font-size: 1.04rem !important;
  font-weight: 600 !important;
  text-decoration: none;
  box-shadow: 0 12px 22px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-link:hover,
body.membership-page .membership-join .join-panel-graphic .join-panel-link:focus-visible {
  transform: translateY(-1px);
  background: #69aeb6 !important;
  border-color: #69aeb6 !important;
}

@media (max-width: 1199.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: minmax(0, .95fr) minmax(360px, .85fr) !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 56%;
    opacity: .72;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "content"
      "note" !important;
    min-height: 0;
    padding: 2rem 1.35rem 12rem !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 100%;
    height: 280px;
    opacity: .58;
    background-size: auto 100%;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::after {
    display: none;
  }

  body.membership-page .membership-join .join-panel-graphic h2 {
    max-width: 11ch !important;
  }

  body.membership-page .membership-join .join-panel-graphic .join-panel-note {
    align-self: stretch;
    margin-top: .4rem;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    border-radius: 28px !important;
    padding-bottom: 10.5rem !important;
  }

  body.membership-page .membership-join .join-panel-graphic .join-actions {
    flex-direction: column;
  }

  body.membership-page .membership-join .join-panel-graphic .join-actions a {
    width: 100%;
    justify-content: center;
  }
}


/* =========================================================
   JOIN ICS GRAPHIC FINAL
   Uses HTML text with the illustration sitting on the right.
   ========================================================= */
body.membership-page .membership-join .join-panel.join-panel-graphic {
  position: relative;
  display: grid !important;
  grid-template-columns: minmax(0, .86fr) minmax(440px, .96fr) !important;
  grid-template-areas: "content note" !important;
  gap: clamp(2rem, 4vw, 3.8rem) !important;
  align-items: start !important;
  min-height: 560px;
  overflow: hidden;
  padding: clamp(2.6rem, 5vw, 4.2rem) !important;
  border-radius: 38px !important;
  border: 1px solid rgba(9, 48, 64, .07) !important;
  background:
    linear-gradient(90deg, rgba(240, 249, 250, .98) 0%, rgba(240, 249, 250, .92) 40%, rgba(240, 249, 250, .52) 60%, rgba(240, 249, 250, .16) 82%, rgba(240, 249, 250, 0) 100%),
    linear-gradient(180deg, rgba(239, 248, 249, .94) 0%, rgba(232, 245, 245, .94) 100%) !important;
  box-shadow: 0 24px 54px rgba(9, 48, 64, .06) !important;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(60%, 920px);
  height: 100%;
  background:
    linear-gradient(90deg, rgba(240, 249, 250, .82) 0%, rgba(240, 249, 250, .34) 22%, rgba(240, 249, 250, 0) 44%),
    url('../images/membership-join-graphic.png') right bottom / contain no-repeat;
  opacity: .98;
  pointer-events: none;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::after {
  content: "";
  position: absolute;
  left: clamp(2.6rem, 5vw, 4.2rem);
  top: clamp(24rem, 32vw, 33rem);
  width: 82px;
  height: 3px;
  border-radius: 999px;
  background: #78B8BF;
  pointer-events: none;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-content,
body.membership-page .membership-join .join-panel-graphic .join-panel-note {
  position: relative;
  z-index: 2;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-content {
  grid-area: content;
  max-width: 650px !important;
}

body.membership-page .membership-join .join-panel-graphic .section-eyebrow {
  display: inline-flex !important;
  margin: 0 0 clamp(1.8rem, 3vw, 2.5rem) !important;
  padding: .95rem 1.85rem !important;
  background: #78B8BF !important;
  border: 1px solid #78B8BF !important;
  color: #ffffff !important;
  font-size: 1.08rem !important;
  font-weight: 850 !important;
  box-shadow: 0 12px 24px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-join .join-panel-graphic h2 {
  max-width: 10.75ch !important;
  margin: 0 0 1.65rem !important;
  font-family: var(--ics-serif, "Libre Baskerville", serif) !important;
  font-size: clamp(3rem, 5.3vw, 5.05rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.055em;
  color: var(--ics-deep) !important;
}

body.membership-page .membership-join .join-panel-graphic > .join-panel-content > p {
  max-width: 34ch !important;
  margin: 0 0 1.9rem !important;
  color: #456477 !important;
  font-size: clamp(1.1rem, 1.35vw, 1.28rem) !important;
  line-height: 1.62 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

body.membership-page .membership-join .join-panel-graphic .join-actions .btn-ics-primary,
body.membership-page .membership-join .join-panel-graphic .join-actions .btn-ics-outline {
  padding: 1rem 1.55rem !important;
  border-radius: 16px !important;
  font-size: 1.05rem !important;
  min-width: 0 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note {
  grid-area: note;
  align-self: start;
  justify-self: stretch;
  margin-top: 0;
  max-width: 650px !important;
  min-height: 0 !important;
  padding: clamp(1.5rem, 2.5vw, 2rem) clamp(1.65rem, 3vw, 2.3rem) !important;
  border-radius: 26px !important;
  border: 1px solid rgba(9, 48, 64, .08) !important;
  background: rgba(255, 255, 255, .94) !important;
  box-shadow: 0 18px 34px rgba(9, 48, 64, .08) !important;
  backdrop-filter: blur(2px);
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note::after,
body.membership-page .membership-join .join-panel-graphic .join-panel-note::before {
  display: none !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note h3 {
  margin: 0 0 .55rem !important;
  color: var(--ics-deep) !important;
  font-family: var(--ics-sans, "Inter", sans-serif) !important;
  font-size: clamp(1.5rem, 2vw, 2rem) !important;
  line-height: 1.14 !important;
  letter-spacing: -.04em;
  font-weight: 850;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note p {
  max-width: none !important;
  margin: 0 0 1.15rem !important;
  color: #456477 !important;
  font-size: clamp(1rem, 1.2vw, 1.16rem) !important;
  line-height: 1.5 !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-link {
  display: inline-flex !important;
  align-items: center;
  gap: .65rem;
  margin: 0 !important;
  padding: .95rem 1.2rem !important;
  border-radius: 14px !important;
  border: 1px solid #78B8BF !important;
  background: #78B8BF !important;
  color: #ffffff !important;
  font-size: 1.04rem !important;
  font-weight: 600 !important;
  text-decoration: none;
  box-shadow: 0 12px 22px rgba(120, 184, 191, .22) !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-link:hover,
body.membership-page .membership-join .join-panel-graphic .join-panel-link:focus-visible {
  transform: translateY(-1px);
  background: #69aeb6 !important;
  border-color: #69aeb6 !important;
}

@media (max-width: 1199.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: minmax(0, .95fr) minmax(360px, .85fr) !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 56%;
    opacity: .72;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "content"
      "note" !important;
    min-height: 0;
    padding: 2rem 1.35rem 12rem !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 100%;
    height: 280px;
    opacity: .58;
    background-size: auto 100%;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::after {
    display: none;
  }

  body.membership-page .membership-join .join-panel-graphic h2 {
    max-width: 11ch !important;
  }

  body.membership-page .membership-join .join-panel-graphic .join-panel-note {
    align-self: stretch;
    margin-top: .4rem;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    border-radius: 28px !important;
    padding-bottom: 10.5rem !important;
  }

  body.membership-page .membership-join .join-panel-graphic .join-actions {
    flex-direction: column;
  }

  body.membership-page .membership-join .join-panel-graphic .join-actions a {
    width: 100%;
    justify-content: center;
  }
}


/* =========================================================
   JOIN ICS GRAPHIC REFINEMENT V2
   - use updated user-edited graphic
   - align artwork to the right
   - reduce heading scale
   ========================================================= */
body.membership-page .membership-join .join-panel.join-panel-graphic {
  grid-template-columns: minmax(0, .84fr) minmax(420px, .76fr) !important;
  gap: clamp(2rem, 3.8vw, 3rem) !important;
  min-height: 545px !important;
  padding: clamp(2.4rem, 4.2vw, 3.5rem) !important;
  background:
    linear-gradient(90deg, rgba(240,249,250,.98) 0%, rgba(240,249,250,.96) 36%, rgba(240,249,250,.90) 52%, rgba(240,249,250,.74) 64%, rgba(240,249,250,.54) 74%, rgba(240,249,250,.42) 100%),
    linear-gradient(180deg, rgba(239,248,249,.96) 0%, rgba(232,245,245,.95) 100%) !important;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::before {
  right: 0 !important;
  bottom: 0 !important;
  width: min(56%, 860px) !important;
  height: 100% !important;
  background:
    linear-gradient(90deg, rgba(240,249,250,.96) 0%, rgba(240,249,250,.68) 14%, rgba(240,249,250,.22) 28%, rgba(240,249,250,0) 42%),
    url('../images/membership-join-graphic.png') right bottom / contain no-repeat !important;
  opacity: 1 !important;
}

body.membership-page .membership-join .join-panel.join-panel-graphic::after {
  left: clamp(2.4rem, 4vw, 3.5rem) !important;
  top: auto !important;
  bottom: clamp(7.2rem, 10vw, 8.6rem) !important;
  width: 76px !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-content {
  max-width: 520px !important;
}

body.membership-page .membership-join .join-panel-graphic .section-eyebrow {
  margin-bottom: clamp(1.25rem, 2vw, 1.8rem) !important;
}

body.membership-page .membership-join .join-panel-graphic h2 {
  max-width: 8.4ch !important;
  font-size: clamp(2.8rem, 4.35vw, 4.35rem) !important;
  line-height: 1.03 !important;
  margin-bottom: 1.2rem !important;
}

body.membership-page .membership-join .join-panel-graphic > .join-panel-content > p {
  max-width: 26ch !important;
  font-size: clamp(1.02rem, 1.2vw, 1.16rem) !important;
  line-height: 1.58 !important;
  margin-bottom: 1.5rem !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note {
  justify-self: end !important;
  align-self: start !important;
  width: min(100%, 560px) !important;
  margin-top: .25rem !important;
}

body.membership-page .membership-join .join-panel-graphic .join-panel-note h3 {
  font-size: clamp(1.45rem, 1.9vw, 1.9rem) !important;
  line-height: 1.12 !important;
}

@media (max-width: 1199.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: minmax(0, .9fr) minmax(360px, .74fr) !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 54% !important;
  }

  body.membership-page .membership-join .join-panel-graphic h2 {
    font-size: clamp(2.65rem, 4.6vw, 3.9rem) !important;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: 1fr !important;
    padding-bottom: 15rem !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    width: 100% !important;
    height: 320px !important;
    background:
      linear-gradient(180deg, rgba(240,249,250,.38) 0%, rgba(240,249,250,0) 18%),
      linear-gradient(90deg, rgba(240,249,250,.94) 0%, rgba(240,249,250,.45) 34%, rgba(240,249,250,0) 64%),
      url('../images/membership-join-graphic.png') right bottom / auto 100% no-repeat !important;
  }

  body.membership-page .membership-join .join-panel-graphic .join-panel-note {
    justify-self: stretch !important;
    width: 100% !important;
  }
}
/* =========================================================
   JOIN ICS GRAPHIC ALIGNMENT FIX
   Aligns the edited graphic to the right edge of the panel
   and reduces the main heading size slightly.
   ========================================================= */

body.membership-page .membership-join .join-panel.join-panel-graphic {
  position: relative;
  overflow: hidden;
  min-height: 545px;
  grid-template-columns: minmax(0, .86fr) minmax(420px, .78fr) !important;
  background:
    linear-gradient(
      90deg,
      rgba(240, 249, 250, .98) 0%,
      rgba(240, 249, 250, .96) 36%,
      rgba(240, 249, 250, .88) 52%,
      rgba(240, 249, 250, .66) 66%,
      rgba(240, 249, 250, .42) 100%
    ),
    linear-gradient(180deg, #eff8f9 0%, #e8f5f5 100%) !important;
}

/* This is the graphic layer */
body.membership-page .membership-join .join-panel.join-panel-graphic::before {
  content: "";
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  background:
    linear-gradient(
      90deg,
      rgba(240, 249, 250, 1) 0%,
      rgba(240, 249, 250, .96) 34%,
      rgba(240, 249, 250, .75) 48%,
      rgba(240, 249, 250, .35) 62%,
      rgba(240, 249, 250, 0) 78%
    ),
    url("../images/membership-join-graphic.png") right bottom / auto 90% no-repeat !important;
  opacity: 1 !important;
  pointer-events: none;
  z-index: 1;
}

/* Keeps content above the graphic */
body.membership-page .membership-join .join-panel-content,
body.membership-page .membership-join .join-panel-note {
  position: relative;
  z-index: 2;
}

/* Smaller heading */
body.membership-page .membership-join .join-panel-graphic h2 {
  max-width: 9.5ch !important;
  font-size: clamp(2.65rem, 4vw, 4.1rem) !important;
  line-height: 1.04 !important;
}

/* Right-hand training card */
body.membership-page .membership-join .join-panel-graphic .join-panel-note {
  justify-self: end !important;
  align-self: start !important;
  width: min(100%, 560px) !important;
  margin-top: 0 !important;
}

/* Optional: move graphic slightly smaller/larger here */
@media (min-width: 1200px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    background:
      linear-gradient(
        90deg,
        rgba(240, 249, 250, 1) 0%,
        rgba(240, 249, 250, .96) 34%,
        rgba(240, 249, 250, .75) 48%,
        rgba(240, 249, 250, .35) 62%,
        rgba(240, 249, 250, 0) 78%
      ),
      url("../images/membership-join-graphic.png") right bottom / auto 92% no-repeat !important;
  }
}

@media (max-width: 991.98px) {
  body.membership-page .membership-join .join-panel.join-panel-graphic {
    grid-template-columns: 1fr !important;
    padding-bottom: 14rem !important;
  }

  body.membership-page .membership-join .join-panel.join-panel-graphic::before {
    background:
      linear-gradient(
        180deg,
        rgba(240, 249, 250, .2) 0%,
        rgba(240, 249, 250, 0) 30%
      ),
      linear-gradient(
        90deg,
        rgba(240, 249, 250, .96) 0%,
        rgba(240, 249, 250, .5) 42%,
        rgba(240, 249, 250, 0) 75%
      ),
      url("../images/membership-join-graphic.png") right bottom / auto 100% no-repeat !important;
    height: 320px !important;
    top: auto;
  }
}

/* Membership page CSS cleaned: global header/footer overrides have been moved out of this page file. */

/* =========================================================
   Membership + Training nav/footer stability fix
   Use at the bottom of membership.css and training.css, or keep
   as a small override loaded after both page stylesheets.
   ========================================================= */

/* Keep header layout consistent on Membership and Training */
body.membership-page .site-header,
body.training-page .site-header {
  background: #ffffff !important;
  background-color: #ffffff !important;
  border-bottom: 1px solid rgba(9, 48, 64, .08) !important;
  box-shadow: 0 2px 18px rgba(9, 48, 64, .10) !important;
  opacity: 1 !important;
  z-index: 1040 !important;
}

body.membership-page .site-header .navbar,
body.training-page .site-header .navbar,
body.membership-page .site-header .nav-wrap,
body.training-page .site-header .nav-wrap {
  background: #ffffff !important;
  background-color: #ffffff !important;
}

/* Desktop: one shared header rhythm */
@media (min-width: 992px) {
  body.membership-page .site-header .nav-wrap,
  body.training-page .site-header .nav-wrap {
    width: 100% !important;
    max-width: none !important;
    min-height: 108px !important;
    padding: .85rem clamp(8.75rem, 12vw, 14.25rem) .85rem clamp(8.75rem, 12vw, 14.25rem) !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: 2.35rem !important;
  }

  body.membership-page .site-header .brand-lockup,
  body.training-page .site-header .brand-lockup,
  body.membership-page .site-header .navbar-brand,
  body.training-page .site-header .navbar-brand {
    grid-column: 1 !important;
    justify-self: start !important;
    margin: 0 !important;
    gap: 0 !important;
  }

  body.membership-page .site-header .navbar-collapse,
  body.training-page .site-header .navbar-collapse {
    grid-column: 2 !important;
    justify-self: end !important;
    width: auto !important;
    display: flex !important;
    justify-content: flex-end !important;
  }

  body.membership-page .site-header .navbar-nav,
  body.training-page .site-header .navbar-nav,
  body.membership-page .site-header .main-nav-list,
  body.training-page .site-header .main-nav-list {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: clamp(1.15rem, 1.45vw, 1.65rem) !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }
}

/* Logo-only header, matching the rest of the cleaned site */
body.membership-page .site-header .brand-name,
body.training-page .site-header .brand-name {
  display: none !important;
}

body.membership-page .site-header img.brand-logo,
body.training-page .site-header img.brand-logo,
body.membership-page .site-header .brand-logo,
body.training-page .site-header .brand-logo {
  width: 96px !important;
  height: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  flex: 0 0 96px !important;
  display: block !important;
  transform: scale(1.08) !important;
  transform-origin: center center !important;
}

/* Nav text and active green underline */
body.membership-page .site-header .navbar .nav-link,
body.training-page .site-header .navbar .nav-link {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  color: #093040 !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  padding: .7rem 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

body.membership-page .site-header .navbar .nav-link:hover,
body.membership-page .site-header .navbar .nav-link:focus,
body.membership-page .site-header .navbar .nav-link.active,
body.membership-page .site-header .navbar .nav-link.is-current,
body.training-page .site-header .navbar .nav-link:hover,
body.training-page .site-header .navbar .nav-link:focus,
body.training-page .site-header .navbar .nav-link.active,
body.training-page .site-header .navbar .nav-link.is-current {
  color: #0FA644 !important;
}

body.membership-page .site-header .navbar .nav-link::after,
body.training-page .site-header .navbar .nav-link::after {
  content: none !important;
  display: none !important;
}

body.membership-page .site-header .navbar .nav-link.active::after,
body.membership-page .site-header .navbar .nav-link.is-current::after,
body.training-page .site-header .navbar .nav-link.active::after,
body.training-page .site-header .navbar .nav-link.is-current::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: .25rem !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: #0FA644 !important;
}

/* Header CTA */
body.membership-page .site-header .nav-cta,
body.training-page .site-header .nav-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 58px !important;
  padding: 1rem 1.45rem !important;
  border-radius: 12px !important;
  background: #0FA644 !important;
  color: #ffffff !important;
  border: 0 !important;
  box-shadow: 0 12px 24px rgba(15, 166, 68, .18) !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

body.membership-page .site-header .nav-cta:hover,
body.training-page .site-header .nav-cta:hover,
body.membership-page .site-header .nav-cta:focus,
body.training-page .site-header .nav-cta:focus {
  background: #0c933d !important;
  color: #ffffff !important;
}

/* Training footer visibility fix */
body.training-page .site-footer,
body.membership-page .site-footer {
  background: #3f4b58 !important;
  color: rgba(255, 255, 255, .82) !important;
}

body.training-page .site-footer .footer-column h2,
body.membership-page .site-footer .footer-column h2,
body.training-page .site-footer .footer-brand,
body.membership-page .site-footer .footer-brand,
body.training-page .site-footer .footer-brand strong,
body.membership-page .site-footer .footer-brand strong {
  color: #ffffff !important;
}

body.training-page .site-footer .footer-column a,
body.membership-page .site-footer .footer-column a,
body.training-page .site-footer .footer-column span,
body.membership-page .site-footer .footer-column span,
body.training-page .site-footer .footer-summary,
body.membership-page .site-footer .footer-summary {
  color: rgba(255, 255, 255, .82) !important;
}

body.training-page .site-footer .footer-column h2,
body.membership-page .site-footer .footer-column h2 {
  border-bottom-color: rgba(78, 166, 84, .72) !important;
  font-weight: 600 !important;
}

/* Tablet / mobile */
@media (max-width: 991.98px) {
  body.membership-page .site-header .nav-wrap,
  body.training-page .site-header .nav-wrap {
    min-height: 90px !important;
    padding: .7rem 1rem !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
  }

  body.membership-page .site-header img.brand-logo,
  body.training-page .site-header img.brand-logo,
  body.membership-page .site-header .brand-logo,
  body.training-page .site-header .brand-logo {
    width: 72px !important;
    height: 72px !important;
    min-width: 72px !important;
    max-width: 72px !important;
    flex-basis: 72px !important;
    transform: scale(1.04) !important;
  }

  body.membership-page .site-header .navbar-collapse,
  body.training-page .site-header .navbar-collapse {
    flex-basis: 100% !important;
    width: 100% !important;
    background: #ffffff !important;
  }

  body.membership-page .site-header .navbar-nav,
  body.training-page .site-header .navbar-nav,
  body.membership-page .site-header .main-nav-list,
  body.training-page .site-header .main-nav-list {
    width: 100% !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding-top: .8rem !important;
  }

  body.membership-page .site-header .navbar .nav-link,
  body.training-page .site-header .navbar .nav-link {
    padding: .75rem 0 !important;
  }

  body.membership-page .site-header .navbar .nav-link.active::after,
  body.membership-page .site-header .navbar .nav-link.is-current::after,
  body.training-page .site-header .navbar .nav-link.active::after,
  body.training-page .site-header .navbar .nav-link.is-current::after {
    display: none !important;
  }

  body.membership-page .site-header .nav-cta,
  body.training-page .site-header .nav-cta {
    width: 100% !important;
    margin-top: .5rem !important;
  }
}

@media (max-width: 575.98px) {
  body.membership-page .site-header img.brand-logo,
  body.training-page .site-header img.brand-logo,
  body.membership-page .site-header .brand-logo,
  body.training-page .site-header .brand-logo {
    width: 62px !important;
    height: 62px !important;
    min-width: 62px !important;
    max-width: 62px !important;
    flex-basis: 62px !important;
    transform: scale(1) !important;
  }

  body.membership-page .site-header .nav-wrap,
  body.training-page .site-header .nav-wrap {
    min-height: 82px !important;
  }
}

