.discover-strip .section-heading,
.feature-mosaic .section-heading,
.ribbon-layout .section-heading,
.dual-column .section-heading,
.panel-cluster .section-heading,
.story-stream .section-heading,
.atlas-board .section-heading {
  align-items: flex-start !important;
  justify-content: flex-start !important;
  text-align: left !important;
}

.discover-strip .section-heading h2,
.feature-mosaic .section-heading h2,
.ribbon-layout .section-heading h2,
.dual-column .section-heading h2,
.panel-cluster .section-heading h2,
.story-stream .section-heading h2,
.atlas-board .section-heading h2,
.discover-strip .section-heading .eyebrow,
.feature-mosaic .section-heading .eyebrow,
.ribbon-layout .section-heading .eyebrow,
.dual-column .section-heading .eyebrow,
.panel-cluster .section-heading .eyebrow,
.story-stream .section-heading .eyebrow,
.atlas-board .section-heading .eyebrow,
.section-kicker {
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}

@media (min-width: 981px) {

  .discover-strip .section-heading h2,
  .feature-mosaic .section-heading h2,
  .ribbon-layout .section-heading h2,
  .dual-column .section-heading h2,
  .panel-cluster .section-heading h2,
  .story-stream .section-heading h2,
  .atlas-board .section-heading h2 {
    white-space: nowrap;
  }
}

.section-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  margin: 0 0 14px;
  width: 100%
}

.section-heading--light h2 {
  color: #fff
}

.section-heading h2 {
  max-width: none;
  line-height: 1.12;
  margin: 0;
  font-family: 'Merriweather', serif;
  font-size: clamp(30px, 4vw, 46px)
}

.section-heading .eyebrow {
  margin-bottom: 0
}

.section-kicker {
  max-width: none;
  margin: 0 0 18px;
  color: #52606d;
  line-height: 1.8;
}

.section-kicker--light {
  color: rgba(255, 255, 255, .84)
}

@media (min-width:981px) {
  .section-kicker {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

.section-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  margin: 0 0 14px
}

.section-heading h2 {
  max-width: 760px;
  line-height: 1.12
}

.section-heading .eyebrow {
  margin-bottom: 0
}

.section-kicker {
  max-width: 760px;
  margin: 0 0 18px;
  color: #52606d;
  line-height: 1.8
}

.section-kicker--light {
  color: rgba(255, 255, 255, .84)
}

.merit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 26px
}

.merit-tile {
  padding: 18px 20px;
  border-radius: 22px;
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(29, 107, 87, .1)
}

.merit-tile strong {
  display: block;
  margin-bottom: 8px;
  font-size: 17px
}

.merit-tile p,
.section-intro-card p {
  margin: 0;
  color: #52606d;
  line-height: 1.8
}

.insight-card__image {
  margin-top: 20px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .16)
}

.insight-card__image img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover
}

.section-intro-card {
  margin: 0 0 18px;
  padding: 16px 18px;
  border-left: 4px solid var(--brand);
  border-radius: 18px;
  background: rgba(255, 255, 255, .7)
}

.feature-card,
.ribbon-card,
.stack-card,
.nutri-card,
.routine-card,
.atlas-card {
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease
}

.feature-card:hover,
.ribbon-card:hover,
.stack-card:hover,
.nutri-card:hover,
.routine-card:hover,
.atlas-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 52px rgba(20, 31, 43, .16);
  border-color: rgba(29, 107, 87, .18)
}

.feature-card h3 a,
.ribbon-card h3 a,
.stack-card h3 a,
.nutri-card h3 a,
.routine-card h3 a,
.atlas-card h3 a {
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 0 1px;
  background-position: 0 100%;
  transition: background-size .25s ease
}

.feature-card h3 a:hover,
.ribbon-card h3 a:hover,
.stack-card h3 a:hover,
.nutri-card h3 a:hover,
.routine-card h3 a:hover,
.atlas-card h3 a:hover {
  background-size: 100% 1px
}

.routine-card {
  background: linear-gradient(90deg, #fffdf9 0%, #f7f1e7 100%)
}

@media (max-width:980px) {
  .merit-grid {
    grid-template-columns: 1fr
  }
}

.quick-search-note {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
  color: #596874
}

.quick-search-note span {
  font-weight: 800;
  color: var(--brand-dark)
}

.quick-search-note a {
  padding: 9px 14px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  font-size: 14px
}

.trust-band {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  padding: 6px 0 8px
}

.trust-band__item {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255, 255, 255, .74);
  border: 1px solid rgba(29, 107, 87, .08);
  box-shadow: var(--shadow)
}

