/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font: 400 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: #111; background-color: #fdfdfd; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; display: flex; min-height: 100vh; flex-direction: column; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** `main` element */
main { display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */ }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-weight: 400; }

/** Links */
a { color: #2a7ae2; text-decoration: none; }
a:visited { color: #1756a9; }
a:hover { color: #111; text-decoration: underline; }
.social-media-list a:hover { text-decoration: none; }
.social-media-list a:hover .username { text-decoration: underline; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }
blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }
pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }
@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.wrapper:after, .footer-col-wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.svg-icon { width: 16px; height: 16px; display: inline-block; fill: #828282; padding-right: 5px; vertical-align: text-top; }

.social-media-list li + li { padding-top: 5px; }

/** Tables */
table { margin-bottom: 30px; width: 100%; text-align: left; color: #3f3f3f; border-collapse: collapse; border: 1px solid #e8e8e8; }
table tr:nth-child(even) { background-color: #f7f7f7; }
table th, table td { padding: 10px 15px; }
table th { background-color: #f0f0f0; border: 1px solid #dedede; border-bottom-color: #c9c9c9; }
table td { border: 1px solid #e8e8e8; }

/** Site header */
.site-header { border-top: 5px solid #424242; border-bottom: 1px solid #e8e8e8; min-height: 55.95px; position: relative; }

.site-title { font-size: 26px; font-weight: 300; line-height: 54px; letter-spacing: -1px; margin-bottom: 0; float: left; }
.site-title, .site-title:visited { color: #424242; }

.site-nav { float: right; line-height: 54px; }
.site-nav .nav-trigger { display: none; }
.site-nav .menu-icon { display: none; }
.site-nav .page-link { color: #111; line-height: 1.5; }
.site-nav .page-link:not(:last-child) { margin-right: 20px; }
@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 15px; background-color: #fdfdfd; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; }
  .site-nav label[for="nav-trigger"] { display: block; float: right; width: 36px; height: 36px; z-index: 2; cursor: pointer; }
  .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; }
  .site-nav .menu-icon > svg { fill: #424242; }
  .site-nav input ~ .trigger { clear: both; display: none; }
  .site-nav input:checked ~ .trigger { display: block; padding-bottom: 5px; }
  .site-nav .page-link { display: block; padding: 5px 10px; margin-left: 20px; }
  .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; padding: 30px 0; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(20% - (30px / 2)); width: calc(20% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(45% - (30px / 2)); width: calc(45% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); }
  .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
@media screen and (max-width: 600px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
/** Page content */
.page-content { padding: 30px 0; flex: 1; }

.page-heading { font-size: 32px; }

.post-list-heading { font-size: 28px; }

.post-list { margin-left: 0; list-style: none; }
.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { font-size: 42px; letter-spacing: -1px; line-height: 1; }
@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }
.post-content h2 { font-size: 32px; }
@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }
.post-content h3 { font-size: 26px; }
@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }
.post-content h4 { font-size: 20px; }
@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Syntax highlighting styles */
.highlight { background: #fff; }
.highlighter-rouge .highlight { background: #eef; }
.highlight .c { color: #998; font-style: italic; }
.highlight .err { color: #a61717; background-color: #e3d2d2; }
.highlight .k { font-weight: bold; }
.highlight .o { font-weight: bold; }
.highlight .cm { color: #998; font-style: italic; }
.highlight .cp { color: #999; font-weight: bold; }
.highlight .c1 { color: #998; font-style: italic; }
.highlight .cs { color: #999; font-weight: bold; font-style: italic; }
.highlight .gd { color: #000; background-color: #fdd; }
.highlight .gd .x { color: #000; background-color: #faa; }
.highlight .ge { font-style: italic; }
.highlight .gr { color: #a00; }
.highlight .gh { color: #999; }
.highlight .gi { color: #000; background-color: #dfd; }
.highlight .gi .x { color: #000; background-color: #afa; }
.highlight .go { color: #888; }
.highlight .gp { color: #555; }
.highlight .gs { font-weight: bold; }
.highlight .gu { color: #aaa; }
.highlight .gt { color: #a00; }
.highlight .kc { font-weight: bold; }
.highlight .kd { font-weight: bold; }
.highlight .kp { font-weight: bold; }
.highlight .kr { font-weight: bold; }
.highlight .kt { color: #458; font-weight: bold; }
.highlight .m { color: #099; }
.highlight .s { color: #d14; }
.highlight .na { color: #008080; }
.highlight .nb { color: #0086B3; }
.highlight .nc { color: #458; font-weight: bold; }
.highlight .no { color: #008080; }
.highlight .ni { color: #800080; }
.highlight .ne { color: #900; font-weight: bold; }
.highlight .nf { color: #900; font-weight: bold; }
.highlight .nn { color: #555; }
.highlight .nt { color: #000080; }
.highlight .nv { color: #008080; }
.highlight .ow { font-weight: bold; }
.highlight .w { color: #bbb; }
.highlight .mf { color: #099; }
.highlight .mh { color: #099; }
.highlight .mi { color: #099; }
.highlight .mo { color: #099; }
.highlight .sb { color: #d14; }
.highlight .sc { color: #d14; }
.highlight .sd { color: #d14; }
.highlight .s2 { color: #d14; }
.highlight .se { color: #d14; }
.highlight .sh { color: #d14; }
.highlight .si { color: #d14; }
.highlight .sx { color: #d14; }
.highlight .sr { color: #009926; }
.highlight .s1 { color: #d14; }
.highlight .ss { color: #990073; }
.highlight .bp { color: #999; }
.highlight .vc { color: #008080; }
.highlight .vg { color: #008080; }
.highlight .vi { color: #008080; }
.highlight .il { color: #099; }

:root { --ink: #17202a; --heading: #10233f; --muted: #52606d; --line: #d9e2ec; --line-strong: #b9c7d5; --surface: #f6f8fb; --surface-strong: #eef5f6; --surface-warm: #fff8ea; --card: #ffffff; --accent: #0f766e; --accent-strong: #115e59; --accent-soft: #dff4ef; --blue: #1d4ed8; --green: #2f7d32; --gold: #a26313; --focus: #f59e0b; --shadow: 0 16px 38px rgba(16, 35, 63, 0.08); }

* { box-sizing: border-box; }

body { color: var(--ink); background: var(--surface); font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }

a { color: var(--accent-strong); }

a:hover { color: var(--blue); }

a:focus-visible, button:focus-visible, input:focus-visible, summary:focus-visible { outline: 3px solid var(--focus); outline-offset: 3px; }

.wrapper { max-width: 1180px; }

.site-header { border-top: 4px solid var(--accent); border-bottom: 1px solid var(--line); background: rgba(255, 255, 255, 0.96); }

.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; min-height: 76px; }

.site-title, .site-title:visited { display: grid; gap: 2px; color: var(--heading); font-weight: 800; line-height: 1.1; text-decoration: none; }

.site-title:hover { text-decoration: none; }

.site-title__main { font-size: 1.02rem; }

.site-title__byline { color: var(--muted); font-size: 0.78rem; font-weight: 650; }

.site-header .site-nav { position: static; float: none; border: 0; background: transparent; line-height: 1; }

.site-nav .nav-trigger { position: absolute; opacity: 0; pointer-events: none; }

.nav-toggle { display: none; }

.nav-menu { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 5px; }

.site-nav .page-link { margin-left: 0; padding: 9px 10px; border-radius: 999px; color: var(--heading); font-size: 0.92rem; font-weight: 700; line-height: 1; text-decoration: none; }

.site-nav .page-link:hover, .site-nav .page-link.is-active { background: var(--accent-soft); color: var(--accent-strong); }

.language-switch { display: inline-flex; gap: 4px; margin-left: 6px; padding: 3px; border: 1px solid var(--line); border-radius: 999px; background: #ffffff; }

.language-switch__link { min-width: 76px; padding: 7px 8px; border-radius: 999px; color: var(--muted); font-size: 0.78rem; font-weight: 800; line-height: 1; text-align: center; text-decoration: none; white-space: nowrap; }

.language-switch__link:hover, .language-switch__link.is-active { background: var(--heading); color: #ffffff; text-decoration: none; }

.page-content { padding: 42px 0 64px; }

.post, .post-detail { max-width: 980px; margin-right: auto; margin-left: auto; }

.post-header { margin-bottom: 22px; }

.post-title { max-width: 920px; margin-bottom: 14px; color: var(--heading); font-size: 2.6rem; font-weight: 850; letter-spacing: 0; line-height: 1.08; }

.page-lede, .archive-intro { max-width: 820px; color: var(--muted); font-size: 1.08rem; line-height: 1.7; }

.hero { display: grid; grid-template-columns: minmax(0, 1.22fr) minmax(280px, 0.78fr); gap: 32px; align-items: stretch; padding: 48px; border: 1px solid var(--line); border-radius: 8px; background: linear-gradient(135deg, rgba(15, 118, 110, 0.12), rgba(29, 78, 216, 0.06) 58%, rgba(162, 99, 19, 0.1)), #ffffff; box-shadow: var(--shadow); }

.hero h1 { max-width: 820px; margin: 0 0 16px; color: var(--heading); font-size: 4.1rem; font-weight: 900; letter-spacing: 0; line-height: 1.02; }

.hero__lede { max-width: 820px; margin: 0; color: #304256; font-size: 1.22rem; line-height: 1.65; }

.hero__positioning { max-width: 760px; margin: 18px 0 0; color: var(--muted); font-size: 1.02rem; line-height: 1.65; }

.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }

.hero__panel { display: grid; gap: 13px; align-content: center; }

.hero__panel span { display: block; padding: 16px 18px; border: 1px solid rgba(15, 118, 110, 0.18); border-radius: 8px; background: rgba(255, 255, 255, 0.82); color: var(--accent-strong); font-weight: 800; line-height: 1.35; }

.hero__languages { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

.hero__languages a { padding: 12px 14px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; color: var(--heading); font-weight: 800; text-align: center; text-decoration: none; }

.hero__languages a:hover { border-color: var(--accent); color: var(--accent-strong); }

.eyebrow { margin: 0 0 10px; color: var(--gold); font-size: 0.78rem; font-weight: 850; letter-spacing: 0.08em; text-transform: uppercase; }

.button { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 18px; border: 1px solid var(--line-strong); border-radius: 8px; background: #ffffff; color: var(--accent-strong); font-weight: 850; text-decoration: none; transition: transform 160ms ease, border-color 160ms ease, background-color 160ms ease; }

.button:hover { border-color: var(--accent); color: var(--accent-strong); text-decoration: none; transform: translateY(-1px); }

.button--primary { border-color: var(--accent); background: var(--accent); color: #ffffff; }

.button--primary:hover { background: var(--accent-strong); color: #ffffff; }

.section { margin-top: 54px; }

.section__heading { margin-bottom: 20px; }

.section__heading h2, .callout h2, .archive-toolbar h2 { margin: 0; color: var(--heading); font-size: 1.85rem; font-weight: 850; letter-spacing: 0; line-height: 1.18; }

.section__heading--inline, .archive-toolbar, .callout { display: flex; align-items: end; justify-content: space-between; gap: 22px; }

.section-link, .rss-link { color: var(--accent-strong); font-weight: 850; }

.audience-grid, .topic-grid, .post-grid, .resource-grid, .start-grid { display: grid; gap: 18px; }

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

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

.topic-grid--compact { grid-template-columns: repeat(4, minmax(0, 1fr)); }

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

.resource-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 24px; }

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

.audience-card, .topic-card, .post-card, .resource-card { min-width: 0; border: 1px solid var(--line); border-radius: 8px; background: var(--card); }

.audience-card, .topic-card, .post-card, .resource-card { padding: 22px; }

.audience-card { border-top-width: 5px; }

.audience-card--offices { border-top-color: var(--accent); }

.audience-card--practitioners { border-top-color: var(--blue); }

.audience-card--science { border-top-color: var(--green); }

.topic-card, .start-link { text-decoration: none; }

a.topic-card:hover, .start-link:hover, .resource-card:hover, .post-card:hover { border-color: var(--line-strong); box-shadow: 0 12px 28px rgba(16, 35, 63, 0.07); }

.audience-card h3, .topic-card h2, .topic-card h3, .post-card h2, .post-card h3, .resource-card h2 { overflow-wrap: anywhere; margin-top: 0; color: var(--heading); font-weight: 850; letter-spacing: 0; line-height: 1.25; }

.topic-card h2, .post-card h2, .resource-card h2 { font-size: 1.18rem; }

.topic-card h3, .post-card h3 { font-size: 1.15rem; }

.post-card h2 a, .post-card h3 a { color: var(--heading); text-decoration: none; }

.post-card h2 a:hover, .post-card h3 a:hover { color: var(--accent-strong); text-decoration: underline; }

.audience-card p, .topic-card p, .post-card p, .resource-card p { color: var(--muted); line-height: 1.65; }

.start-section { padding: 30px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.start-link { display: flex; align-items: center; min-height: 96px; padding: 18px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface); color: var(--heading); font-weight: 850; line-height: 1.35; }

.post-card { display: flex; flex-direction: column; }

.post-card__meta, .post-meta { display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: center; margin-bottom: 12px; color: var(--muted); font-size: 0.9rem; }

.post-card__action { margin-top: auto; }

.language-pill, .meta-badge, .tag-list span { display: inline-flex; align-items: center; min-height: 26px; border-radius: 999px; font-size: 0.76rem; font-weight: 800; line-height: 1; }

.language-pill { padding: 5px 9px; background: var(--surface-warm); color: var(--gold); }

.meta-list, .tag-list, .post-meta__group { display: flex; flex-wrap: wrap; gap: 8px; }

.meta-list { margin-top: 14px; }

.meta-badge { padding: 5px 10px; background: var(--surface-strong); color: var(--accent-strong); }

.tag-list { margin-top: 14px; }

.tag-list span { padding: 5px 10px; background: var(--accent-soft); color: var(--accent-strong); }

.read-more, .translation-link a { color: var(--accent-strong); font-weight: 850; }

.archive-toolbar { align-items: center; margin: 28px 0 18px; padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.archive-toolbar__links { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }

.archive-toolbar__links a { padding: 9px 12px; border: 1px solid var(--line); border-radius: 999px; color: var(--heading); font-size: 0.9rem; font-weight: 800; text-decoration: none; }

.archive-toolbar__links a:hover { border-color: var(--accent); color: var(--accent-strong); }

.archive-search { display: grid; grid-template-columns: auto minmax(220px, 1fr) auto minmax(150px, 0.35fr); gap: 10px; align-items: center; margin: 18px 0 24px; padding: 16px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.archive-search label { color: var(--heading); font-size: 0.9rem; font-weight: 850; }

.archive-search input, .archive-search select { min-height: 42px; width: 100%; border: 1px solid var(--line-strong); border-radius: 8px; color: var(--ink); background: #ffffff; }

.archive-search input { padding: 0 12px; }

.archive-search select { padding: 0 10px; }

.archive-search__status { grid-column: 2 / -1; margin: 0; color: var(--muted); font-size: 0.9rem; }

.filter-placeholder { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0 24px; padding: 14px 16px; border: 1px dashed var(--line-strong); border-radius: 8px; background: rgba(255, 255, 255, 0.72); color: var(--muted); }

.filter-placeholder strong { color: var(--heading); }

.archive-list { display: grid; gap: 18px; margin-top: 26px; }

.archive-list--cards { grid-template-columns: 1fr; }

.taxonomy-overview { display: flex; flex-wrap: wrap; gap: 10px; margin: 24px 0 34px; }

.taxonomy-overview a { padding: 9px 12px; border: 1px solid var(--line); border-radius: 999px; background: #ffffff; color: var(--heading); font-size: 0.9rem; font-weight: 800; text-decoration: none; }

.taxonomy-overview a:hover { border-color: var(--accent); color: var(--accent-strong); }

.topic-sections { display: grid; gap: 34px; }

.topic-section { padding: 26px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.topic-section > p { max-width: 820px; color: var(--muted); line-height: 1.7; }

.topic-section h3 { margin-top: 24px; color: var(--heading); font-size: 1.15rem; font-weight: 850; }

.topic-meta { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 18px; padding: 16px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface); }

.topic-meta strong { display: block; color: var(--heading); font-size: 0.88rem; }

.callout { align-items: center; padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: linear-gradient(135deg, #ffffff, var(--surface-strong)); }

.callout p { max-width: 720px; margin-bottom: 0; color: var(--muted); line-height: 1.65; }

.callout--compact { margin: 28px 0 8px; }

.post-hero { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--line); }

.post-language-switch { display: inline-flex; gap: 6px; margin-top: 18px; padding: 4px; border: 1px solid var(--line); border-radius: 999px; background: #ffffff; }

.post-language-switch a { padding: 8px 12px; border-radius: 999px; color: var(--heading); font-size: 0.85rem; font-weight: 850; text-decoration: none; }

.post-language-switch a:hover, .post-language-switch a.is-active { background: var(--heading); color: #ffffff; }

.post-detail .post-title { font-size: 3.1rem; }

.post-summary { max-width: 820px; color: var(--muted); font-size: 1.08rem; line-height: 1.65; }

.post-summary-panel, .post-toc, .author-box, .post-disclaimer, .post-related { margin: 28px 0; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.post-summary-panel { padding: 24px; background: linear-gradient(135deg, #ffffff, var(--surface-strong)); }

.post-facts { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin: 0 0 20px; }

.post-facts div { padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: rgba(255, 255, 255, 0.74); }

.post-facts dt { color: var(--muted); font-size: 0.78rem; font-weight: 850; text-transform: uppercase; letter-spacing: 0.06em; }

.post-facts dd { margin: 6px 0 0; color: var(--heading); font-weight: 850; }

.post-summary-panel__block + .post-summary-panel__block { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line); }

.post-summary-panel h2, .post-toc h2, .author-box h2, .post-related h2 { margin: 0 0 10px; color: var(--heading); font-size: 1.2rem; font-weight: 850; letter-spacing: 0; }

.post-summary-panel p, .post-summary-panel li, .author-box p, .post-disclaimer { color: var(--muted); line-height: 1.65; }

.post-toc { padding: 18px 20px; background: var(--surface); }

.post-toc ol { display: grid; gap: 8px; margin: 0; padding-left: 20px; }

.post-toc a { color: var(--accent-strong); font-weight: 750; }

.post-content { font-size: 1.02rem; line-height: 1.75; }

.post-content a { text-decoration-thickness: 0.08em; text-underline-offset: 0.18em; }

.post-content h2, .post-content h3, .post-content h4 { margin-top: 2rem; color: var(--heading); letter-spacing: 0; line-height: 1.25; }

.post-content p, .post-content li { color: #263747; }

.post-content .post-card h2, .post-content .topic-card h2, .post-content .resource-card h2, .post-content .callout h2, .post-content .archive-toolbar h2 { margin-top: 0; }

.post-content .post-card p, .post-content .topic-card p, .post-content .resource-card p, .post-content .callout p, .post-content .archive-toolbar p { color: var(--muted); }

.post-content .eyebrow { color: var(--gold); }

.post-content blockquote { margin: 24px 0; padding: 16px 20px; border-left: 4px solid var(--accent); background: #ffffff; color: var(--muted); box-shadow: 0 8px 20px rgba(16, 35, 63, 0.04); }

.post-content code, .post-content pre, .page-content code, .page-content pre { border-radius: 6px; background: #eef2f7; }

.post-content pre, .page-content pre { padding: 16px; overflow-x: auto; }

.post-content table, .page-content table { display: block; width: 100%; margin: 22px 0; overflow-x: auto; border-collapse: collapse; border: 1px solid var(--line); border-radius: 8px; white-space: normal; }

.post-content th, .post-content td, .page-content th, .page-content td { min-width: 160px; padding: 10px 12px; border: 1px solid var(--line); vertical-align: top; }

.post-content th, .page-content th { background: var(--surface-strong); color: var(--heading); font-weight: 850; }

.post-content tr:nth-child(even) td, .page-content tr:nth-child(even) td { background: #fbfdff; }

.post-content h2[id*="sources"] + ul, .post-content h2[id*="references"] + ul, .post-content h2[id*="further-reading"] + ul, .post-content h2[id*="official-sources"] + ul, .post-content h2[id*="papers"] + ul, .post-content h2[id*="sources"] + ol, .post-content h2[id*="references"] + ol, .post-content h2[id*="further-reading"] + ol, .post-content h2[id*="official-sources"] + ol, .post-content h2[id*="papers"] + ol { padding: 18px 22px 18px 36px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; }

.post-content img { max-width: 100%; height: auto; border-radius: 8px; }

.post-footer { margin-top: 40px; }

.author-box { padding: 22px; }

.post-disclaimer { padding: 16px 18px; font-weight: 750; }

.post-related { padding: 24px; }

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

.empty-state { padding: 16px; border: 1px dashed var(--line-strong); border-radius: 8px; color: var(--muted); background: var(--surface); }

.site-footer { border-top: 1px solid var(--line); background: #ffffff; }

.site-footer .wrapper { padding-top: 28px; padding-bottom: 30px; }

.footer-grid { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(180px, 0.8fr) minmax(160px, 0.5fr); gap: 28px; }

.footer-heading, .footer-subheading { margin: 0 0 8px; color: var(--heading); font-weight: 850; }

.footer-description, .footer-disclaimer { max-width: 620px; margin: 0 0 8px; color: var(--muted); line-height: 1.6; }

.footer-disclaimer { font-weight: 750; }

.footer-nav, .footer-social { display: grid; align-content: start; gap: 8px; }

.footer-nav a, .footer-social a { color: var(--accent-strong); font-weight: 750; }

@media (max-width: 1060px) { .topic-grid--compact, .start-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .audience-grid, .topic-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 900px) { .site-header__inner { min-height: 68px; }
  .site-header .site-nav { position: relative; }
  .nav-toggle { display: inline-flex; align-items: center; gap: 8px; min-height: 40px; padding: 0 12px; border: 1px solid var(--line); border-radius: 999px; background: #ffffff; color: var(--heading); cursor: pointer; font-weight: 850; }
  .nav-toggle .menu-icon { display: inline-flex; align-items: center; }
  .nav-toggle .menu-icon svg { fill: currentColor; }
  .nav-menu { position: absolute; z-index: 20; top: calc(100% + 10px); right: 0; display: none; width: 340px; max-width: 86vw; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #ffffff; box-shadow: var(--shadow); }
  .site-nav .nav-trigger:checked ~ .nav-menu { display: grid; grid-template-columns: 1fr; gap: 6px; }
  .site-nav .page-link { display: block; padding: 12px; line-height: 1.2; }
  .language-switch { justify-content: stretch; margin: 8px 0 0; }
  .language-switch__link { flex: 1; }
  .hero, .post-grid, .resource-grid, .topic-meta, .post-facts, .footer-grid { grid-template-columns: 1fr; }
  .hero { padding: 34px 26px; }
  .hero h1 { font-size: 3rem; }
  .section__heading--inline, .archive-toolbar, .callout { align-items: start; flex-direction: column; }
  .archive-toolbar__links { justify-content: flex-start; }
  .archive-search { grid-template-columns: 1fr; }
  .archive-search__status { grid-column: auto; } }
@media (max-width: 640px) { .wrapper { padding-right: 18px; padding-left: 18px; }
  .page-content { padding-top: 28px; }
  .site-title__main { max-width: 190px; font-size: 0.95rem; }
  .site-title__byline { font-size: 0.72rem; }
  .hero, .start-section, .callout { padding: 24px 18px; }
  .hero h1 { font-size: 2.32rem; }
  .hero__lede { font-size: 1.05rem; }
  .hero__languages, .audience-grid, .topic-grid, .topic-grid--compact, .post-grid--related, .post-grid--topic, .start-grid { grid-template-columns: 1fr; }
  .button { width: 100%; }
  .post-title, .post-detail .post-title { font-size: 2.15rem; }
  .section__heading h2, .callout h2, .archive-toolbar h2 { font-size: 1.55rem; }
  .topic-section, .post-summary-panel, .post-related { padding: 20px 16px; }
  .post-language-switch { display: grid; grid-template-columns: 1fr 1fr; border-radius: 8px; } }
