/* ==========================================================================
   Whistleblower Theme — main.css
   Forensic palette. Mobile-first. Self-contained.
   ========================================================================== */

:root {
	--wb-bg:        #FFFFFF;
	--wb-bg-alt:    #FAFAF8;
	--wb-bg-warm:   #FAF8F4;
	--wb-bg-tint:   #F0F6FC;
	--wb-ink:       #0F0F0F;
	--wb-ink-2:     #4A4A48;
	--wb-ink-3:     #6B6B68;
	--wb-line:      #E8E8E5;
	--wb-line-2:    #D8D8D5;
	--wb-accent:    #1E5C8B;
	--wb-accent-2:  #C4C4C0;

	--wb-font-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--wb-font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

	--wb-pad: 16px;
	--wb-pad-lg: 24px;
	--wb-radius: 6px;
	--wb-radius-lg: 8px;
}

/* ==========================================================================
   Reset / base
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--wb-font-sans);
	font-size: 16px;
	line-height: 1.6;
	color: var(--wb-ink);
	background: var(--wb-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video, canvas { max-width: 100%; height: auto; display: block; }
a { color: var(--wb-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button {
	font-family: inherit;
	font-size: inherit;
	cursor: pointer;
	border: none;
	background: transparent;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}
.skip-link {
	position: absolute;
	top: -40px;
	left: 0;
	background: var(--wb-ink);
	color: #fff;
	padding: 8px 16px;
	z-index: 100;
}
.skip-link:focus { top: 0; }

/* ==========================================================================
   Masthead
   ========================================================================== */

.wb-masthead {
	background: var(--wb-bg);
	border-bottom: 0.5px solid var(--wb-line);
	position: sticky;
	top: 0;
	z-index: 50;
}
.wb-masthead__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px var(--wb-pad);
	max-width: 1200px;
	margin: 0 auto;
	gap: 16px;
}
.wb-wordmark {
	display: inline-block;
	color: var(--wb-ink);
	text-decoration: none;
	font-weight: 600;
	font-size: 17px;
	letter-spacing: -0.01em;
	line-height: 1;
}
.wb-wordmark:hover { text-decoration: none; }
.wb-wordmark__text { color: var(--wb-ink); }
.wb-standing-line {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	color: var(--wb-accent);
	margin-top: 4px;
	letter-spacing: 0.04em;
}
.wb-masthead__brand { min-width: 0; }

.wb-nav--desktop { display: none; }
.wb-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 22px;
	font-family: var(--wb-font-mono);
	font-size: 12px;
}
.wb-nav__list a {
	color: var(--wb-ink);
	text-decoration: none;
}
.wb-nav__list a:hover { color: var(--wb-accent); }
.wb-nav__list .current-menu-item > a,
.wb-nav__list .current_page_item > a {
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}

.wb-nav__toggle {
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 0.5px solid var(--wb-line-2);
	border-radius: var(--wb-radius);
	color: var(--wb-ink);
	background: transparent;
}

/* Mobile drawer */
.wb-mobile-drawer {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: 84%;
	max-width: 360px;
	background: var(--wb-bg);
	border-left: 0.5px solid var(--wb-line);
	transform: translateX(100%);
	transition: transform 0.25s ease-out;
	z-index: 60;
	display: flex;
	flex-direction: column;
	padding: 80px 24px 24px;
}
.wb-mobile-drawer[hidden] { display: flex !important; }
.wb-mobile-drawer.is-open { transform: translateX(0); }
.wb-mobile-drawer__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 18px;
	font-family: var(--wb-font-sans);
	font-size: 18px;
	font-weight: 500;
}
.wb-mobile-drawer__list a {
	color: var(--wb-ink);
	text-decoration: none;
	display: block;
	padding: 8px 0;
}
.wb-mobile-drawer__list a:hover { color: var(--wb-accent); }
.wb-mobile-drawer__footer {
	margin-top: auto;
	padding-top: 24px;
	border-top: 0.5px solid var(--wb-line);
}

/* ==========================================================================
   Main content
   ========================================================================== */

.wb-main {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
}

/* ==========================================================================
   Hero (shared across data-driven variants)
   ========================================================================== */

.wb-hero {
	padding: 28px var(--wb-pad) 20px;
}
.wb-hero__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-hero__question {
	font-family: var(--wb-font-sans);
	font-size: 34px;
	font-weight: 600;
	line-height: 1.05;
	letter-spacing: -0.035em;
	color: var(--wb-ink);
	margin: 0 0 14px;
}
.wb-hero__summary {
	font-size: 15px;
	line-height: 1.55;
	color: var(--wb-ink);
	margin: 0;
	max-width: 640px;
}
.wb-hero--compact .wb-hero__question { font-size: 28px; }

/* ==========================================================================
   Data strip (Investigation, Money)
   ========================================================================== */

.wb-data-strip {
	margin: 0 var(--wb-pad) 22px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	overflow: hidden;
}
.wb-data-strip__cell {
	padding: 12px 14px;
	border-right: 0.5px solid var(--wb-line);
	border-bottom: 0.5px solid var(--wb-line);
}
.wb-data-strip__cell:nth-child(2n) { border-right: 0; }
.wb-data-strip__cell:nth-child(n+3) { border-bottom: 0; }
.wb-data-strip__label {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-bottom: 4px;
}
.wb-data-strip__value {
	font-family: var(--wb-font-mono);
	font-size: 14px;
	color: var(--wb-ink);
}
.wb-data-strip__value--accent { color: var(--wb-accent); }

/* ==========================================================================
   Pie section
   ========================================================================== */

