/*
Theme Name: GeneratePress Contra
Theme URI: https://generatepress.com
Description: Child theme of GeneratePress recreating the contra.com/blog layout and design. Step 1: Contra-style header (logo, category nav, search) on a white background with Inter + DM Mono typography.
Author: Groovy Tracks
Template: generatepress
Version: 1.16.2
Text Domain: generatepress-contra
*/

/* ==========================================================================
   Design tokens
   ========================================================================== */
:root {
	--contra-bg: #ffffff;          /* page background (real Contra is white) */
	--contra-surface: #f5f6f9;     /* search field, subtle fills */
	--contra-ink: #14171f;         /* near-black */
	--contra-ink-2: #373f51;       /* secondary text */
	--contra-muted: #6b7280;       /* meta / labels */
	--contra-border: #e5e7eb;
	--contra-border-strong: #d0d4dc;
	--contra-accent: #beff6a;      /* lime */
	--contra-pink: #e6447e;        /* LATEST ticker badge */

	--contra-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--contra-mono: "DM Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
	--contra-serif: "Source Serif 4", Georgia, serif;

	--contra-maxw: 760px;
	--contra-wide: 1280px;
}

/* ==========================================================================
   Base
   ========================================================================== */
body.contra,
body.contra #page,
body.contra .site-content {
	background-color: var(--contra-bg);
	color: var(--contra-ink);
	font-family: var(--contra-font);
	-webkit-font-smoothing: antialiased;
}
body.contra .site-content {
	display: block;   /* defeat GP content+sidebar flex */
	padding: 0;
}
body.contra a { color: inherit; text-decoration: none; }

/* ==========================================================================
   Header (native GeneratePress, restyled for Contra)
   ========================================================================== */
body.contra .site-header {
	background-color: var(--contra-bg);
	border-bottom: 1px solid var(--contra-border);
}
body.contra .inside-header {
	position: relative;        /* anchor for the centered nav */
	max-width: var(--contra-wide);
	padding: 26px 32px;
	align-items: center;
}

/* Logo — the bundled mark is the brand; hide GP's text title/tagline */
body.contra .site-logo { margin: 0; line-height: 0; }
body.contra .site-logo img { height: 38px; width: auto; }
body.contra .site-branding { display: none; }

/* Primary navigation: absolutely centered in the bar */
body.contra #site-navigation.main-navigation {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	flex: 0 0 auto;
	margin: 0;
	background: transparent;
}
body.contra #site-navigation .inside-navigation {
	max-width: none;
	padding: 0;
}
body.contra .main-nav > ul {
	display: flex;
	align-items: center;
	gap: 30px;
	width: auto;
}
body.contra .main-nav ul li a {
	font-family: var(--contra-font);
	font-weight: 500;
	font-size: 15px;
	color: var(--contra-ink);
	padding: 8px 0;
	line-height: 1;
}
body.contra .main-nav ul li a:hover,
body.contra .main-nav .current-menu-item > a {
	color: var(--contra-ink-2);
	background: transparent;
}

/* Search pill (button that opens the modal) — pushed to the far right
   (nav is absolutely centered, so margin-left:auto pushes search to the edge) */
body.contra .contra-search-trigger { flex: 0 0 auto; margin-left: auto; }
body.contra button.contra-search-trigger {
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 280px;
	background-color: var(--contra-surface);
	border: 1px solid var(--contra-border);
	border-radius: 999px;
	padding: 9px 16px;
	color: var(--contra-muted);
	cursor: pointer;
	text-align: left;
	font-family: var(--contra-font);
	transition: border-color 0.15s ease, background-color 0.15s ease;
}
body.contra button.contra-search-trigger:hover { border-color: var(--contra-border-strong); }
.contra-search-icon { color: var(--contra-muted); flex: 0 0 auto; }
.contra-search-placeholder { font-size: 15px; color: var(--contra-muted); line-height: 1; }

/* ==========================================================================
   Search modal
   ========================================================================== */