.trust-band__item strong {
  display: block;
  margin-bottom: 8px;
  font-size: 18px
}

.trust-band__item p {
  margin: 0;
  color: #52606d;
  line-height: 1.8
}

@media (max-width:980px) {
  .trust-band {
    grid-template-columns: 1fr
  }
}


.cat-health-shell {
  display: grid;
  gap: 18px;
  padding: 6px 0 0
}

.cat-health-lead,
.cat-health-grid {
  display: grid;
  gap: 18px
}

.cat-health-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr))
}

.cat-hero-card {
  display: grid;
  grid-template-columns: minmax(300px, 1.05fr) minmax(0, 1fr);
  background: var(--paper);
  border: 1px solid rgba(26, 42, 56, .08);
  border-radius: 28px;
  box-shadow: var(--shadow);
  overflow: hidden
}

.cat-hero-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.cat-hero-card__body {
  padding: 28px 28px 24px
}

.cat-hero-card__body h3 {
  margin: 14px 0 12px;
  font-size: 34px;
  line-height: 1.14
}

.cat-hero-card__body p {
  color: #52606d;
  line-height: 1.85
}

.cat-grid-card {
  padding: 20px 20px 18px;
  background: linear-gradient(180deg, #fffdf9 0%, #f7f2e8 100%);
  border: 1px solid rgba(26, 42, 56, .08);
  border-radius: 24px;
  box-shadow: var(--shadow)
}

.cat-grid-card h3 {
  margin: 14px 0 10px;
  font-size: 22px;
  line-height: 1.24
}

.cat-grid-card p {
  margin: 0;
  color: #52606d;
  line-height: 1.8
}

@media (max-width:980px) {

  .cat-health-grid,
  .cat-hero-card {
    grid-template-columns: 1fr
  }
}

.card-thumb {
  border-radius: 20px;
  overflow: hidden;
  background: #e8e1d5;
  aspect-ratio: 16/10;
  margin-bottom: 16px
}

.card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.card-copy {
  display: block
}

.card-thumb--compact {
  width: 150px;
  min-width: 150px;
  aspect-ratio: 1/1;
  margin-bottom: 0
}

.ribbon-card,
.stack-card,
.nutri-card,
.atlas-card,
.result-card {
  overflow: hidden
}

.routine-card {
  grid-template-columns: 110px 150px 1fr auto
}

.cat-side-card {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  align-items: start
}

.cat-side-card .card-thumb {
  margin-bottom: 0;
  aspect-ratio: 1/1
}

.result-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 18px;
  align-items: start
}

.result-card .card-thumb {
  margin-bottom: 0
}

@media (max-width:980px) {
  .routine-card {
    grid-template-columns: 1fr
  }

  .card-thumb--compact {
    width: 100%;
    min-width: 0;
    margin-bottom: 14px
  }

  .cat-side-card,
  .result-card {
    grid-template-columns: 1fr
  }
}


.utility-link--input {
  min-width: 300px;
  font: inherit;
  color: var(--ink);
  outline: none
}

.utility-link--input::placeholder {
  color: #7a8792
}

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

.section-intro-card--compact {
  max-width: 880px;
  margin-bottom: 20px
}

.atlas-board__grid--balanced {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch
}

.atlas-board__grid--balanced .atlas-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 18px 18px 20px
}

.atlas-board__grid--balanced .atlas-card .card-thumb {
  aspect-ratio: 16/10;
  margin-bottom: 14px
}

.atlas-board__grid--balanced .atlas-card h3 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 56px
}

.atlas-board__grid--balanced .atlas-card p {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 86px
}

.atlas-board__grid--balanced .atlas-card .micro-btn {
  margin-top: auto
}

.atlas-board__grid--balanced .atlas-card--tall {
  grid-row: auto
}

@media (max-width:980px) {
  .atlas-board__grid--balanced {
    grid-template-columns: 1fr 1fr
  }
}

@media (max-width:640px) {
  .atlas-board__grid--balanced {
    grid-template-columns: 1fr
  }
}

