:root {
  --bg: #f5f7fb;
  --surface: #ffffff;
  --surface-soft: #edf1f8;
  --text: #111827;
  --muted: #637087;
  --border: #d8dfeb;
  --accent: #155dfc;
  --accent-dark: #0f3ea8;
  --radius: 16px;
}
* { box-sizing: border-box; }
html, body { max-width: 100%; overflow-x: hidden; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: var(--bg); color: var(--text); line-height: 1.5; overflow-wrap: break-word; }
a { color: inherit; text-decoration: none; }
img, svg, video, canvas { max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; max-width: 100%; }
table { max-width: 100%; border-collapse: collapse; }
th, td { vertical-align: top; overflow-wrap: anywhere; }
pre, code, .whitespace-pre-wrap { max-width: 100%; white-space: pre-wrap; overflow-wrap: anywhere; word-break: break-word; }
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible {
  outline: 3px solid rgba(21, 93, 252, .45);
  outline-offset: 3px;
}
.skip-link {
  position: fixed;
  left: 1rem;
  top: .75rem;
  z-index: 100;
  transform: translateY(-160%);
  background: #111827;
  color: #fff;
  border-radius: 999px;
  padding: .55rem .85rem;
  font-weight: 700;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .22);
}
.skip-link:focus { transform: translateY(0); }
.container { width: min(1240px, calc(100% - 2rem)); margin: 0 auto; }
.title { font-size: clamp(1.75rem, 4vw, 2.9rem); line-height: 1.08; margin: .35rem 0 .75rem; }
.title-compact { font-size: clamp(1.45rem, 3vw, 2.2rem); }
.lead { color: #334155; font-size: 1.05rem; line-height: 1.65; margin: .6rem 0 0; max-width: 62ch; }
.site-header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,.96); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border); }
.topbar { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 1rem; padding: .9rem 0; }
.brand { display: inline-flex; align-items: center; gap: .7rem; min-width: 0; }
.brand-logo { width: 38px; height: 38px; }
.brand-title { font-size: 1.1rem; font-weight: 800; letter-spacing: .04em; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.header-search { min-width: 0; }
.header-search input { width: 100%; border: 1px solid var(--border); background: var(--surface-soft); border-radius: 999px; padding: .62rem 1rem; font-size: .95rem; }
.header-actions { display: flex; align-items: center; justify-content: flex-end; gap: .5rem; min-width: 0; flex-wrap: wrap; }
.btn-link { border: 1px solid var(--border); border-radius: 999px; padding: .45rem .8rem; font-size: .85rem; color: var(--muted); min-height: 2.35rem; display: inline-flex; align-items: center; justify-content: center; }
.mobile-menu-toggle { display: none; border: 1px solid var(--border); background: var(--surface); border-radius: 999px; padding: .45rem .8rem; min-height: 2.35rem; align-items: center; justify-content: center; cursor: pointer; }
.main-nav { display: flex; flex-wrap: wrap; gap: .55rem 1rem; overflow: visible; padding: 0 0 .85rem; }
.main-nav a { white-space: nowrap; font-size: .88rem; color: var(--muted); min-height: 2rem; display: inline-flex; align-items: center; }
.site-main { padding: 1.5rem 0 2.5rem; }
.site-main * { min-width: 0; }
.site-main a,
.site-main span,
.site-main p,
.site-main li,
.site-main div,
.site-main article,
.site-main section { overflow-wrap: anywhere; }
.breaking-banner { margin-bottom: 1rem; border: 1px solid #f8c8cb; background: #fff1f2; border-radius: 12px; padding: .7rem .9rem; font-size: .92rem; }
.messages { display: grid; gap: .5rem; margin-bottom: 1rem; }
.message-item { background: #ecfdf3; border: 1px solid #baf3d0; color: #065f46; border-radius: 10px; padding: .6rem .8rem; font-size: .9rem; }
.grid-main { display: grid; gap: 1.2rem; }
.hero { background: var(--surface); border: 1px solid var(--border); border-radius: calc(var(--radius) + 4px); overflow: hidden; display: grid; gap: 0; }
.hero-layout { display: grid; gap: 0; }
.hero-media { min-height: 260px; background: #dbe2ee; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; }
.hero-content { padding: 1.25rem 1.3rem; }
.kicker { text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--accent); font-size: .72rem; }
.hero h1, .hero h2 { font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1.15; margin: .4rem 0 .7rem; }
.meta { color: var(--muted); font-size: .82rem; display: flex; flex-wrap: wrap; gap: .6rem; }
.section { margin-top: 1.4rem; }
.section-title { margin: 0 0 .8rem; font-size: 1.2rem; }
.section-heading { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: .75rem; }
.section-description { margin: 0; color: #475569; line-height: 1.65; max-width: 70ch; }
.cards-3 { display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0,1fr)); }
.news-layout { display: grid; grid-template-columns: minmax(0,1fr) 310px; gap: 1.25rem; align-items: start; }
.discovery-grid { display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 1.25rem; align-items: start; }
.profile-hero { display: grid; grid-template-columns: minmax(0,1fr) 310px; gap: 1.25rem; align-items: start; }
.service-layout { display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 1.25rem; align-items: start; }
.service-aside { display: grid; gap: 1rem; }
.article-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.page,
.article-page,
.article-detail,
.sidebar-card,
.news-card,
.article-card,
.digest-card,
.newsroom-card,
.hero,
.footer-grid > section { min-width: 0; }
.news-card,
.article-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; display: flex; flex-direction: column; min-height: 100%; }
.news-card-media { aspect-ratio: 16/9; background: #dbe2ee; display: block; }
.news-card-media img { width: 100%; height: 100%; object-fit: cover; }
.news-card-content,
.card-body { padding: .95rem 1rem 1rem; min-width: 0; display: grid; gap: .35rem; overflow-wrap: anywhere; }
.news-card h3 { margin: .4rem 0 .5rem; font-size: 1.04rem; line-height: 1.3; }
.article-card h3,
.card-body h3 { margin: .35rem 0 .45rem; font-size: 1.04rem; line-height: 1.3; }
.news-card p,
.article-card p,
.card-body p { margin: 0; color: var(--muted); font-size: .9rem; }
.sidebar-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; }
.sidebar-list { display: grid; gap: .85rem; }
.sidebar-list a { font-weight: 600; }
.sidebar-list p { margin: 0; line-height: 1.6; }
.footer-cta { margin-top: 1.2rem; background: #eaf0ff; border: 1px solid #c6d5ff; border-radius: var(--radius); padding: 1.2rem; }
.news-card-badges { margin: .75rem 0 .35rem; }
.digest-grid { display: grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.digest-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; display: grid; gap: .9rem; }
.digest-card-header { display: flex; justify-content: space-between; gap: 1rem; align-items: flex-start; }
.digest-card h3 { margin: .35rem 0 0; font-size: 1.05rem; line-height: 1.3; }
.digest-card-lead { margin: 0; color: #475569; line-height: 1.65; }
.digest-card-items { display: grid; gap: .75rem; }
.digest-card-link { display: grid; gap: .2rem; border-top: 1px solid var(--border); padding-top: .75rem; }
.digest-card-link:first-child { border-top: 0; padding-top: 0; }
.digest-card-link strong { font-size: .95rem; }
.digest-card-link span { color: var(--muted); font-size: .9rem; line-height: 1.55; }
.share-panel { margin: 1.4rem 0; display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(280px, .85fr); gap: 1rem; align-items: start; }
.share-panel-main,
.share-panel-side { background: var(--surface-soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem 1.1rem; }
.share-panel-main { background: linear-gradient(135deg, #edf4ff 0%, #f8fbff 100%); }
.share-panel-headline { margin: .65rem 0 .4rem; font-size: 1.2rem; font-weight: 700; line-height: 1.35; }
.share-panel-teaser { margin: 0; color: #334155; line-height: 1.7; }
.share-panel-actions { margin-bottom: 0; }
.site-footer { background: #0f172a; color: #e2e8f0; margin-top: 2.2rem; padding: 2rem 0; }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)); gap: 1.2rem; }
.footer-grid > section { min-width: 0; }
.footer-grid h3 { margin: 0 0 .7rem; font-size: .9rem; text-transform: uppercase; letter-spacing: .06em; color: #cbd5e1; }
.footer-grid ul { margin: 0; padding: 0; list-style: none; display: grid; gap: .4rem; }
.footer-muted { color: #9ca3af; font-size: .9rem; }
.footer-muted a { text-decoration: underline; text-underline-offset: 2px; }
.newsletter-form { display: grid; gap: .5rem; }
.newsletter-form input, .newsletter-form button, .page-form input, .page-form textarea, .page-form select, .newsletter-form select { width: 100%; min-width: 0; max-width: 100%; border-radius: 10px; border: 1px solid var(--border); padding: .62rem .75rem; font: inherit; background: var(--surface); min-height: 2.55rem; }
.newsletter-form button, .page-form button { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 600; cursor: pointer; }
.page-form { display: grid; gap: .85rem; }
.page-form label { display: grid; gap: .35rem; font-weight: 600; color: #1e293b; }
.page-form textarea { min-height: 140px; resize: vertical; }
.page-form input[type="checkbox"], .newsletter-form input[type="checkbox"] { width: auto; padding: 0; }
.checkbox-row { display: flex !important; align-items: flex-start; gap: .5rem !important; font-weight: 500 !important; }
.checkbox-row input { width: auto !important; margin-top: .2rem; }
.comments-list { gap: 1rem; }
.comment-card { border: 1px solid var(--border); border-radius: 8px; padding: 1rem; background: var(--surface); }
.comment-card--reply { margin-top: .75rem; background: #f8fafc; }
.comment-replies { margin-top: .75rem; padding-left: 1rem; border-left: 3px solid #dbeafe; }
.comment-reply-form { margin-top: .85rem; padding-top: .85rem; border-top: 1px solid var(--border); }
.comment-reply-form textarea { min-height: 80px; }
.report-details { margin-top: .85rem; }
.report-details summary { cursor: pointer; color: var(--accent); font-weight: 600; }
.report-form { margin-top: .75rem; }
.newsroom-shell { display: grid; gap: 1.2rem; }
.newsroom-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.newsroom-actions { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; }
.newsroom-grid { display: grid; gap: 1rem; align-items: start; }
.newsroom-grid--two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.newsroom-grid--newsletter { grid-template-columns: minmax(0, 1fr) minmax(280px, .42fr); }
.newsroom-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; box-shadow: 0 12px 28px rgba(15, 23, 42, .05); }
.newsroom-card h2 { margin: 0 0 .75rem; font-size: 1.15rem; }
.newsroom-card h3 { margin: .65rem 0 .4rem; font-size: 1rem; }
.newsroom-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; margin-bottom: .9rem; }
.newsroom-pills { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.newsroom-pill { display: inline-flex; align-items: center; min-height: 2rem; border: 1px solid var(--border); border-radius: 999px; padding: .35rem .7rem; font-size: .84rem; font-weight: 650; white-space: nowrap; }
.newsroom-pill--active { background: #111827; border-color: #111827; color: #fff; }
.newsroom-pill--muted { background: #f1f5f9; color: #475569; }
.newsroom-pill--warning { background: #fff7ed; border-color: #fed7aa; color: #9a3412; }
.newsroom-pill--danger { background: #fff1f2; border-color: #fecdd3; color: #9f1239; }
.newsroom-pill--info { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }
.newsroom-pill--success { background: #ecfdf5; border-color: #bbf7d0; color: #047857; }
.newsroom-stack { display: grid; gap: .85rem; }
.newsroom-form-row { display: flex; flex-wrap: wrap; gap: .55rem; align-items: center; margin-bottom: .8rem; }
.newsroom-build-form { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .7rem; align-items: start; margin-top: .8rem; }
.newsroom-span-2 { grid-column: span 2; }
.newsroom-span-all { grid-column: 1 / -1; }
.newsroom-input,
.newsroom-select { min-height: 2.55rem; min-width: 0; border: 1px solid var(--border); border-radius: 10px; padding: .55rem .7rem; background: var(--surface); color: var(--text); font: inherit; }
.newsroom-input--grow { flex: 1 1 220px; }
.newsroom-button { display: inline-flex; align-items: center; justify-content: center; min-height: 2.55rem; border: 1px solid transparent; border-radius: 10px; padding: .55rem .85rem; font-weight: 700; font: inherit; cursor: pointer; }
.newsroom-button--primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.newsroom-button--soft { background: #f1f5f9; border-color: var(--border); color: #334155; }
.newsroom-button--info { background: #e0f2fe; border-color: #bae6fd; color: #0369a1; }
.newsroom-callout { border-radius: var(--radius); padding: .9rem 1rem; line-height: 1.6; }
.newsroom-callout--warning { background: #fffbeb; border: 1px solid #fde68a; color: #92400e; }
.newsroom-list { display: grid; gap: .75rem; }
.newsroom-item { border: 1px solid var(--border); border-radius: 12px; padding: .85rem; background: #fff; }
.newsroom-item--split { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; }
.newsroom-item-label { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: .65rem; align-items: start; }
.newsroom-item-label input[type="checkbox"] { margin-top: .25rem; }
.newsroom-item-meta { color: var(--muted); font-size: .82rem; }
.newsroom-item-text { display: block; margin-top: .55rem; color: #334155; line-height: 1.65; overflow-wrap: anywhere; }
.newsroom-item-context { display: block; margin-top: .45rem; color: var(--muted); font-size: .82rem; overflow-wrap: anywhere; }
.newsroom-item-context a,
.newsroom-inline-link { color: var(--accent-dark); text-decoration: underline; text-underline-offset: 2px; }
.newsroom-item-note { display: block; margin-top: .45rem; color: #a16207; font-size: .82rem; }
.newsroom-item-note--success { color: #047857; }
.newsroom-item-note--danger { color: #be123c; }
.newsroom-empty,
.newsroom-muted { color: var(--muted); font-size: .92rem; }
.newsroom-kicker { color: var(--muted); font-size: .75rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.newsroom-detail-list { display: grid; gap: .45rem; margin: .75rem 0 1rem; color: #334155; font-size: .94rem; }
.newsroom-detail-list p { margin: 0; overflow-wrap: anywhere; }
.newsroom-bullet-list { margin: .5rem 0 0; padding-left: 1.1rem; color: #334155; }
.page-narrow { max-width: 760px; margin: 0 auto; }
.article-page,
.article-detail { background: var(--surface); border: 1px solid var(--border); border-radius: calc(var(--radius) + 4px); padding: 1.2rem; }
.article-page .title,
.article-detail .title { font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.08; margin: .35rem 0 .8rem; }
.article-page .lead,
.article-detail .lead { font-size: 1.05rem; color: #334155; margin-bottom: 1rem; }
.article-page .main-image,
.article-detail .main-image { width: 100%; border-radius: 14px; margin: .6rem 0 1rem; }
.article-body { font-size: 1.08rem; line-height: 1.75; max-width: 760px; overflow-wrap: anywhere; }
.article-body img,
.article-body iframe { max-width: 100%; }
.article-body table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.article-body blockquote { border-left: 3px solid var(--accent); margin: 1rem 0; padding: .3rem 0 .3rem 1rem; color: #334155; font-style: italic; }
.article-body p { margin: 0 0 1rem; }
.article-toolbar { display: flex; gap: .55rem; flex-wrap: wrap; margin: 1rem 0; min-width: 0; }
.article-toolbar > * { min-width: 0; }
.pill { border: 1px solid var(--border); border-radius: 999px; padding: .45rem .75rem; font-size: .86rem; background: var(--surface-soft); min-height: 2.35rem; display: inline-flex; align-items: center; justify-content: center; }
.pill-accent { background: var(--accent); border-color: var(--accent); color: #fff; }
.page { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.2rem; }
.breadcrumbs { margin-bottom: 1rem; }
.breadcrumbs-list { display: flex; flex-wrap: wrap; gap: .45rem; list-style: none; margin: 0; padding: 0; color: var(--muted); font-size: .84rem; }
.breadcrumbs-item::after { content: "/"; margin-left: .45rem; color: #94a3b8; }
.breadcrumbs-item:last-child::after { display: none; }
.status-note { margin-top: 1rem; padding: .85rem 1rem; border-radius: 12px; font-size: .92rem; line-height: 1.55; }
.status-note strong { margin-right: .3rem; }
.status-note--draft { background: #fff7ed; border: 1px solid #fed7aa; color: #9a3412; }
.status-note--inverted { background: rgba(148, 163, 184, .12); border-color: rgba(148, 163, 184, .35); color: #e2e8f0; }
.context-panel { display: grid; gap: .75rem; }
.story-figure { margin: 1.1rem 0; background: var(--surface-soft); border: 1px solid var(--border); border-radius: calc(var(--radius) - 2px); overflow: hidden; }
.story-figure-media { aspect-ratio: 16/9; background: #dbe2ee; }
.story-figure-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.story-figure-media--placeholder { display: grid; place-items: center; color: var(--muted); font-weight: 600; }
.story-figure-caption { display: grid; gap: .35rem; padding: .9rem 1rem 1rem; background: var(--surface); }
.story-figure-caption-text { color: #334155; }
.story-figure-meta { color: var(--muted); font-size: .88rem; }
.search-filter-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr));
  gap: .75rem;
  align-items: end;
  margin-top: 1rem;
}
.search-filter-form label { display: grid; gap: .3rem; margin: 0; font-weight: 650; min-width: 0; }
.search-filter-form input,
.search-filter-form select,
.search-filter-form button {
  width: 100%;
  min-width: 0;
  min-height: 2.55rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .58rem .75rem;
  background: var(--surface);
}
.search-filter-form button { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 700; cursor: pointer; }
.responsive-table { max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.flex { display: flex; min-width: 0; }
.inline-flex { display: inline-flex; min-width: 0; align-items: center; }
.grid { display: grid; min-width: 0; }
.block { display: block; }
.hidden { display: none; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-between { justify-content: space-between; }
.justify-end { justify-content: flex-end; }
.grid-cols-1 { grid-template-columns: minmax(0, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.col-span-2 { grid-column: span 2 / span 2; }
.col-span-3 { grid-column: span 3 / span 3; }
.col-span-4 { grid-column: span 4 / span 4; }
.gap-1 { gap: .25rem; }
.gap-2 { gap: .5rem; }
.gap-3 { gap: .75rem; }
.gap-4 { gap: 1rem; }
.gap-5 { gap: 1.25rem; }
.space-y-3 > * + * { margin-top: .75rem; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-5 > * + * { margin-top: 1.25rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }
.w-full { width: 100%; }
.w-36 { width: 9rem; }
.h-28 { height: 7rem; }
.shrink-0 { flex-shrink: 0; }
.min-w-0 { min-width: 0; }
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.text-left { text-align: left; }
.text-center { text-align: center; }
.uppercase { text-transform: uppercase; }
.tracking-wide { letter-spacing: .04em; }
.rounded { border-radius: 8px; }
.rounded-lg { border-radius: 10px; }
.rounded-xl { border-radius: 14px; }
.rounded-full { border-radius: 999px; }
.border { border: 1px solid var(--border); }
.border-slate-200 { border-color: #e2e8f0; }
.border-sky-200 { border-color: #bae6fd; }
.border-emerald-200 { border-color: #a7f3d0; }
.border-amber-200 { border-color: #fde68a; }
.border-rose-200 { border-color: #fecdd3; }
.bg-white { background: #fff; }
.bg-slate-50 { background: #f8fafc; }
.bg-slate-100 { background: #f1f5f9; }
.bg-slate-200 { background: #e2e8f0; }
.bg-sky-50 { background: #f0f9ff; }
.bg-sky-100 { background: #e0f2fe; }
.bg-sky-700 { background: #0369a1; }
.bg-sky-800 { background: #075985; }
.bg-emerald-50 { background: #ecfdf5; }
.bg-emerald-100 { background: #d1fae5; }
.bg-amber-50 { background: #fffbeb; }
.bg-amber-100 { background: #fef3c7; }
.bg-rose-50 { background: #fff1f2; }
.bg-rose-100 { background: #ffe4e6; }
.bg-indigo-50 { background: #eef2ff; }
.bg-indigo-100 { background: #e0e7ff; }
.bg-fuchsia-100 { background: #fae8ff; }
.text-white { color: #fff; }
.text-slate-500 { color: #64748b; }
.text-slate-600 { color: #475569; }
.text-slate-700 { color: #334155; }
.text-slate-800 { color: #1e293b; }
.text-slate-900 { color: #0f172a; }
.text-sky-700 { color: #0369a1; }
.text-sky-800 { color: #075985; }
.text-indigo-800 { color: #3730a3; }
.text-indigo-900 { color: #312e81; }
.text-fuchsia-900 { color: #701a75; }
.text-emerald-700 { color: #047857; }
.text-emerald-800 { color: #065f46; }
.text-amber-700 { color: #b45309; }
.text-amber-800 { color: #92400e; }
.text-rose-700 { color: #be123c; }
.text-rose-800 { color: #9f1239; }
.text-red-600 { color: #dc2626; }
.text-xs { font-size: .75rem; line-height: 1.35; }
.text-sm { font-size: .875rem; line-height: 1.45; }
.text-base { font-size: 1rem; line-height: 1.55; }
.text-lg { font-size: 1.125rem; line-height: 1.4; }
.text-xl { font-size: 1.25rem; line-height: 1.35; }
.text-2xl { font-size: 1.5rem; line-height: 1.25; }
.text-3xl { font-size: 1.875rem; line-height: 1.18; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 650; }
.font-bold { font-weight: 700; }
.font-extrabold { font-weight: 800; }
.shadow-sm { box-shadow: 0 8px 20px rgba(15, 23, 42, .06); }
.p-2 { padding: .5rem; }
.p-3 { padding: .75rem; }
.p-4 { padding: 1rem; }
.p-5 { padding: 1.25rem; }
.p-6 { padding: 1.5rem; }
.px-2 { padding-left: .5rem; padding-right: .5rem; }
.px-2\.5 { padding-left: .625rem; padding-right: .625rem; }
.px-3 { padding-left: .75rem; padding-right: .75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-1 { padding-top: .25rem; padding-bottom: .25rem; }
.py-1\.5 { padding-top: .375rem; padding-bottom: .375rem; }
.py-2 { padding-top: .5rem; padding-bottom: .5rem; }
.pl-5 { padding-left: 1.25rem; }
.mt-1 { margin-top: .25rem; }
.mt-2 { margin-top: .5rem; }
.mt-3 { margin-top: .75rem; }
.mt-4 { margin-top: 1rem; }
.mt-5 { margin-top: 1.25rem; }
.mb-2 { margin-bottom: .5rem; }
.mb-3 { margin-bottom: .75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mx-auto { margin-left: auto; margin-right: auto; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.list-disc { list-style: disc; }
.hover\:underline:hover { text-decoration: underline; text-underline-offset: 2px; }
.hover\:bg-slate-50:hover { background: #f8fafc; }
.hover\:bg-sky-800:hover { background: #075985; }
@media (max-width: 1024px) {
  .news-layout, .profile-hero, .discovery-grid, .service-layout, .share-panel, .newsroom-grid--two, .newsroom-grid--newsletter { grid-template-columns: 1fr; }
  .cards-3 { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 640px) {
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sm\:flex-row { flex-direction: row; }
}
@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .md\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  .md\:col-span-2 { grid-column: span 2 / span 2; }
  .md\:col-span-3 { grid-column: span 3 / span 3; }
}
@media (min-width: 1024px) {
  .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .lg\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .lg\:grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  .lg\:col-span-4 { grid-column: span 4 / span 4; }
}
@media (min-width: 1280px) {
  .xl\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .xl\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .xl\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .container { width: min(100% - 1rem, 1240px); }
  .topbar { grid-template-columns: minmax(0, 1fr) auto; gap: .55rem; padding: .65rem 0; }
  .brand-logo { width: 30px; height: 30px; }
  .brand-title { max-width: 46vw; font-size: .95rem; }
  .header-search { order: 3; grid-column: 1 / -1; }
  .btn-link { display: none; }
  .mobile-menu-toggle { display: inline-flex; }
  .main-nav { display: none; padding-top: .5rem; }
  .main-nav.is-open { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .45rem; }
  .main-nav a { white-space: normal; justify-content: center; text-align: center; border: 1px solid var(--border); border-radius: 999px; background: var(--surface-soft); padding: .42rem .6rem; min-height: 2.45rem; overflow-wrap: anywhere; }
  .article-grid, .cards-3, .digest-grid { grid-template-columns: 1fr; }
  .section-heading { flex-direction: column; }
  .footer-grid { grid-template-columns: 1fr; }
  .digest-card-header { flex-direction: column; }
  .newsroom-header, .newsroom-card-head, .newsroom-item--split { flex-direction: column; }
  .newsroom-build-form { grid-template-columns: 1fr; }
  .newsroom-span-2 { grid-column: auto; }
  .newsroom-form-row { align-items: stretch; }
  .newsroom-form-row > * { width: 100%; }
  .site-main .flex { flex-wrap: wrap; }
  .site-main .justify-between { justify-content: flex-start; }
  .site-main .grid-cols-2,
  .site-main .grid-cols-3,
  .site-main .grid-cols-4,
  .site-main .grid-cols-5,
  .site-main .grid-cols-6 { grid-template-columns: 1fr; }
  .site-main .col-span-2,
  .site-main .col-span-3,
  .site-main .col-span-4 { grid-column: auto; }
  .page, .article-page, .article-detail, .sidebar-card, .newsroom-card { padding: 1rem; }
  .article-page .title, .article-detail .title, .title { font-size: clamp(1.55rem, 8vw, 2.15rem); line-height: 1.12; }
  .lead { font-size: 1rem; line-height: 1.6; }
  .article-body { font-size: 1rem; line-height: 1.7; }
  .article-toolbar { gap: .45rem; }
  .pill, .newsroom-pill { white-space: normal; text-align: center; min-height: 2.4rem; }
  .share-panel-main, .share-panel-side { padding: 1rem; }
  table { display: block; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .w-36 { width: min(9rem, 38vw); }
  .h-28 { height: auto; min-height: 5.5rem; }
}
@media (max-width: 430px) {
  .container { width: calc(100% - .75rem); }
  .brand-title { max-width: 42vw; }
  .news-card-content, .card-body { padding: .85rem; }
  .main-nav.is-open { grid-template-columns: 1fr; }
  .footer-grid { gap: 1rem; }
}