.wb-pie-section {
	padding: 0 var(--wb-pad) 22px;
}
.wb-pie-section__chart {
	max-width: 280px;
	width: 100%;
	aspect-ratio: 1;
	margin: 0 auto 16px;
	position: relative;
}
.wb-legend__row {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 4px 0;
	font-size: 13.5px;
	line-height: 1.55;
}
.wb-legend__swatch {
	display: inline-block;
	width: 9px;
	height: 9px;
	flex-shrink: 0;
}
.wb-legend__label { flex: 1; }
.wb-legend__value {
	font-family: var(--wb-font-mono);
	font-size: 11px;
}
.wb-pie-section__caption {
	border-top: 0.5px solid var(--wb-line);
	margin-top: 14px;
	padding-top: 12px;
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.6;
}

/* ==========================================================================
   Pivot card (Rosen / "the other strand")
   ========================================================================== */

.wb-pivot {
	margin: 0 var(--wb-pad) 22px;
	background: var(--wb-bg-warm);
	border: 0.5px solid var(--wb-accent);
	border-radius: var(--wb-radius);
	padding: 16px 16px 14px;
}
.wb-pivot__label {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 8px;
}
.wb-pivot__title {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.35;
	color: var(--wb-ink);
	margin: 0 0 10px;
	letter-spacing: -0.005em;
}
.wb-pivot__body {
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--wb-ink-2);
	margin: 0 0 10px;
}
.wb-pivot__link {
	font-family: var(--wb-font-mono);
	font-size: 11.5px;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}
.wb-pivot__link:hover { text-decoration: none; opacity: 0.8; }

/* ==========================================================================
   Surface tiles (the four interactive surfaces)
   ========================================================================== */

.wb-surfaces {
	padding: 4px var(--wb-pad) 20px;
}
.wb-surfaces__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-surfaces__grid {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.wb-surface {
	display: block;
	padding: 14px 16px;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	background: var(--wb-bg);
	color: inherit;
	text-decoration: none;
	transition: border-color 0.15s ease;
}
.wb-surface:hover { border-color: var(--wb-accent); text-decoration: none; }
.wb-surface__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
}
.wb-surface__num {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-surface__arrow {
	font-family: var(--wb-font-mono);
	font-size: 14px;
	color: var(--wb-accent);
}
.wb-surface__body {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.45;
	margin: 0;
}

/* ==========================================================================
   Recent / story-so-far block
   ========================================================================== */

.wb-recent {
	padding: 4px var(--wb-pad) 24px;
}
.wb-recent__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 12px;
}
.wb-recent__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-recent__view-all {
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	color: var(--wb-accent);
	text-decoration: none;
}
.wb-recent__view-all:hover { text-decoration: underline; }

/* ==========================================================================
   Tile grid + tile component
   ========================================================================== */

.wb-tile-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}
.wb-tile {
	display: block;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	background: var(--wb-bg);
	color: inherit;
	text-decoration: none;
	overflow: hidden;
	transition: border-color 0.15s ease;
}
.wb-tile:hover { border-color: var(--wb-accent); text-decoration: none; }
.wb-tile__image img {
	width: 100%;
	height: auto;
	display: block;
}
.wb-tile__content { padding: 14px 16px; }
.wb-tile__meta {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-bottom: 8px;
}
.wb-tile__sep { margin: 0 4px; }
.wb-tile__title {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.3;
	color: var(--wb-ink);
	margin: 0 0 6px;
	letter-spacing: -0.005em;
}
.wb-tile__excerpt {
	font-size: 13px;
	line-height: 1.5;
	color: var(--wb-ink-2);
	margin: 0;
}

/* ==========================================================================
   Brief variant (chronological)
   ========================================================================== */

.wb-brief { padding: 0 var(--wb-pad) 24px; }
.wb-brief__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 16px;
}
.wb-brief__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}
.wb-brief__item { border-top: 0.5px solid var(--wb-line); }
.wb-brief__item:last-child { border-bottom: 0.5px solid var(--wb-line); }
.wb-brief__entry {
	display: flex;
	gap: 14px;
	padding: 16px 0;
	color: inherit;
	text-decoration: none;
}
.wb-brief__entry:hover { text-decoration: none; }
.wb-brief__entry:hover .wb-brief__title { color: var(--wb-accent); }
.wb-brief__date {
	font-family: var(--wb-font-mono);
	flex-shrink: 0;
	width: 60px;
	display: flex;
	flex-direction: column;
	font-size: 11px;
	color: var(--wb-ink-3);
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.wb-brief__date-month { font-size: 10px; }
.wb-brief__date-day { font-size: 22px; color: var(--wb-ink); margin: 2px 0; }
.wb-brief__date-year { font-size: 10px; }
.wb-brief__body { flex: 1; min-width: 0; }
.wb-brief__category {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-bottom: 6px;
}
.wb-brief__title {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.3;
	margin: 0 0 6px;
	letter-spacing: -0.005em;
}
.wb-brief__excerpt {
	font-size: 13px;
	color: var(--wb-ink-2);
	margin: 0;
	line-height: 1.5;
}
.wb-brief__view-all {
	margin-top: 16px;
	text-align: center;
}
.wb-brief__view-all a {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
}

/* ==========================================================================
   Archive feature variant
   ========================================================================== */

.wb-archive-feature {
	margin: 0 var(--wb-pad) 24px;
	padding: 20px 16px;
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
}
.wb-archive-feature__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 16px;
}
.wb-archive-feature__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-archive-feature__open {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-accent);
}
.wb-archive-feature__stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-bottom: 14px;
}
.wb-archive-feature__stat {
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 12px;
	text-align: center;
}
.wb-archive-feature__stat-value {
	font-family: var(--wb-font-mono);
	font-size: 22px;
	color: var(--wb-ink);
	margin-bottom: 4px;
}
.wb-archive-feature__stat-label {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
}
.wb-archive-feature__caption {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0;
}

/* ==========================================================================
   Story variant (article-first)
   ========================================================================== */