@media (max-width:980px) {
  .utility-link--input {
    min-width: 100%
  }
}

.search-inline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto
}

.search-inline__button {
  height: 46px;
  padding: 0 18px;
  border: none;
  border-radius: 999px;
  background: var(--brand);
  color: #fff;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--shadow)
}

.search-inline__button:hover {
  background: var(--brand-dark)
}

@media (max-width:980px) {
  .search-inline {
    width: 100%
  }

  .search-inline__button {
    flex: 0 0 auto
  }
}

.editorial-footer {
  display: grid;
  grid-template-columns: minmax(260px, .95fr) minmax(0, 1.15fr) minmax(220px, .7fr);
  gap: 30px;
  align-items: start
}

.editorial-footer__intro p {
  margin: 14px 0 0;
  color: #4d5c68;
  line-height: 1.8;
  max-width: 420px
}

.editorial-footer__links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px
}

.editorial-footer__links h3 {
  margin: 0 0 10px;
  font-family: 'Merriweather', serif;
  font-size: 18px
}

.editorial-footer__links a {
  display: block;
  margin: 0 0 9px;
  color: #4d5c68
}

.editorial-footer__eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--brand);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 11px;
  font-weight: 800
}

.editorial-footer__aside {
  padding: 16px 18px;
  border-left: 3px solid rgba(29, 107, 87, .18);
  background: rgba(255, 255, 255, .4);
  border-radius: 18px
}

.editorial-footer__aside p {
  margin: 0;
  color: #52606d;
  line-height: 1.8
}

.editorial-footer__base {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding-top: 16px;
  margin-top: 22px;
  border-top: 1px solid var(--line);
  color: #61707d;
  font-size: 13px
}

.editorial-footer__base p {
  margin: 0
}

@media (max-width:980px) {

  .editorial-footer,
  .editorial-footer__links {
    grid-template-columns: 1fr
  }

  .editorial-footer__base {
    display: grid;
    grid-template-columns: 1fr
  }

  .editorial-footer__aside {
    border-left: none;
    border-top: 3px solid rgba(29, 107, 87, .18)
  }
}

.site-shell {
  box-shadow: 0 10px 30px rgba(20, 31, 43, .06)
}

.topbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 18px 0
}

.prime-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  font-weight: 600;
  min-width: 0;
  justify-self: center
}

.prime-nav a {
  position: relative;
  color: #556371;
  transition: color .2s ease;
  white-space: nowrap
}

.prime-nav a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -5px;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: var(--brand);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .2s ease
}

.prime-nav a:hover::after {
  transform: scaleX(1)
}

.search-inline {
  gap: 8px;
  flex: 0 0 auto
}

.utility-link--input {
  min-width: 220px;
  max-width: 220px;
  height: 42px;
  padding: 0 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .5)
}

.search-inline__button {
  height: 42px;
  padding: 0 14px;
  font-size: 13px;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease
}

.search-inline__button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(17, 73, 59, .16)
}

.info-layout,
.search-layout,
.article-layout {
  padding: 64px 0 84px
}

.info-layout .wrap,
.search-layout .wrap,
.article-layout .wrap {
  width: min(980px, calc(100% - 40px))
}

.info-page,
.search-shell,
.article-shell {
  padding: 38px 40px;
  border-radius: 28px
}

.info-page h1,
.search-shell h1,
.article-shell h1 {
  margin: 0 0 16px;
  font-family: 'Merriweather', serif;
  font-size: clamp(34px, 4.5vw, 48px);
  line-height: 1.12;
  letter-spacing: -.02em
}

.info-page p,
.search-shell p,
.article-shell p,
.article-shell li {
  font-size: 16px;
  line-height: 1.9
}

.crumb {
  margin-bottom: 18px
}

.deep-footer {
  margin-top: 50px;
  padding: 40px 0 26px
}

.editorial-footer {
  gap: 28px
}

.editorial-footer__links {
  gap: 20px
}

.editorial-footer__links a {
  transition: color .2s ease, transform .2s ease
}

.editorial-footer__links a:hover {
  color: var(--brand);
  transform: translateX(2px)
}

.editorial-footer__aside {
  box-shadow: 0 10px 24px rgba(20, 31, 43, .05)
}

.editorial-footer__base {
  margin-top: 20px;
  padding-top: 16px
}