.contra-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: flex-start;
	justify-content: center;
}
.contra-modal[hidden] { display: none; }
.contra-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(20, 23, 31, 0.55);
	backdrop-filter: blur(2px);
}
.contra-modal-panel {
	position: relative;
	margin-top: 11vh;
	width: min(680px, 92vw);
	max-height: 76vh;
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 24px 60px rgba(20, 23, 31, 0.28);
	overflow: hidden;
	animation: contra-modal-in 0.16s ease-out;
}
@keyframes contra-modal-in {
	from { opacity: 0; transform: translateY(-8px); }
	to { opacity: 1; transform: none; }
}
.contra-modal-search {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 18px 22px;
	border-bottom: 1px solid var(--contra-border);
}
.contra-modal-icon { color: var(--contra-muted); flex: 0 0 auto; }
.contra-modal-input {
	flex: 1 1 auto;
	border: none;
	outline: none;
	background: transparent;
	font-family: var(--contra-font);
	font-size: 18px;
	color: var(--contra-ink);
}
.contra-modal-input::placeholder { color: var(--contra-muted); }
body.contra button.contra-modal-clear {
	flex: 0 0 auto;
	background: transparent;
	background-color: transparent;
	border: none;
	padding: 4px 6px;
	cursor: pointer;
	font-family: var(--contra-mono);
	font-size: 12px;
	letter-spacing: 0.1em;
	color: var(--contra-muted);
}
body.contra button.contra-modal-clear:hover { color: var(--contra-ink); }

.contra-modal-results {
	list-style: none;
	margin: 0;
	padding: 8px;
	overflow-y: auto;
}
.contra-modal-results li { margin: 0; }
.contra-modal-result {
	display: block;
	padding: 12px 14px;
	border-radius: 10px;
	transition: background 0.12s ease;
}
.contra-modal-result:hover { background: var(--contra-surface); }
.contra-modal-result-title {
	display: block;
	font-size: 16px;
	font-weight: 600;
	color: var(--contra-ink);
	line-height: 1.3;
}
.contra-modal-result-excerpt {
	display: block;
	margin-top: 3px;
	font-size: 14px;
	color: var(--contra-muted);
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.contra-modal-empty {
	padding: 18px 16px;
	color: var(--contra-muted);
	font-size: 15px;
}

@media (max-width: 600px) {
	.contra-modal-panel { margin-top: 0; width: 100vw; max-height: 100vh; height: 100%; border-radius: 0; }
}

@media (max-width: 768px) {
	body.contra .inside-header { padding: 12px 18px; align-items: center; }

	/* Search collapses to a compact icon button, sat just left of the hamburger */
	body.contra .contra-search-trigger { margin-left: auto; flex: 0 0 auto; }
	body.contra button.contra-search-trigger {
		min-width: 0;
		width: 42px;
		height: 42px;
		padding: 0;
		justify-content: center;
	}
	body.contra .contra-search-placeholder { display: none; }

	/* Hamburger toggle: clean, transparent, dark icon, right after search */
	body.contra .mobile-menu-control-wrapper { margin-left: 8px; }
	body.contra .menu-toggle,
	body.contra .menu-toggle:hover,
	body.contra .menu-toggle:focus {
		background: transparent;
		color: var(--contra-ink);
		padding: 8px;
	}

	/* Dropdown menu: full-width list below the bar, left-aligned with dividers */
	body.contra #site-navigation.main-navigation {
		position: static;
		transform: none;
		left: auto;
		width: 100%;
		border-top: 1px solid var(--contra-border);
	}
	body.contra #site-navigation .inside-navigation { padding: 0; }
	body.contra .main-nav > ul {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		width: 100%;
	}
	body.contra .main-nav ul li { border-bottom: 1px solid var(--contra-border); }
	body.contra .main-nav ul li:last-child { border-bottom: none; }
	body.contra .main-nav ul li a {
		display: block;
		padding: 15px 2px;
		font-size: 16px;
		text-align: left;
	}
}

/* ==========================================================================
   Blog card grid
   ========================================================================== */