.wb-story-hero {
	margin-bottom: 24px;
}
.wb-story-hero__link {
	display: block;
	color: inherit;
	text-decoration: none;
}
.wb-story-hero__link:hover { text-decoration: none; }
.wb-story-hero__image img {
	width: 100%;
	height: auto;
	display: block;
}
.wb-story-hero__content {
	padding: 18px var(--wb-pad);
}
.wb-story-hero__meta {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-bottom: 10px;
}
.wb-story-hero__sep { margin: 0 4px; }
.wb-story-hero__title {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.1;
	letter-spacing: -0.025em;
	margin: 0 0 12px;
}
.wb-story-hero__excerpt {
	font-size: 15px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0 0 12px;
}
.wb-story-hero__cta {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}

/* ==========================================================================
   Network feature variant
   ========================================================================== */

.wb-network-feature {
	margin: 0 var(--wb-pad) 24px;
	padding: 20px 16px;
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
}
.wb-network-feature__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 16px;
}
.wb-network-feature__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-network-feature__open {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-accent);
}
.wb-network-feature__placeholder {
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 16px;
	margin-bottom: 12px;
}
.wb-network-feature__caption {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0;
}

/* ==========================================================================
   Wire variant (feed)
   ========================================================================== */

.wb-wire { padding: 0 var(--wb-pad) 24px; }
.wb-wire__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 14px;
}
.wb-wire__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-wire__live {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-wire__live-dot {
	width: 6px;
	height: 6px;
	background: var(--wb-accent);
	border-radius: 50%;
	animation: wb-pulse 2s infinite ease-in-out;
}
@keyframes wb-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.3; }
}
.wb-wire__list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 0.5px solid var(--wb-line);
}
.wb-wire__item { border-bottom: 0.5px solid var(--wb-line); }
.wb-wire__entry {
	display: grid;
	grid-template-columns: 60px auto 1fr;
	align-items: baseline;
	gap: 10px;
	padding: 10px 0;
	color: inherit;
	text-decoration: none;
	font-size: 14px;
}
.wb-wire__entry:hover { text-decoration: none; color: var(--wb-accent); }
.wb-wire__time {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.wb-wire__category {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-wire__title {
	font-weight: 500;
	color: var(--wb-ink);
	line-height: 1.4;
}
.wb-wire__entry:hover .wb-wire__title { color: var(--wb-accent); }
.wb-wire__view-all {
	margin-top: 16px;
	text-align: center;
}
.wb-wire__view-all a {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
}

/* ==========================================================================
   Dossier variant (split)
   ========================================================================== */

.wb-dossier {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	padding: 0 var(--wb-pad) 24px;
}
.wb-dossier__panel-label {
	font-family: var(--wb-font-mono);
	font-size: 9.5px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-dossier__article {
	display: block;
	color: inherit;
	text-decoration: none;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	overflow: hidden;
	background: var(--wb-bg);
}
.wb-dossier__article:hover { border-color: var(--wb-accent); text-decoration: none; }
.wb-dossier__article-image img { width: 100%; display: block; }
.wb-dossier__article-meta,
.wb-dossier__article-title,
.wb-dossier__article-excerpt,
.wb-dossier__article-cta { padding-left: 16px; padding-right: 16px; }
.wb-dossier__article-meta {
	padding-top: 14px;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
}
.wb-dossier__article-sep { margin: 0 4px; }
.wb-dossier__article-title {
	font-size: 18px;
	font-weight: 500;
	line-height: 1.25;
	margin: 8px 0;
	letter-spacing: -0.01em;
}
.wb-dossier__article-excerpt {
	font-size: 13.5px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0 0 10px;
}
.wb-dossier__article-cta {
	display: inline-block;
	padding-bottom: 14px;
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
}
.wb-dossier__library {
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 16px;
}
.wb-dossier__library-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-bottom: 12px;
}
.wb-dossier__library-stat {
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 12px;
	text-align: center;
}
.wb-dossier__library-value {
	font-family: var(--wb-font-mono);
	font-size: 22px;
	color: var(--wb-ink);
	margin-bottom: 4px;
}
.wb-dossier__library-label {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
}
.wb-dossier__library-caption {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0 0 12px;
}
.wb-dossier__library-link {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}

/* ==========================================================================
   Article (single.php)
   ========================================================================== */

.wb-article {
	max-width: 720px;
	margin: 0 auto;
	padding: 28px var(--wb-pad) 40px;
}
.wb-article__header { margin-bottom: 24px; }
.wb-article__meta {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-bottom: 12px;
}
.wb-article__date::after { content: " · "; }
.wb-article__title {
	font-size: 30px;
	font-weight: 600;
	line-height: 1.15;
	letter-spacing: -0.025em;
	margin: 0 0 14px;
}
.wb-article__byline {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	letter-spacing: 0.04em;
}
.wb-article__author { color: var(--wb-ink-2); }
.wb-article__featured-image { margin: 0 0 24px; }
.wb-article__featured-image img { width: 100%; display: block; }
.wb-article__featured-image figcaption {
	font-size: 12px;
	color: var(--wb-ink-3);
	margin-top: 6px;
	text-align: center;
	font-style: italic;
}
.wb-article__body {
	font-size: 17px;
	line-height: 1.7;
	color: var(--wb-ink);
}
.wb-article__body p { margin: 0 0 1.4em; }
.wb-article__body h2 {
	font-size: 22px;
	font-weight: 600;
	margin: 2em 0 0.6em;
	letter-spacing: -0.015em;
}
.wb-article__body h3 {
	font-size: 18px;
	font-weight: 600;
	margin: 1.6em 0 0.5em;
}
.wb-article__body blockquote {
	border-left: 3px solid var(--wb-accent);
	margin: 1.6em 0;
	padding: 0 0 0 20px;
	font-size: 18px;
	color: var(--wb-ink-2);
	font-style: italic;
}
.wb-article__body a { color: var(--wb-accent); }
.wb-article__body a:hover { text-decoration: underline; }
.wb-article__body strong { font-weight: 600; }
.wb-article__body ul,
.wb-article__body ol {
	margin: 0 0 1.4em;
	padding-left: 24px;
}
.wb-article__body li { margin-bottom: 0.5em; }
.wb-article__body img { max-width: 100%; height: auto; }
.wb-article__body figure { margin: 1.5em 0; }
.wb-article__body figcaption {
	font-size: 12px;
	color: var(--wb-ink-3);
	margin-top: 6px;
	text-align: center;
	font-style: italic;
}

/* PDF embed support — keeps native Gutenberg wp-block-file styling
   but drapes it in the Forensic palette. */
.wb-article__body .wp-block-file {
	margin: 1.5em 0;
	padding: 16px;
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
}
.wb-article__body .wp-block-file__embed {
	width: 100% !important;
	height: 70vh;
	min-height: 400px;
	max-height: 800px;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	background: var(--wb-bg);
}
.wb-article__body .wp-block-file > a:not(.wp-block-file__button) {
	display: inline-block;
	margin-top: 12px;
	font-family: var(--wb-font-mono);
	font-size: 13px;
	color: var(--wb-ink-2);
	text-decoration: none;
}
.wb-article__body .wp-block-file > a:not(.wp-block-file__button):hover {
	color: var(--wb-accent);
	text-decoration: underline;
}
.wb-article__body .wp-block-file__button {
	display: inline-block;
	margin-top: 12px;
	margin-left: 12px;
	padding: 8px 14px;
	background: var(--wb-bg);
	color: var(--wb-accent) !important;
	border: 0.5px solid var(--wb-accent);
	border-radius: var(--wb-radius);
	font-family: var(--wb-font-mono);
	font-size: 12px;
	letter-spacing: 0.04em;
	text-decoration: none;
	text-transform: lowercase;
	font-weight: 500;
	transition: background 0.15s ease;
}
.wb-article__body .wp-block-file__button:hover {
	background: var(--wb-accent);
	color: var(--wb-bg) !important;
}

.wb-article__footer {
	margin-top: 40px;
	padding-top: 24px;
	border-top: 0.5px solid var(--wb-line);
}
.wb-article__tags {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	margin-bottom: 16px;
}
.wb-article__tags a {
	color: var(--wb-ink-3);
	margin-right: 8px;
}
.wb-article__tags a:hover { color: var(--wb-accent); }
.wb-article__methodology {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	line-height: 1.6;
}

/* Post navigation */
.wb-post-nav {
	max-width: 720px;
	margin: 0 auto;
	padding: 0 var(--wb-pad) 40px;
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}
.wb-post-nav a {
	display: block;
	padding: 14px 16px;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	color: inherit;
	text-decoration: none;
}
.wb-post-nav a:hover { border-color: var(--wb-accent); text-decoration: none; }
.wb-post-nav__direction {
	display: block;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 4px;
}
.wb-post-nav__title {
	font-size: 14px;
	color: var(--wb-ink);
}

/* ==========================================================================
   Archive (category.php / archive.php)
   ========================================================================== */

.wb-archive {
	max-width: 1200px;
	margin: 0 auto;
	padding: 28px var(--wb-pad) 40px;
}
.wb-archive__header { margin-bottom: 24px; }
.wb-archive__label {
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 8px;
}
.wb-archive__title {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.1;
	letter-spacing: -0.025em;
	margin: 0 0 8px;
}
.wb-archive__description,
.wb-archive__count {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	letter-spacing: 0.04em;
}

/* Pagination */
.wb-archive nav.pagination,
.wb-archive .pagination {
	margin-top: 32px;
	display: flex;
	justify-content: center;
	gap: 6px;
	flex-wrap: wrap;
}
.wb-archive nav.pagination a,
.wb-archive nav.pagination span,
.wb-archive .pagination a,
.wb-archive .pagination span {
	display: inline-block;
	min-width: 36px;
	padding: 8px 12px;
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	color: var(--wb-ink);
	text-decoration: none;
	font-family: var(--wb-font-mono);
	font-size: 12px;
	text-align: center;
}
.wb-archive nav.pagination .current,
.wb-archive .pagination .current {
	background: var(--wb-ink);
	color: var(--wb-bg);
	border-color: var(--wb-ink);
}

/* ==========================================================================
   404
   ========================================================================== */

.wb-404 {
	max-width: 720px;
	margin: 0 auto;
	padding: 60px var(--wb-pad);
}
.wb-404__label {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-404__title {
	font-size: 26px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.02em;
	margin: 0 0 16px;
}
.wb-404__body {
	font-size: 15px;
	color: var(--wb-ink-2);
	line-height: 1.6;
	margin: 0 0 16px;
}
.wb-404__link {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.wb-footer {
	border-top: 0.5px solid var(--wb-line);
	background: var(--wb-bg);
	padding: 24px var(--wb-pad);
	margin-top: 40px;
}
.wb-footer__inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.wb-footer__brand {}
.wb-footer__wordmark {
	font-size: 14px;
	font-weight: 500;
	color: var(--wb-ink);
	margin-bottom: 4px;
}
.wb-footer__methodology {
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	color: var(--wb-ink-2);
	line-height: 1.65;
}
.wb-footer__contact { margin-top: 8px; }
.wb-footer__contact a { color: var(--wb-accent); }
.wb-footer__legal {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 0.5px solid var(--wb-line);
	font-family: var(--wb-font-mono);
	font-size: 10px;
	color: var(--wb-ink-3);
	text-align: center;
}

/* Empty state */
.wb-empty {
	padding: 40px 16px;
	text-align: center;
	color: var(--wb-ink-3);
	font-size: 14px;
}

/* Search form */
.wb-search-form {
	display: flex;
	gap: 8px;
	margin: 16px 0;
}
.wb-search-form__input {
	flex: 1;
	padding: 10px 12px;
	border: 0.5px solid var(--wb-line-2);
	border-radius: var(--wb-radius);
	font-family: var(--wb-font-sans);
	font-size: 14px;
}
.wb-search-form__submit {
	padding: 10px 16px;
	border: 0.5px solid var(--wb-accent);
	border-radius: var(--wb-radius);
	background: var(--wb-bg);
	color: var(--wb-accent);
	font-family: var(--wb-font-mono);
	font-size: 12px;
}

/* ==========================================================================
   Tablet (>= 720px)
   ========================================================================== */

@media (min-width: 720px) {
	:root {
		--wb-pad: 24px;
	}

	.wb-data-strip { grid-template-columns: repeat(4, 1fr); }
	.wb-data-strip__cell { border-bottom: 0; }
	.wb-data-strip__cell:nth-child(2n) { border-right: 0.5px solid var(--wb-line); }
	.wb-data-strip__cell:nth-child(4n) { border-right: 0; }
	.wb-data-strip__cell:nth-child(n+3) { border-bottom: 0; }

	.wb-pie-section {
		display: grid;
		grid-template-columns: 280px 1fr;
		gap: 32px;
		align-items: center;
	}
	.wb-pie-section__chart { margin: 0; }
	.wb-pie-section__caption {
		grid-column: 1 / -1;
	}
	.wb-pie-section--lead {
		display: grid;
		grid-template-columns: 320px 1fr;
	}

	.wb-tile-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 14px;
	}

	.wb-surfaces__grid {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 12px;
	}

	.wb-archive-feature__stats { grid-template-columns: repeat(3, 1fr); }
	.wb-dossier { grid-template-columns: 2fr 1fr; gap: 24px; }
	.wb-post-nav { grid-template-columns: 1fr 1fr; }

	.wb-hero__question { font-size: 44px; }
	.wb-hero--compact .wb-hero__question { font-size: 36px; }
	.wb-article__title { font-size: 36px; }
	.wb-story-hero__title { font-size: 36px; }
	.wb-archive__title { font-size: 36px; }
}

/* ==========================================================================
   Desktop (>= 960px)
   ========================================================================== */

@media (min-width: 960px) {
	.wb-masthead__inner { padding: 16px 32px; }
	.wb-wordmark { font-size: 24px; }
	.wb-standing-line { font-size: 11px; }
	.wb-nav--desktop { display: block; }
	.wb-nav__toggle { display: none; }
	.wb-mobile-drawer { display: none !important; }

	.wb-tile-grid { grid-template-columns: repeat(3, 1fr); }
	.wb-surfaces__grid { grid-template-columns: repeat(4, 1fr); }

	.wb-hero__question { font-size: 56px; }
	.wb-hero--compact .wb-hero__question { font-size: 44px; }

	.wb-article__title { font-size: 44px; }
	.wb-story-hero__title { font-size: 48px; }
	.wb-archive__title { font-size: 44px; }

	.wb-footer__inner {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
		gap: 32px;
	}
	.wb-footer__methodology {
		max-width: 480px;
		text-align: right;
	}
}

/* ==========================================================================
   Infinite scroll status
   ========================================================================== */

.wb-infinite-sentinel {
	width: 100%;
	height: 1px;
	margin: 0;
}
.wb-infinite-status {
	display: none;
	padding: 16px;
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	color: var(--wb-ink-3);
	text-align: center;
	cursor: default;
}
.wb-infinite-status.is-visible { display: block; }
.wb-infinite-status.is-done {
	color: var(--wb-ink-3);
	font-style: italic;
}

/* ==========================================================================
   Surface pages (timeline / players / evidence / money — coming soon)
   ========================================================================== */

.wb-surface-page {
	max-width: 900px;
	margin: 0 auto;
	padding: 28px var(--wb-pad) 60px;
}
.wb-surface-page__header {
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 0.5px solid var(--wb-line);
}
.wb-surface-page__number {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-surface-page__title {
	font-size: 30px;
	font-weight: 600;
	line-height: 1.1;
	letter-spacing: -0.025em;
	margin: 0 0 6px;
}
.wb-surface-page__subtitle {
	font-size: 15px;
	color: var(--wb-ink-2);
	margin: 0;
}
.wb-surface-page__description {
	font-size: 15px;
	line-height: 1.65;
	color: var(--wb-ink);
	margin-bottom: 32px;
	max-width: 680px;
}
.wb-surface-page__description p { margin: 0; }

.wb-surface-page__skeleton {
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 20px 16px;
	margin-bottom: 28px;
	min-height: 280px;
}
.wb-surface-page__skeleton-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 20px;
}
.wb-surface-page__skeleton-dot {
	width: 6px;
	height: 6px;
	background: var(--wb-accent);
	border-radius: 50%;
	animation: wb-pulse 2s infinite ease-in-out;
}

/* Timeline skeleton */
.wb-skeleton--timeline {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.wb-skeleton__track {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.wb-skeleton__track-label {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
}
.wb-skeleton__track-line {
	position: relative;
	height: 28px;
	border-bottom: 0.5px solid var(--wb-line-2);
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 0 4px;
}
.wb-skeleton__node {
	width: 8px;
	height: 8px;
	background: var(--wb-ink);
	border-radius: 50%;
	transform: translateY(50%);
}
.wb-skeleton__node--accent { background: var(--wb-accent); }
.wb-skeleton__axis {
	display: flex;
	justify-content: space-between;
	padding: 0 4px;
	margin-top: 8px;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	color: var(--wb-ink-3);
	letter-spacing: 0.04em;
}

/* Players skeleton */
.wb-skeleton--players { text-align: center; }
.wb-skeleton--players svg {
	width: 100%;
	max-width: 600px;
	height: auto;
	margin: 0 auto 12px;
}
.wb-skeleton__legend {
	display: flex;
	gap: 20px;
	justify-content: center;
	flex-wrap: wrap;
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-2);
}
.wb-skeleton__legend > span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.wb-skeleton__swatch {
	display: inline-block;
	width: 9px;
	height: 9px;
	border-radius: 50%;
}

/* Evidence skeleton */
.wb-skeleton--evidence {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.wb-skeleton__searchbar {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line-2);
	border-radius: var(--wb-radius);
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-ink-3);
}
.wb-skeleton__filters {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.wb-skeleton__filters span {
	display: inline-block;
	padding: 6px 12px;
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line-2);
	border-radius: 14px;
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-3);
	letter-spacing: 0.04em;
}
.wb-skeleton__doc-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	margin-top: 6px;
}
.wb-skeleton__doc {
	display: flex;
	gap: 12px;
	padding: 10px 12px;
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	align-items: center;
}
.wb-skeleton__doc-icon {
	width: 24px;
	height: 30px;
	background: var(--wb-line);
	border-radius: 2px;
	flex-shrink: 0;
}
.wb-skeleton__doc-meta { flex: 1; min-width: 0; }
.wb-skeleton__doc-title {
	height: 10px;
	width: 70%;
	background: var(--wb-line);
	border-radius: 2px;
	margin-bottom: 6px;
}
.wb-skeleton__doc-sub {
	height: 8px;
	width: 40%;
	background: var(--wb-line);
	border-radius: 2px;
}

/* Money skeleton */
.wb-skeleton--money {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	align-items: center;
}
.wb-skeleton__pie {
	max-width: 200px;
	margin: 0 auto;
}
.wb-skeleton__bars {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.wb-skeleton__bar {
	display: flex;
	align-items: center;
	gap: 12px;
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-2);
}
.wb-skeleton__bar span {
	display: inline-block;
	height: 16px;
	background: var(--wb-ink);
	border-radius: 2px;
	min-width: 12px;
}
.wb-skeleton__bar--accent span { background: var(--wb-accent); }
.wb-skeleton__bar--muted span { background: var(--wb-line-2); }
.wb-skeleton__bar em {
	font-style: normal;
	color: var(--wb-ink-3);
}

.wb-surface-page__cta {
	border-top: 0.5px solid var(--wb-line);
	padding-top: 20px;
}
.wb-surface-page__cta-body {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.6;
	margin: 0 0 12px;
}
.wb-surface-page__cta-link {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}
.wb-surface-page__cta-link:hover { text-decoration: none; opacity: 0.8; }

/* Tablet+ adjustments for surface pages */
@media (min-width: 720px) {
	.wb-surface-page__title { font-size: 40px; }
	.wb-surface-page__skeleton { padding: 28px 24px; min-height: 360px; }
	.wb-skeleton__doc-grid { grid-template-columns: 1fr 1fr; }
	.wb-skeleton--money { grid-template-columns: 220px 1fr; }
}

/* ==========================================================================
   The Players (populated surface — v1.2)
   ========================================================================== */

.wb-players { max-width: 1100px; }

.wb-players__network {
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 20px 16px 16px;
	margin-bottom: 32px;
}
.wb-players__network-label {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 16px;
}
.wb-players__svg {
	width: 100%;
	max-width: 720px;
	height: auto;
	display: block;
	margin: 0 auto 14px;
}
.wb-players__network-legend {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-ink-2);
	border-top: 0.5px solid var(--wb-line);
	padding-top: 12px;
	line-height: 1.5;
}
.wb-players__network-legend > span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.wb-players__legend-swatch {
	display: inline-block;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	flex-shrink: 0;
}
.wb-players__legend-overlap {
	color: var(--wb-accent);
}
.wb-players__legend-dash {
	display: inline-block;
	width: 18px;
	height: 1px;
	background: repeating-linear-gradient(to right, var(--wb-accent) 0, var(--wb-accent) 3px, transparent 3px, transparent 6px);
	flex-shrink: 0;
}