@media (max-width:980px) {
  .topbar {
    display: flex;
    flex-wrap: wrap;
    gap: 14px
  }

  .prime-nav {
    order: 3;
    width: 100%;
    justify-content: center;
    gap: 12px;
    font-size: 13px
  }

  .search-inline {
    width: auto;
    margin-left: auto
  }

  .utility-link--input {
    min-width: 180px;
    max-width: 180px;
    flex: 0 0 180px
  }

  .info-layout,
  .search-layout,
  .article-layout {
    padding: 52px 0 72px
  }

  .info-page,
  .search-shell,
  .article-shell {
    padding: 30px 24px
  }
}

.mobile-chrome__toggle,
.mobile-drawer {
  display: none
}

.mobile-chrome__toggle {
  position: relative;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
  cursor: pointer
}

.mobile-chrome__icon {
  position: relative;
  display: block;
  width: 18px;
  height: 14px
}

.mobile-chrome__icon--menu {
  background: linear-gradient(var(--ink), var(--ink)) center 6px/18px 2px no-repeat
}

.mobile-chrome__icon--menu::before,
.mobile-chrome__icon--menu::after {
  content: '';
  position: absolute;
  left: 0;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: var(--ink)
}

.mobile-chrome__icon--menu::before {
  top: 0
}

.mobile-chrome__icon--menu::after {
  bottom: 0
}

.mobile-chrome__icon--search {
  width: 18px;
  height: 18px
}

.mobile-chrome__icon--search::before,
.mobile-chrome__icon--search::after {
  content: '';
  position: absolute
}

.mobile-chrome__icon--search::before {
  left: 1px;
  top: 1px;
  width: 10px;
  height: 10px;
  border: 2px solid var(--ink);
  border-radius: 50%
}

.mobile-chrome__icon--search::after {
  right: 1px;
  bottom: 2px;
  width: 7px;
  height: 2px;
  border-radius: 999px;
  background: var(--ink);
  transform: rotate(45deg);
  transform-origin: center center
}

.mobile-drawer {
  border-top: 1px solid rgba(17, 73, 59, .08);
  background: rgba(248, 245, 239, .96);
  height: 100vh;
}

.mobile-drawer__inner {
  padding: 14px 0 18px
}

.mobile-nav {
  display: grid;
  gap: 10px
}

.mobile-nav a {
  display: block;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, .74);
  border: 1px solid rgba(29, 107, 87, .08);
  font-weight: 700;
  color: #43515e
}

.mobile-drawer.is-open {
  display: block
}

@media (max-width:640px) {
  .site-shell {
    overflow: clip
  }

  .topbar {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    align-items: center;
    gap: 10px;
    padding: 14px 0
  }

  .topbar>.prime-nav,
  .topbar>.search-inline {
    display: none !important
  }

  .mobile-chrome__toggle {
    display: inline-flex
  }

  .brandmark {
    justify-self: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    max-width: 100%;
    font-size: 14px;
    gap: 8px;
    text-align: center
  }

  .brandmark span:last-child {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
  }

  .brandmark__seal {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    flex: 0 0 auto
  }

  .mobile-chrome__toggle--menu {
    grid-column: 1;
    justify-self: start
  }

  .mobile-chrome__toggle--search {
    grid-column: 3;
    justify-self: end
  }

  .search-inline--mobile {
    display: flex;
    gap: 8px;
    flex-wrap: nowrap
  }

  .search-inline--mobile .utility-link--input {
    min-width: 0;
    max-width: none;
    flex: 1
  }

  .search-inline--mobile .search-inline__button {
    width: auto;
    flex: 0 0 auto
  }

  .info-layout .wrap,
  .search-layout .wrap,
  .article-layout .wrap {
    width: min(100% - 24px, 980px)
  }

  .info-page,
  .search-shell,
  .article-shell {
    padding: 24px 18px
  }

  .info-page h1,
  .search-shell h1,
  .article-shell h1 {
    font-size: 32px
  }

  .deep-footer {
    margin-top: 38px;
    padding: 34px 0 24px
  }

  .editorial-footer {
    gap: 18px
  }

  .editorial-footer__intro p {
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.75
  }

  .editorial-footer__links {
    gap: 14px
  }

  .editorial-footer__links>div {
    padding: 16px 16px 14px;
    border: 1px solid rgba(29, 107, 87, .1);
    border-radius: 18px;
    background: rgba(255, 255, 255, .55)
  }

  .editorial-footer__links h3 {
    margin-bottom: 8px;
    font-size: 16px
  }

  .editorial-footer__links a {
    margin: 0;
    padding: 10px 0;
    font-size: 14px;
    line-height: 1.5
  }

  .editorial-footer__aside {
    padding: 14px 16px;
    border-radius: 18px
  }

  .editorial-footer__aside p {
    font-size: 14px;
    line-height: 1.75
  }

  .editorial-footer__base {
    margin-top: 18px;
    padding-top: 14px;
    gap: 8px;
    text-align: center
  }

  .editorial-footer__base p {
    font-size: 12px;
    line-height: 1.6
  }

  .deep-footer .brandmark {
    justify-self: start;
    justify-content: flex-start;
    text-align: left
  }
}





