:root {
  --primary: #1c6ea4;
  --primary-dark: #134e75;
  --accent: #2bb0a3;
  --accent-soft: #d8f0ec;
  --ink: #27313a;
  --muted: #637079;
  --surface: #ffffff;
  --background: #f3f7fa;
  --border: #d8e4ee;
}

html { font-size: 17px; }
body {
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 17px; line-height: 1.65; color: #27313a;
  background-color: #f3f7fa;
  display: flex; flex-direction: column; min-height: 100vh;
}
.site-main { flex: 1 0 auto; }
.page-container { max-width: 1100px; margin: 0 auto; padding: 2rem 1rem; }

h1, h2, h3, h4, h5, h6 { font-family: 'Montserrat', sans-serif; color: #1c6ea4; font-weight: 700; line-height: 1.25; }
h1, .page-title { font-size: 38px; font-weight: 700; margin: .4em 0 .5em; }
h2, .block-heading { font-size: 28px; font-weight: 600; }
h3 { font-size: 21px; font-weight: 600; }

/* ── Header / nav ───────────────────────────────────── */
.site-header { background: #fff; border-bottom: 3px solid #1c6ea4; }
.header-inner { max-width: 1100px; margin: 0 auto; padding: .6rem 1rem; display: flex; align-items: center; flex-wrap: wrap; }
.site-brand { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 1.35rem; color: #1c6ea4; text-decoration: none; display: flex; align-items: center; gap: .6rem; }
.site-logo { width: 44px; height: 44px; object-fit: contain; border-radius: 6px; }
.footer-logo { width: 36px; height: 36px; vertical-align: middle; margin-right: .5rem; }
.site-nav { margin-left: auto; }
.site-menu { display: flex; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; }
.site-menu .pure-menu-link { color: #27313a; font-weight: 600; padding: .5em .7em; }
.site-menu .pure-menu-link:hover { color: #1c6ea4; }
.nav-burger { display: none; font-size: 1.6rem; cursor: pointer; color: #1c6ea4; margin-left: auto; }
.nav-toggle-cb { display: none; }
@media (max-width: 768px) {
  .nav-burger { display: block; }
  .site-nav { flex-basis: 100%; }
  .site-menu { display: none; flex-direction: column; }
  .nav-toggle-cb:checked ~ .site-nav .site-menu { display: flex; }
}

/* ── Hero ───────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, rgba(28,110,164,.86) 0%, rgba(19,78,117,.9) 100%),
              url('/assets/images/img_bb9ca69b0494.png') center/cover no-repeat;
  color: #fff;
}

/* ── Generated-media bands ──────────────────────────── */
.media-band {
  position: relative; color: #fff; text-align: center;
  background: linear-gradient(rgba(19,78,117,.78), rgba(19,78,117,.82)),
              url('/assets/images/img_616545c230a9.png') center/cover no-repeat;
  padding: 54px 1rem;
}
.media-band h2 { color: #fff; }
.media-band p { color: #e3f0f8; max-width: 720px; margin: .6rem auto 1.4rem; }
.media-band .pure-button { background: #2bb0a3; color: #fff; border-radius: 24px; font-weight: 700; padding: .7em 2em; }
.media-band .pure-button:hover { background: #229387; }
.areas-figure { border-radius: 12px; overflow: hidden; margin: 1.5rem 0; }
.areas-figure img { width: 100%; height: auto; display: block; }
.hero-inner { max-width: 1100px; margin: 0 auto; padding: 56px 1rem 60px; text-align: center; }
.hero-title { color: #fff; font-size: 38px; margin-bottom: .3em; }
.hero-lead { color: #d4e6f2; font-size: 1.12rem; max-width: 700px; margin: 0 auto 1.4em; }
.hero-btn-primary { background: #2bb0a3; color: #fff; border-radius: 24px; margin: .3em; font-weight: 700; }
.hero-btn-primary:hover { background: #229387; }
.hero-btn-secondary { background: transparent; border: 2px solid #fff; color: #fff; border-radius: 24px; margin: .3em; font-weight: 700; }

/* ── Info / clinical cards ──────────────────────────── */
.info-cards { margin: 0 -.5rem 2rem; }
.info-card { background: #fff; border: 1px solid var(--border); border-top: 3px solid #2bb0a3; border-radius: 12px; padding: 1.2rem; margin: .5rem; text-align: center; }
.info-card .card-title a { color: #1c6ea4; text-decoration: none; }
.info-card:hover { border-color: #1c6ea4; }

/* ── Content ────────────────────────────────────────── */
.site-prose p, .block-paragraph { margin: 0 0 1.1em; }
.block-image, .article-main-image { max-width: 100%; height: auto; border-radius: 8px; margin: 1.1em 0; }
.article-summary { border-left: 4px solid #2bb0a3; background: #d8f0ec; padding: 1em 1.3em; border-radius: 0 8px 8px 0; }
.article-dates { color: #637079; font-size: .9rem; }
.block-quote { border-left: 4px solid #2bb0a3; padding-left: 1.2em; color: #637079; font-style: italic; }
.block-list { margin-left: 1.3em; } .block-list li { margin-bottom: .4em; }
.block-table { margin: 0; width: 100%; }
.block-table th { background: #e4f0f8; color: #1c6ea4; }
.block-list-item { padding: 1em 0; border-bottom: 1px solid var(--border); }
.list-item-title a { color: #1c6ea4; }

/* content body links — scoped, visible */
.site-prose a, .block-paragraph a, .block-list a {
  color: #1c6ea4; text-decoration: underline; text-decoration-color: rgba(28,110,164,.4);
}
.site-prose a:hover, .block-paragraph a:hover { color: #134e75; }

/* ── Breadcrumbs ────────────────────────────────────── */
.breadcrumb-bar { max-width: 1100px; margin: 0 auto; padding: .4rem 1rem; }
.breadcrumbs .pure-menu-link { color: #1c6ea4; }

/* ── Cards / category ───────────────────────────────── */
.cat-card, .card-minimal { background: #fff; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin: .5rem; }
.card-body { padding: 1rem; }
.card-title a, .horizontal-card h5 a, .card-minimal h5 a { color: #1c6ea4; }
.card-minimal { border-left: 3px solid #2bb0a3; padding: .9em 1.2em; }
.read-more-btn { background: #2bb0a3; color: #fff; font-weight: 700; }

/* ── ToC ────────────────────────────────────────────── */
.toc-box { background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 1em 1.2em; margin-bottom: 1.4em; }
.toc-box h6 { color: #1c6ea4; margin-top: 0; }
.toc-box a { color: #27313a; }
.toc-level-3 { padding-left: 1em; }

/* ── Footer ─────────────────────────────────────────── */
.site-footer { background: #134e75; color: #cfe2f0; padding: 32px 0 0; margin-top: 2rem; }
.footer-inner { max-width: 1100px; margin: 0 auto; padding: 0 1rem; }
.site-footer .footer-title { color: #fff; font-family: 'Montserrat', sans-serif; }
.site-footer a { color: #cfe2f0; }
.site-footer a:hover { color: #fff; }
.footer-links { list-style: none; padding: 0; }
.footer-copyright { background: rgba(0,0,0,.2); padding: .9em 0; margin-top: 1.4rem; text-align: center; }