.wb-players__group {
	margin-bottom: 36px;
	padding-top: 8px;
}
.wb-players__group-head {
	border-top: 0.5px solid var(--wb-line);
	padding-top: 18px;
	margin-bottom: 18px;
}
.wb-players__group-label {
	font-size: 22px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.015em;
	color: var(--wb-ink);
	margin: 0 0 6px;
}
.wb-players__group-subtitle {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.04em;
	color: var(--wb-ink-3);
	line-height: 1.55;
	margin: 0;
}

.wb-players__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}
.wb-player {
	background: var(--wb-bg);
	border: 0.5px solid var(--wb-line);
	border-radius: var(--wb-radius);
	padding: 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.wb-player--pump {
	border-left: 2px solid var(--wb-accent);
}
.wb-player--commission {
	border-left: 2px solid var(--wb-ink);
}
.wb-player--lobby {
	border-left: 2px solid var(--wb-ink-2);
}
.wb-player__head {
	display: flex;
	flex-direction: column;
	gap: 3px;
}
.wb-player__name {
	font-size: 15px;
	font-weight: 600;
	line-height: 1.25;
	letter-spacing: -0.005em;
	color: var(--wb-ink);
	margin: 0;
}
.wb-player__role {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--wb-accent);
}
.wb-player__description {
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--wb-ink);
	margin: 0;
}
.wb-player__source {
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	color: var(--wb-ink-3);
	line-height: 1.5;
	font-style: italic;
	margin-top: 2px;
}