:root {
  --bg: #f6f2eb;
  --paper: #fffdf9;
  --ink: #1f2933;
  --muted: #61707d;
  --line: #dfd7cb;
  --brand: #1d6b57;
  --brand-dark: #11493b;
  --sand: #efe6d8;
  --accent: #cb7c45;
  --night: #17222e;
  --radius: 24px;
  --shadow: 0 18px 45px rgba(20, 31, 43, .12)
}

* {
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  margin: 0;
  font-family: 'Manrope', sans-serif;
  background: linear-gradient(180deg, #f8f5ef 0%, #f3ede2 100%);
  color: var(--ink)
}

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

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

.wrap {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto
}

.site-shell {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(248, 245, 239, .9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(17, 73, 59, .08)
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0
}

.brandmark {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  letter-spacing: -.03em
}

.brandmark__seal {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--brand), #49a387);
  color: #fff;
  box-shadow: var(--shadow)
}

.prime-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  color: var(--muted);
  font-size: 14px
}

.prime-nav a:hover,
.utility-link:hover {
  color: var(--brand)
}

.utility-link {
  padding: 11px 18px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper)
}

.welcome-panel {
  padding: 56px 0 28px
}

.welcome-panel__grid {
  display: grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 28px;
  align-items: stretch
}

.welcome-panel h1 {
  font-family: 'Merriweather', serif;
  font-size: clamp(40px, 6vw, 68px);
  line-height: 1.06;
  margin: 0 0 18px
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--brand);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  font-weight: 800
}

.lead-copy {
  max-width: 760px;
  font-size: 18px;
  line-height: 1.8;
  color: #334250
}

.welcome-panel__actions,
.cred-list {
  display: flex;
  flex-wrap: wrap;
  gap: 14px
}

.welcome-panel__actions {
  margin: 26px 0
}

.cta-main,
.cta-alt {
  padding: 15px 22px;
  border-radius: 999px;
  font-weight: 700
}

.cta-main {
  background: var(--brand);
  color: #fff
}

.cta-alt {
  background: var(--paper);
  border: 1px solid var(--line)
}

.cred-list {
  list-style: none;
  padding: 0;
  margin: 0;
  color: var(--muted);
  font-size: 14px
}

.cred-list li {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(29, 107, 87, .08)
}

.insight-card,
.feature-card,
.ribbon-card,
.stack-card,
.nutri-card,
.routine-card,
.atlas-card,
.info-page,
.search-shell,
.article-shell {
  background: var(--paper);
  border: 1px solid rgba(26, 42, 56, .08);
  border-radius: var(--radius);
  box-shadow: var(--shadow)
}

.insight-card {
  padding: 28px;
  background: linear-gradient(180deg, #1b6c58, #11493b);
  color: #fff
}

.insight-card__label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .18em;
  opacity: .78
}

.signal-stack {
  display: grid;
  gap: 14px;
  margin-top: 24px
}

.signal-stack article {
  padding: 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, .1)
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin: 0 0 22px
}

.section-heading h2 {
  margin: 0;
  font-family: 'Merriweather', serif;
  font-size: clamp(28px, 4vw, 42px)
}

.section-heading--light {
  color: #fff
}

.discover-strip,
.feature-mosaic,
.dual-column,
.panel-cluster,
.story-stream,
.atlas-board {
  padding: 32px 0 18px
}

.topic-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px
}

.topic-pills a {
  padding: 12px 18px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: var(--muted)
}

.feature-mosaic__stage {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 18px
}

.feature-card {
  padding: 18px
}