.contra-blog {
	max-width: var(--contra-wide);
	margin: 0 auto;
	padding: 56px 32px 96px;
}

/* ==========================================================================
   "LATEST" news ticker
   ========================================================================== */
.contra-ticker {
	background: var(--contra-surface);
	border-bottom: 1px solid var(--contra-border);
}
.contra-ticker-inner {
	max-width: var(--contra-wide);
	margin: 0 auto;
	display: flex;
	align-items: stretch;
}
.contra-ticker-label {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	padding: 0 20px;
	background: var(--contra-pink);
	color: #fff;
	font-family: var(--contra-font);
	font-weight: 800;
	font-style: italic;
	font-size: 13px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.contra-ticker-viewport {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	display: flex;
	align-items: center;
}
.contra-ticker-track {
	display: inline-flex;
	flex-wrap: nowrap;
	white-space: nowrap;
	will-change: transform;
	animation: contra-ticker 42s linear infinite;
}
.contra-ticker:hover .contra-ticker-track { animation-play-state: paused; }
@keyframes contra-ticker {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}
.contra-ticker-item {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 18px;
	padding: 11px 0;
	font-family: var(--contra-font);
	font-size: 14px;
	color: var(--contra-ink);
	transition: color 0.15s ease;
}
.contra-ticker-item:hover { color: var(--contra-pink); }
.contra-ticker-item::after {
	content: "|";
	margin-left: 18px;
	color: var(--contra-border-strong);
}
.contra-ticker-time {
	color: var(--contra-pink);
	font-weight: 600;
	font-size: 13px;
}
.contra-ticker-date {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	padding: 0 20px;
	white-space: nowrap;
	font-family: var(--contra-font);
	font-size: 13px;
	color: var(--contra-muted);
	border-left: 1px solid var(--contra-border);
}
@media (max-width: 640px) {
	.contra-ticker-date { display: none; }
	.contra-ticker-label { padding: 0 14px; font-size: 12px; }
}
@media (prefers-reduced-motion: reduce) {
	.contra-ticker-track { animation: none; }
}

/* ==========================================================================
   Featured slider
   ========================================================================== */
.contra-featured {
	position: relative;
	margin: 4px 0 72px;
}
.contra-fx-viewport { overflow: hidden; }
.contra-fx-track {
	display: flex;
	transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
	will-change: transform;
}
.contra-slide {
	flex: 0 0 100%;
	min-width: 0;
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 48px;
	align-items: center;
}
.contra-slide-media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 16 / 11;
	border-radius: 16px;
	overflow: hidden;
	background: var(--contra-ink);
}
.contra-slide-media .contra-card-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.contra-slide-body { padding-right: 24px; }
.contra-slide-title {
	font-family: var(--contra-font);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.08;
	font-size: clamp(28px, 3.6vw, 42px);
	margin: 8px 0 16px;
	color: var(--contra-ink);
}
.contra-slide:hover .contra-slide-title {
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 2px;
}
.contra-slide-excerpt {
	font-family: var(--contra-serif);
	font-size: 18px;
	line-height: 1.55;
	color: var(--contra-ink-2);
	margin: 0 0 20px;
	max-width: 46ch;
}