@media (min-width: 720px) {
	.wb-players__grid {
		grid-template-columns: 1fr 1fr;
		gap: 14px;
	}
	.wb-players__network-legend {
		flex-direction: row;
		flex-wrap: wrap;
		gap: 18px;
	}
}

@media (min-width: 960px) {
	.wb-players__grid {
		grid-template-columns: 1fr 1fr 1fr;
	}
	.wb-player__name {
		font-size: 16px;
	}
}

/* ==========================================================================
   Pivot card — dual links (v1.2.1)
   ========================================================================== */

.wb-pivot__links {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-start;
}
.wb-pivot__link--secondary {
	color: var(--wb-ink-2);
	border-bottom-color: var(--wb-ink-3);
	font-size: 11px;
}
.wb-pivot__link--secondary:hover {
	color: var(--wb-accent);
	border-bottom-color: var(--wb-accent);
}

@media (min-width: 720px) {
	.wb-pivot__links {
		flex-direction: row;
		gap: 18px;
		align-items: baseline;
	}
}

.wb-players__group-docs {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-top: 12px;
	padding-top: 10px;
	border-top: 0.5px dashed var(--wb-line-2);
}
.wb-players__group-docs a {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
	align-self: flex-start;
}
.wb-players__group-docs a:hover {
	opacity: 0.75;
}