.feature-card--hero {
  grid-row: span 2;
  padding: 0;
  overflow: hidden
}

.feature-card__media {
  aspect-ratio: 16/11;
  background: #ddd
}

.feature-card__body {
  padding: 20px
}

.feature-card__tag,
.ribbon-card__tag,
.stack-card__tag,
.nutri-card__tag,
.routine-card__tag,
.atlas-card__tag {
  display: inline-flex;
  padding: 7px 11px;
  border-radius: 999px;
  background: var(--sand);
  color: var(--brand-dark);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase
}

.feature-card h3,
.ribbon-card h3,
.stack-card h3,
.nutri-card h3,
.routine-card h3,
.atlas-card h3 {
  margin: 14px 0 10px;
  font-size: 22px;
  line-height: 1.25
}

.feature-card p,
.ribbon-card p,
.stack-card p,
.nutri-card p,
.routine-card p,
.atlas-card p,
.info-page p,
.article-shell p,
.article-shell li {
  color: #52606d;
  line-height: 1.8
}

.ribbon-layout {
  padding: 42px 0;
  background: linear-gradient(135deg, #17222e, #24384c)
}

.ribbon-layout__track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px
}

.ribbon-card {
  padding: 18px;
  background: rgba(255, 255, 255, .96)
}

.dual-column__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px
}

.stack-card {
  padding: 20px
}

.stack-card__items {
  display: grid;
  gap: 16px
}

.panel-cluster__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px
}

.nutri-card {
  padding: 22px;
  background: linear-gradient(180deg, #fffdf9, #f5efe5)
}

.story-stream__list {
  display: grid;
  gap: 16px
}

.routine-card {
  padding: 18px 22px;
  display: grid;
  grid-template-columns: 170px 1fr auto;
  gap: 18px;
  align-items: center
}

.routine-card__index {
  font-size: 34px;
  font-weight: 800;
  color: var(--brand)
}

.atlas-board__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 18px
}

.atlas-card {
  padding: 18px
}

.atlas-card--tall {
  grid-row: span 2
}

.deep-footer {
  margin-top: 44px;
  padding: 44px 0 70px;
  background: #efe6d8;
  border-top: 1px solid var(--line)
}

.deep-footer__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: 26px
}

.deep-footer h3 {
  margin: 0 0 12px
}

.deep-footer a {
  display: block;
  margin: 0 0 10px;
  color: #4d5c68
}

.info-layout,
.search-layout,
.article-layout {
  padding: 48px 0 72px
}

.info-page,
.search-shell,
.article-shell {
  padding: 28px
}

.crumb {
  display: inline-flex;
  gap: 8px;
  color: var(--brand);
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 14px
}

.search-results {
  display: grid;
  gap: 14px;
  margin-top: 18px
}

.result-card {
  padding: 18px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--line)
}

.article-hero {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 24px;
  margin-bottom: 20px
}

.article-frame--stacked {
  max-width: 1320px
}

.article-hero--stacked {
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: start;
  margin-bottom: 44px;
  padding: 0
}

.article-hero__copy--stacked {
  max-width: none;
  padding-right: 0
}

.article-hero__copy--stacked h1 {
  max-width: none;
  font-size: clamp(46px, 5.4vw, 68px);
  line-height: 1.01;
  letter-spacing: -.045em
}

.article-hero__copy--stacked .lead-copy {
  max-width: 72ch;
  font-size: 20px;
  line-height: 1.9;
  color: #3e4d59
}

.article-hero__media--stacked .article-cover {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 32px;
  aspect-ratio: 16/7;
  object-fit: cover;
  box-shadow: 0 28px 60px rgba(20, 31, 43, .14)
}

.article-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 860px) 180px;
  gap: 56px;
  align-items: start;
  justify-content: space-between
}

.article-sidebar {
  position: relative;
  order: 2
}

.article-panel {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none
}

.article-panel--nav {
  position: sticky;
  top: 110px;
  padding: 6px 0 0
}

.article-panel__label {
  margin: 0 0 12px;
  color: var(--brand);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 11px;
  font-weight: 800
}

.article-nav {
  display: grid;
  gap: 6px
}

.article-nav a {
  display: block;
  padding: 10px 0;
  border-radius: 0;
  color: #4d5d68;
  font-weight: 700;
  line-height: 1.45;
  border-bottom: 1px solid rgba(29, 107, 87, .08);
  transition: color .2s ease, transform .2s ease
}