/* Arrows + dots */
body.contra .contra-fx-arrow {
	position: absolute;
	/* Center on the slide area, offset up by ~half the dots row below it. */
	top: calc(50% - 18px);
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	background-color: #fff;
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	cursor: pointer;
	z-index: 2;
	box-shadow: 0 2px 10px rgba(20, 23, 31, 0.12);
	transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
body.contra .contra-fx-arrow:hover {
	background-color: var(--contra-bg);
	border-color: var(--contra-ink);
	box-shadow: 0 4px 14px rgba(20, 23, 31, 0.18);
}
/* Explicit stroke beats GP's inline button{color:#fff} that the chevron's
   stroke="currentColor" would otherwise inherit (white on white). */
body.contra .contra-fx-arrow svg { display: block; }
body.contra .contra-fx-arrow svg path { stroke: var(--contra-ink); }
.contra-fx-prev { left: 8px; }
.contra-fx-next { right: 8px; }

.contra-fx-dots {
	display: flex;
	justify-content: center;
	gap: 9px;
	margin-top: 28px;
}
.contra-fx-dot {
	width: 8px;
	height: 8px;
	padding: 0;
	border: none;
	border-radius: 999px;
	background: var(--contra-border-strong);
	cursor: pointer;
	transition: background 0.15s ease, width 0.15s ease;
}
.contra-fx-dot.is-active { background: var(--contra-ink); width: 22px; }

@media (max-width: 768px) {
	.contra-slide { grid-template-columns: 1fr; gap: 22px; }
	.contra-slide-body { padding-right: 0; }
	.contra-fx-arrow { display: none; }
	.contra-featured { margin-bottom: 56px; }
}

/* ==========================================================================
   Category carousels (full-bleed rows)
   ========================================================================== */
/* Lift GP's 1200px #page cap on the blog home so the dark rows bleed full
   width. Inner containers keep content centred at our own max-width. */
body.contra.blog #page,
body.contra.home #page,
body.contra.single #page {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.contra-row {
	background: var(--contra-bg);
	padding: 72px 0;
}
.contra-row.is-dark {
	background: var(--contra-ink);
	color: #fff;
}
.contra-row-inner {
	max-width: var(--contra-wide);
	margin: 0 auto;
	padding: 0 32px;
}
.contra-row-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 32px;
}
.contra-row-title {
	font-family: var(--contra-font);
	font-weight: 700;
	letter-spacing: -0.02em;
	font-size: clamp(24px, 3vw, 34px);
	margin: 0;
	color: var(--contra-ink);
}
.contra-row.is-dark .contra-row-title { color: #fff; }
.contra-row-title a { color: inherit; }

.contra-row-nav { display: flex; gap: 10px; flex: 0 0 auto; }
body.contra .contra-row-arrow {
	width: 40px;
	height: 40px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	background-color: transparent;
	color: var(--contra-ink);
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	cursor: pointer;
	transition: background-color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}
body.contra .contra-row-arrow:hover { background-color: var(--contra-surface); border-color: var(--contra-ink); }
body.contra .contra-row-arrow svg path { stroke: var(--contra-ink); }
body.contra .contra-row.is-dark .contra-row-arrow { border-color: rgba(255, 255, 255, 0.35); }
body.contra .contra-row.is-dark .contra-row-arrow:hover { background-color: rgba(255, 255, 255, 0.12); border-color: #fff; }
body.contra .contra-row.is-dark .contra-row-arrow svg path { stroke: #fff; }

/* Horizontal scroller */
.contra-row-scroller {
	display: flex;
	gap: 22px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding-bottom: 4px;
}
.contra-row-scroller::-webkit-scrollbar { display: none; }
.contra-row-card {
	flex: 0 0 300px;
	scroll-snap-align: start;
}
@media (max-width: 600px) {
	.contra-row { padding: 48px 0; }
	.contra-row-inner { padding: 0 18px; }
	.contra-row-card { flex-basis: 78vw; }
}

/* Dark-row card text */
.contra-row.is-dark .contra-card-title { color: #fff; }
.contra-row.is-dark .contra-card-meta { color: rgba(255, 255, 255, 0.6); }
.contra-row.is-dark .contra-tag {
	color: rgba(255, 255, 255, 0.85);
	border-color: rgba(255, 255, 255, 0.25);
	background: transparent;
}
.contra-row.is-dark .contra-tag:hover {
	background: var(--contra-accent);
	color: var(--contra-ink);
	border-color: var(--contra-accent);
}

/* ==========================================================================
   Footer
   ========================================================================== */
.contra-footer {
	background: var(--contra-ink);
	color: #fff;
}
.contra-footer-inner {
	max-width: var(--contra-wide);
	margin: 0 auto;
	padding: 64px 32px 32px;
}
.contra-footer-top {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1.7fr;
	gap: 48px;
	align-items: start;
}
@media (max-width: 900px) {
	.contra-footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
	.contra-footer-news { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
	.contra-footer-top { grid-template-columns: 1fr; gap: 32px; }
	.contra-footer-inner { padding: 48px 18px 28px; }
}

.contra-footer-logo img { height: 40px; width: auto; display: block; }
.contra-footer-tagline {
	color: rgba(255, 255, 255, 0.6);
	font-size: 15px;
	line-height: 1.5;
	margin: 18px 0;
	max-width: 32ch;
}
.contra-footer-social { display: flex; gap: 12px; }
.contra-footer-social a {
	width: 38px;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.contra-footer-social a:hover { background: rgba(255, 255, 255, 0.1); border-color: #fff; }

.contra-footer-h {
	font-family: var(--contra-mono);
	font-size: 13px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.5);
	margin: 0 0 18px;
	font-weight: 400;
}
.contra-footer-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.contra-footer-menu li { margin: 0; }
.contra-footer-menu a {
	color: rgba(255, 255, 255, 0.85);
	font-size: 15px;
	transition: color 0.15s ease;
}
.contra-footer-menu a:hover { color: #fff; }

/* Newsletter (CF7 form) */
.contra-footer-news-text {
	color: rgba(255, 255, 255, 0.7);
	font-size: 15px;
	line-height: 1.5;
	margin: 0 0 18px;
	max-width: 40ch;
}
.contra-footer-news .wpcf7-form .contact_form {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
}
.contra-footer-news .wpcf7-form p { margin: 0; }
.contra-footer-news .wpcf7-form br { display: none; }
.contra-footer-news .wpcf7-form .contact_form > p:first-child,
.contra-footer-news .wpcf7-form-control-wrap { flex: 1 1 240px; display: block; }
body.contra .contra-footer-news input[type="email"] {
	width: 100%;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	padding: 13px 18px;
	color: #fff;
	font-family: var(--contra-font);
	font-size: 15px;
}
body.contra .contra-footer-news input[type="email"]::placeholder { color: rgba(255, 255, 255, 0.5); }
body.contra .contra-footer-news input[type="email"]:focus { outline: none; border-color: #fff; }
body.contra .contra-footer-news input[type="submit"] {
	background: var(--contra-accent);
	color: var(--contra-ink);
	border: none;
	border-radius: 999px;
	padding: 13px 28px;
	font-family: var(--contra-font);
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: filter 0.15s ease;
}
body.contra .contra-footer-news input[type="submit"]:hover { filter: brightness(0.94); }
.contra-footer-news .wpcf7-spinner { margin: 0 0 0 8px; }
.contra-footer-news .wpcf7-response-output {
	flex-basis: 100%;
	margin: 14px 0 0 !important;
	border-color: rgba(255, 255, 255, 0.3) !important;
	border-radius: 8px;
	color: #fff;
	font-size: 14px;
}

.contra-footer-bottom {
	margin-top: 56px;
	padding-top: 24px;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.contra-footer-bottom p { margin: 0; color: rgba(255, 255, 255, 0.5); font-size: 14px; }

/* ==========================================================================
   Article (single post)
   ========================================================================== */
.contra-single {
	max-width: 1180px;
	margin: 0 auto;
	padding: 56px 32px 0;
}
.contra-single-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: 56px;
	align-items: start;
}
@media (max-width: 980px) {
	.contra-single-grid { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 600px) {
	.contra-single { padding: 36px 18px 0; }
}

.contra-article { max-width: none; margin: 0; padding: 0; }
.contra-article-head,
.contra-article-body,
.contra-article-foot { max-width: none; margin-left: 0; margin-right: 0; }

/* Sticky "Latest articles" sidebar.
   The grid ITEM must be the sticky element (with align-self:start) — sticking
   an inner div fails because align-items:start shrinks the item to content. */
.contra-single-aside {
	position: sticky;
	top: 28px;
	align-self: start;
}
.contra-aside-title {
	font-family: var(--contra-mono);
	font-size: 13px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--contra-ink-2);
	margin: 0 0 8px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--contra-border);
}
.contra-aside-list { list-style: none; margin: 0; padding: 0; }
.contra-aside-list li { border-bottom: 1px solid var(--contra-border); }
.contra-aside-list li:last-child { border-bottom: none; }
.contra-aside-list a { display: flex; gap: 14px; align-items: flex-start; padding: 14px 0; }

.contra-aside-thumb {
	position: relative;
	flex: 0 0 auto;
	width: 66px;
	height: 66px;
	border-radius: 10px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--contra-ink);
}
.contra-aside-thumb .contra-card-fallback { width: 58%; max-width: 42px; opacity: 0.95; }
.contra-aside-thumb-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.contra-aside-text { min-width: 0; }
.contra-aside-item-title {
	display: block;
	font-family: var(--contra-font);
	font-weight: 600;
	font-size: 15px;
	line-height: 1.3;
	color: var(--contra-ink);
	transition: color 0.15s ease;
}
.contra-aside-list a:hover .contra-aside-item-title { color: var(--contra-ink-2); }
.contra-aside-item-meta {
	display: block;
	margin-top: 4px;
	font-family: var(--contra-font);
	font-size: 13px;
	color: var(--contra-muted);
}
@media (max-width: 980px) {
	.contra-single-aside { position: static; }
}

.contra-article-cats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 18px;
}
.contra-article-title {
	font-family: var(--contra-font);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.06;
	font-size: clamp(32px, 5.5vw, 56px);
	margin: 0 0 18px;
	color: var(--contra-ink);
}
.contra-article-meta {
	font-family: var(--contra-font);
	font-size: 15px;
	color: var(--contra-muted);
}

/* Hero (wider than the text column) */
.contra-article-hero {
	position: relative;
	width: 100%;
	margin: 40px 0;
	aspect-ratio: 16 / 9;
	border-radius: 18px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--contra-ink);
}
.contra-article-hero .contra-card-fallback { width: 34%; max-width: 170px; opacity: 0.95; }
.contra-article-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* Body typography */
.contra-article-body {
	font-family: var(--contra-serif);
	font-size: 20px;
	line-height: 1.7;
	color: #23262e;
}
.contra-article-body > p:first-child { font-size: 22px; }
.contra-article-body p { margin: 0 0 1.4em; }
.contra-article-body h2 {
	font-family: var(--contra-font);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.2;
	font-size: 28px;
	margin: 1.8em 0 0.6em;
	color: var(--contra-ink);
}
.contra-article-body h3 {
	font-family: var(--contra-font);
	font-weight: 700;
	font-size: 22px;
	margin: 1.6em 0 0.5em;
	color: var(--contra-ink);
}
.contra-article-body a {
	color: var(--contra-ink);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.contra-article-body img { max-width: 100%; height: auto; border-radius: 12px; }
.contra-article-body figure { margin: 1.8em 0; }
.contra-article-body figcaption { font-family: var(--contra-font); font-size: 14px; color: var(--contra-muted); margin-top: 8px; }
.contra-article-body blockquote {
	margin: 1.8em 0;
	padding: 4px 0 4px 24px;
	border-left: 3px solid var(--contra-ink);
	font-style: italic;
	color: var(--contra-ink);
}
.contra-article-body ul,
.contra-article-body ol { margin: 0 0 1.4em 1.2em; }
.contra-article-body li { margin: 0.4em 0; }
.contra-article-body iframe { max-width: 100%; border-radius: 12px; }

/* Foot: tags + back link, then share row */
.contra-article-foot {
	margin-top: 48px;
	padding-top: 28px;
	border-top: 1px solid var(--contra-border);
	display: flex;
	flex-direction: column;
	gap: 26px;
}
.contra-article-tags-row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	justify-content: space-between;
}
.contra-article-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.contra-article-tags a {
	font-family: var(--contra-mono);
	font-size: 12px;
	letter-spacing: 0.04em;
	color: var(--contra-ink-2);
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	padding: 5px 12px;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.contra-article-tags a:hover { background: var(--contra-accent); border-color: var(--contra-ink); color: var(--contra-ink); }
.contra-article-back { font-family: var(--contra-mono); font-size: 14px; color: var(--contra-ink-2); white-space: nowrap; }
.contra-article-back:hover { color: var(--contra-ink); }

/* Share row */
.contra-article-share { display: flex; align-items: center; gap: 16px; }
.contra-share-label {
	font-family: var(--contra-mono);
	font-size: 13px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--contra-ink-2);
}
.contra-share-btns { display: flex; gap: 10px; }
body.contra a.contra-share-btn,
body.contra button.contra-share-btn {
	width: 40px;
	height: 40px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	background-color: transparent;
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	color: var(--contra-ink);
	cursor: pointer;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}
body.contra a.contra-share-btn:hover,
body.contra button.contra-share-btn:hover { background-color: var(--contra-surface); border-color: var(--contra-ink); }
.contra-share-btn svg { display: block; }
.contra-share-copy.is-copied { background-color: var(--contra-accent) !important; border-color: var(--contra-ink) !important; }

/* Related posts */
.contra-related {
	background: var(--contra-surface);
	margin-top: 80px;
	padding: 64px 0;
}
.contra-related-inner {
	max-width: var(--contra-wide);
	margin: 0 auto;
	padding: 0 32px;
}
.contra-related .contra-row-title { margin-bottom: 28px; }
@media (max-width: 600px) {
	.contra-article { padding: 36px 18px 0; }
	.contra-related { padding: 48px 0; }
	.contra-related-inner { padding: 0 18px; }
}

.contra-archive-title {
	font-family: var(--contra-font);
	font-weight: 800;
	letter-spacing: -0.03em;
	font-size: clamp(32px, 5vw, 52px);
	margin: 0 0 40px;
	color: var(--contra-ink);
}

.contra-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	column-gap: 32px;
	row-gap: 56px;
}
@media (max-width: 980px) {
	.contra-grid { grid-template-columns: repeat(2, 1fr); row-gap: 44px; }
}
@media (max-width: 600px) {
	.contra-grid { grid-template-columns: 1fr; row-gap: 40px; }
	.contra-blog { padding: 32px 18px 72px; }
}

/* Card ------------------------------------------------------------------- */
.contra-card { display: flex; flex-direction: column; }

.contra-card-media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 16 / 10;
	border-radius: 16px;
	overflow: hidden;
	background: var(--contra-ink);
}
.contra-card-fallback {
	width: 42%;
	max-width: 150px;
	height: auto;
	opacity: 0.95;
}
.contra-card-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.contra-card-body { display: block; margin-top: 18px; }
.contra-card-meta {
	font-family: var(--contra-font);
	font-size: 14px;
	color: var(--contra-muted);
	margin: 0 0 8px;
}
.contra-card-title {
	font-family: var(--contra-font);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.25;
	font-size: 21px;
	margin: 0 0 14px;
	color: var(--contra-ink);
}
.contra-card:hover .contra-card-title {
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 2px;
}

.contra-post-cats { display: flex; flex-wrap: wrap; gap: 8px; }
.contra-tag {
	font-family: var(--contra-font);
	font-size: 13px;
	color: var(--contra-ink-2);
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	padding: 5px 14px;
	background: #fff;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.contra-tag:hover { background: var(--contra-accent); border-color: var(--contra-ink); color: var(--contra-ink); }

/* View more -------------------------------------------------------------- */
.contra-loadmore-wrap { display: flex; justify-content: center; margin-top: 64px; }
.contra-loadmore {
	font-family: var(--contra-font);
	font-size: 15px;
	font-weight: 600;
	color: var(--contra-ink);
	background: #fff;
	border: 1px solid var(--contra-border-strong);
	border-radius: 999px;
	padding: 13px 30px;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}
.contra-loadmore:hover { background: var(--contra-surface); border-color: var(--contra-ink); }
.contra-loadmore.is-loading { opacity: 0.55; cursor: default; }