@media (min-width: 720px) {
	.wb-players__group-docs {
		flex-direction: row;
		gap: 16px;
	}
}

/* ==========================================================================
   Methodology and Notice page (v1.2.2)
   ========================================================================== */

.wb-methodology {
	max-width: 720px;
	margin: 0 auto;
	padding: 28px var(--wb-pad) 60px;
}
.wb-methodology__header {
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 0.5px solid var(--wb-line);
}
.wb-methodology__label {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-methodology__title {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--wb-ink);
	margin: 0;
}
.wb-methodology__body {
	font-size: 15.5px;
	line-height: 1.65;
	color: var(--wb-ink);
}
.wb-methodology__section {
	margin-bottom: 28px;
}
.wb-methodology__section:last-child {
	margin-bottom: 0;
}
.wb-methodology__section-title {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin: 0 0 12px;
	font-weight: 500;
}
.wb-methodology__body p {
	margin: 0 0 14px;
}
.wb-methodology__body p:last-child {
	margin-bottom: 0;
}
.wb-methodology__body a {
	color: var(--wb-accent);
}
.wb-methodology__body a:hover {
	text-decoration: underline;
}
.wb-methodology__footer {
	margin-top: 40px;
	padding-top: 20px;
	border-top: 0.5px solid var(--wb-line);
}
.wb-methodology__footer-link {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
}