.article-nav a:hover {
  background: transparent;
  color: var(--brand);
  transform: translateX(2px)
}

.article-main {
  display: grid;
  gap: 34px;
  order: 1
}

.article-panel--content {
  padding: 0
}

.article-panel--recommended {
  padding: 20px 0 0;
  border-top: 1px solid rgba(29, 107, 87, .12)
}

.article-panel__head {
  margin-bottom: 16px
}

.article-panel__head h2 {
  margin: 0;
  font-family: 'Merriweather', serif;
  font-size: 30px;
  line-height: 1.2
}

.recommended-list {
  display: grid;
  gap: 18px
}

.recommended-card {
  display: grid;
  grid-template-columns: 192px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 14px 0
}

.recommended-card+.recommended-card {
  border-top: 1px solid rgba(29, 107, 87, .1)
}

.recommended-card__media img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 20px
}

.recommended-card__copy h3 {
  margin: 10px 0 8px;
  font-size: 24px;
  line-height: 1.26
}

.recommended-card__copy p {
  margin: 0;
  color: #52606d;
  line-height: 1.78
}

.article-body--editorial {
  max-width: none
}

.article-body--editorial h2 {
  scroll-margin-top: 120px;
  margin: 46px 0 16px;
  font-size: 32px
}

.article-body--editorial p {
  margin: 0 0 22px;
  font-size: 18px;
  line-height: 2;
  color: #41505c
}

.article-body--editorial p:first-child {
  font-size: 21px;
  line-height: 1.95;
  color: #2f3c47
}

@media (max-width:1100px) {
  .article-detail-grid {
    grid-template-columns: minmax(0, 1fr) 170px;
    gap: 30px
  }

  .article-hero__copy--stacked {
    max-width: none;
    padding-right: 0
  }

  .article-hero__copy--stacked h1 {
    max-width: none
  }

  .recommended-card {
    grid-template-columns: 160px minmax(0, 1fr)
  }
}

@media (max-width:820px) {
  .article-detail-grid {
    grid-template-columns: 1fr;
    gap: 26px
  }

  .article-sidebar,
  .article-main {
    order: initial
  }

  .article-panel--nav {
    position: static;
    padding-top: 0
  }

  .article-nav a {
    padding: 12px 0
  }

  .article-hero--stacked {
    margin-bottom: 28px
  }

  .article-hero__media--stacked .article-cover {
    aspect-ratio: 16/9
  }
}

@media (max-width:640px) {
  .wrap {
    width: min(100% - 24px, 1180px)
  }

  .welcome-panel__grid{
    display: flex;
    flex-wrap: wrap;
  }

  .dual-column__grid{
    grid-template-columns:1fr
  }


  .panel-cluster__grid{
    grid-template-columns:1fr
  }

  .routine-card{
    grid-template-columns: 1fr
  }

  .ribbon-layout__track {
    grid-template-columns: 1fr
  }

  .atlas-board__grid{
    grid-template-columns: 1fr;
  }

  .deep-footer h3{
    text-align: center;
  }

  .deep-footer a{
    text-align: center;
  }

  .deep-footer a{
    /* display: flex; */
  }

  .welcome-panel h1 {
    font-size: 38px
  }

  .section-heading {
    align-items: start;
    flex-direction: column
  }

  .article-shell {
    padding: 24px 18px
  }

  .crumb--article {
    margin-bottom: 20px;
    font-size: 12px
  }

  .article-hero--stacked {
    gap: 18px;
    margin-bottom: 24px
  }

  .article-hero__copy--stacked h1 {
    font-size: 34px;
    line-height: 1.08
  }

  .article-hero__copy--stacked .lead-copy {
    font-size: 17px;
    line-height: 1.8
  }

  .article-hero__media--stacked .article-cover {
    border-radius: 24px;
    aspect-ratio: 16/10
  }

  .article-detail-grid {
    gap: 18px
  }

  .article-panel__head h2 {
    font-size: 24px
  }

  .recommended-card {
    grid-template-columns: 1fr;
    gap: 12px
  }

  .article-body--editorial h2 {
    margin: 34px 0 14px;
    font-size: 26px
  }

  .article-body--editorial p {
    font-size: 16px;
    line-height: 1.9
  }
}