@media (min-width: 720px) {
	.wb-methodology__title { font-size: 36px; }
}

/* ==========================================================================
   Footer notice block (v1.2.2)
   ========================================================================== */

.wb-footer__notice {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 0.5px dashed var(--wb-line-2);
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	color: var(--wb-ink-3);
	line-height: 1.65;
}
.wb-footer__notice-link {
	display: inline-block;
	margin-top: 8px;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}
.wb-footer__notice-link:hover {
	opacity: 0.75;
}

.wb-footer__legal-sep {
	margin: 0 6px;
	color: var(--wb-line-2);
}
.wb-footer__legal a {
	color: var(--wb-ink-3);
	text-decoration: none;
}
.wb-footer__legal a:hover {
	color: var(--wb-accent);
	text-decoration: underline;
}

/* Article footer notice link */
.wb-article__notice-link {
	margin-top: 10px;
}
.wb-article__notice-link a {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
}
.wb-article__notice-link a:hover {
	opacity: 0.75;
}

@media (min-width: 960px) {
	/* When footer is horizontal on desktop, keep notice block tied to methodology */
	.wb-footer__methodology {
		max-width: 540px;
	}
}

/* ==========================================================================
   Utility nav (Methodology link, always visible) — v1.2.3
   ========================================================================== */

.wb-nav__utility {
	display: none;
	list-style: none;
	margin: 0 0 0 22px;
	padding: 0 0 0 22px;
	border-left: 0.5px solid var(--wb-line);
	font-family: var(--wb-font-mono);
	font-size: 11px;
}
.wb-nav__utility a {
	color: var(--wb-ink-3);
	text-decoration: none;
	letter-spacing: 0.04em;
}
.wb-nav__utility a:hover {
	color: var(--wb-accent);
}

@media (min-width: 960px) {
	.wb-nav__utility { display: flex; }
}

.wb-mobile-drawer__utility {
	list-style: none;
	margin: 0 0 16px;
	padding: 0 0 16px;
	border-bottom: 0.5px solid var(--wb-line);
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-family: var(--wb-font-mono);
	font-size: 12px;
}
.wb-mobile-drawer__utility a {
	color: var(--wb-ink-3);
	text-decoration: none;
	display: block;
	padding: 4px 0;
	letter-spacing: 0.04em;
}
.wb-mobile-drawer__utility a:hover {
	color: var(--wb-accent);
}

/* Contact page email styling */
.wb-contact__email {
	font-family: var(--wb-font-mono);
	font-size: 18px;
	color: var(--wb-accent);
	text-decoration: none;
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 2px;
}
.wb-contact__email:hover {
	opacity: 0.75;
}

/* ==========================================================================
   The Timeline (populated surface — v1.2.6)
   ========================================================================== */

.wb-timeline {
	max-width: 880px;
	margin: 0 auto;
	padding: 28px var(--wb-pad) 60px;
}

.wb-timeline__header {
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 0.5px solid var(--wb-line);
}
.wb-timeline__label {
	font-family: var(--wb-font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wb-accent);
	margin-bottom: 12px;
}
.wb-timeline__title {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.15;
	letter-spacing: -0.025em;
	margin: 0 0 10px;
}
.wb-timeline__subtitle {
	font-size: 14px;
	color: var(--wb-ink-2);
	line-height: 1.55;
	margin: 0;
	max-width: 640px;
}

/* Filter chips */
.wb-timeline__filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	padding: 16px 0;
	margin-bottom: 16px;
	position: sticky;
	top: 60px;
	background: var(--wb-bg);
	z-index: 10;
	border-bottom: 0.5px solid var(--wb-line);
}
.wb-timeline__filters-label {
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--wb-ink-3);
	margin-right: 6px;
}
.wb-timeline__filter {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 11px;
	border: 0.5px solid var(--wb-line-2);
	border-radius: 16px;
	background: var(--wb-bg);
	color: var(--wb-ink);
	font-family: var(--wb-font-sans);
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.15s ease;
}
.wb-timeline__filter:hover {
	border-color: var(--wb-accent);
	color: var(--wb-accent);
}
.wb-timeline__filter.is-active {
	background: var(--wb-accent);
	color: var(--wb-bg);
	border-color: var(--wb-accent);
}
.wb-timeline__filter-count {
	font-family: var(--wb-font-mono);
	font-size: 10px;
	color: var(--wb-ink-3);
	background: var(--wb-bg-alt);
	padding: 1px 6px;
	border-radius: 10px;
	min-width: 22px;
	text-align: center;
}
.wb-timeline__filter.is-active .wb-timeline__filter-count {
	color: var(--wb-bg);
	background: rgba(255, 255, 255, 0.2);
}

/* Feed */
.wb-timeline__feed {
	list-style: none;
	margin: 0;
	padding: 0;
}
.wb-timeline__event {
	display: grid;
	grid-template-columns: 32px 1fr;
	gap: 14px;
	padding: 18px 0;
	border-top: 0.5px solid var(--wb-line);
}
.wb-timeline__event:first-child {
	border-top: 0;
	padding-top: 8px;
}
.wb-timeline__event.is-hidden {
	display: none;
}

.wb-timeline__icon {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 4px;
}
.wb-timeline__icon svg {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	padding: 4px;
	background: var(--wb-bg-alt);
	border: 0.5px solid var(--wb-line);
	color: var(--wb-ink);
}

/* Type-coded icon backgrounds */
.wb-timeline__event--procurement .wb-timeline__icon svg { background: #F0F4F8; color: #2A4A6B; border-color: #D9E4EE; }
.wb-timeline__event--financial   .wb-timeline__icon svg { background: #FAF8F2; color: #6B5A28; border-color: #E5DFD0; }
.wb-timeline__event--commission  .wb-timeline__icon svg { background: #FAF1E8; color: #8B5A2B; border-color: #E8D9C2; }
.wb-timeline__event--lobbying    .wb-timeline__icon svg { background: #F4F1F8; color: #5B4A7E; border-color: #DFD8E8; }
.wb-timeline__event--pump        .wb-timeline__icon svg { background: #F0F6FC; color: #1E5C8B; border-color: #C9DCEC; }
.wb-timeline__event--litigation  .wb-timeline__icon svg { background: #FAF0F0; color: #8B2B2B; border-color: #E8C9C9; }
.wb-timeline__event--regulatory  .wb-timeline__icon svg { background: #F0F4F0; color: #2B6B3B; border-color: #C9DCC9; }
.wb-timeline__event--ukraine     .wb-timeline__icon svg { background: #F8F4E8; color: #8B7128; border-color: #E5D8B5; }

/* Filter chip color hints */
.wb-timeline__filter--procurement::before { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #2A4A6B; margin-right: 2px; }
.wb-timeline__filter--financial::before   { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #6B5A28; margin-right: 2px; }
.wb-timeline__filter--commission::before  { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #8B5A2B; margin-right: 2px; }
.wb-timeline__filter--lobbying::before    { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #5B4A7E; margin-right: 2px; }
.wb-timeline__filter--pump::before        { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #1E5C8B; margin-right: 2px; }
.wb-timeline__filter--litigation::before  { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #8B2B2B; margin-right: 2px; }
.wb-timeline__filter--regulatory::before  { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #2B6B3B; margin-right: 2px; }
.wb-timeline__filter--ukraine::before     { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #8B7128; margin-right: 2px; }
.wb-timeline__filter.is-active::before { display: none !important; }

.wb-timeline__content {
	min-width: 0;
}
.wb-timeline__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	font-family: var(--wb-font-mono);
	font-size: 10px;
	letter-spacing: 0.06em;
	color: var(--wb-ink-3);
	text-transform: uppercase;
	margin-bottom: 6px;
}
.wb-timeline__date {
	color: var(--wb-ink-2);
}
.wb-timeline__sep {
	color: var(--wb-line-2);
}
.wb-timeline__type-tag {
	color: var(--wb-accent);
}
.wb-timeline__headline {
	font-size: 16px;
	font-weight: 600;
	line-height: 1.3;
	letter-spacing: -0.005em;
	color: var(--wb-ink);
	margin: 0 0 8px;
}
.wb-timeline__body {
	font-size: 14px;
	line-height: 1.55;
	color: var(--wb-ink);
}
.wb-timeline__body p {
	margin: 0 0 8px;
}
.wb-timeline__body p:last-child {
	margin-bottom: 0;
}

.wb-timeline__footer {
	margin-top: 12px;
	padding-top: 10px;
	border-top: 0.5px dashed var(--wb-line-2);
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.wb-timeline__people,
.wb-timeline__source {
	font-family: var(--wb-font-mono);
	font-size: 10.5px;
	color: var(--wb-ink-3);
	line-height: 1.55;
}
.wb-timeline__footer-label {
	display: inline-block;
	min-width: 50px;
	color: var(--wb-accent);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-right: 6px;
}

.wb-timeline__cta {
	margin-top: 32px;
	padding-top: 20px;
	border-top: 0.5px solid var(--wb-line);
}
.wb-timeline__cta-body {
	font-size: 13px;
	color: var(--wb-ink-2);
	line-height: 1.6;
	margin: 0 0 12px;
}
.wb-timeline__cta-link {
	font-family: var(--wb-font-mono);
	font-size: 12px;
	color: var(--wb-accent);
	border-bottom: 1px solid var(--wb-accent);
	padding-bottom: 1px;
	text-decoration: none;
}

@media (min-width: 720px) {
	.wb-timeline__title { font-size: 36px; }
	.wb-timeline__event { grid-template-columns: 40px 1fr; gap: 18px; padding: 22px 0; }
	.wb-timeline__icon svg { width: 32px; height: 32px; padding: 6px; }
	.wb-timeline__headline { font-size: 18px; }
	.wb-timeline__body { font-size: 14.5px; }
}

@media (min-width: 960px) {
	.wb-timeline__filters { top: 72px; }
}
