/* =========================================================================
   openAPen — main stylesheet
   Boxy modern vibrant design, mobile-first, overflow-safe.
   ========================================================================= */

/* ------------------------------ Tokens ---------------------------------- */
:root {
	/* Vibrant modern palette */
	--oa-primary:     #6C3CE1;
	--oa-primary-lt:  #8B5CF6;
	--oa-primary-dk:  #5521C6;
	--oa-secondary:   #F97066;
	--oa-tertiary:    #06B6D4;

	--oa-bg:          #FFFFFF;
	--oa-bg-soft:     #F6F7FB;
	--oa-bg-muted:    #EEF0F6;
	--oa-bg-cool:     #EEF2FF;

	--oa-ink:         #0F172A;
	--oa-text:        #334155;
	--oa-muted:       #64748B;
	--oa-line:        #D9DEE8;
	--oa-line-soft:   #E7EAF1;

	--oa-accent:      var(--oa-secondary);
	--oa-accent-ink:  #C2410C;
	--oa-accent-bg:   #FFF1F0;

	--oa-danger:      #EF4444;
	--oa-success:     #10B981;
	--oa-info:        #6C3CE1;
	--oa-warn:        #F59E0B;

	/* Boxy radii (smaller, more rectangular) */
	--oa-radius:    8px;
	--oa-radius-sm: 4px;
	--oa-radius-lg: 12px;

	/* Stronger, more defined shadows */
	--oa-shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .05);
	--oa-shadow:    0 4px 12px -2px rgba(15, 23, 42, .10), 0 2px 6px -2px rgba(15, 23, 42, .06);
	--oa-shadow-lg: 0 14px 30px -6px rgba(15, 23, 42, .18), 0 6px 12px -4px rgba(15, 23, 42, .08);
	--oa-shadow-xl: 0 24px 50px -10px rgba(108, 60, 225, .28), 0 10px 20px -8px rgba(15, 23, 42, .12);
	--oa-shadow-hover: 0 18px 36px -8px rgba(108, 60, 225, .22), 0 8px 16px -6px rgba(15, 23, 42, .12);

	--oa-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	--oa-font-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;

	--oa-container: 1240px;
	--oa-container-narrow: 740px;
	--oa-gap: 28px;

	--oa-header-h: 64px;
}

/* ------------------------------ Reset / overflow safety ----------------- */
*, *::before, *::after { box-sizing: border-box; }
html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	overflow-x: hidden;
}
body {
	margin: 0;
	font-family: var(--oa-font-sans);
	font-size: 16px;
	line-height: 1.65;
	color: var(--oa-text);
	background: var(--oa-bg-soft);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	max-width: 100%;
}
img, svg, video, canvas, iframe, embed, object {
	max-width: 100%;
	height: auto;
	display: block;
}
a { color: var(--oa-primary); text-decoration: none; transition: color .2s ease; word-wrap: break-word; }
a:hover { color: var(--oa-primary-lt); }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
input, textarea, select { font: inherit; color: inherit; max-width: 100%; }
table { max-width: 100%; }

/* Universal word breaking — stops long URLs/titles from overflowing */
h1, h2, h3, h4, h5, h6, p, li, dd, dt, figcaption, blockquote {
	overflow-wrap: break-word;
	word-wrap: break-word;
	hyphens: auto;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--oa-font-serif);
	color: var(--oa-ink);
	margin: 0 0 .5em;
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.2;
}
h1 { font-size: clamp(1.75rem, 5vw + .3rem, 3rem); }
h2 { font-size: clamp(1.4rem, 3vw + .4rem, 2.05rem); }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.05rem; }
p  { margin: 0 0 1em; }

::selection { background: var(--oa-primary); color: #fff; }

.screen-reader-text {
	position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px;
	overflow: hidden; word-wrap: normal !important; white-space: nowrap;
}
.skip-link {
	position: absolute; left: -9999px; top: 0; z-index: 9999; padding: 12px 20px;
	background: var(--oa-primary); color: #fff; border-radius: 0 0 var(--oa-radius-sm) 0;
}
.skip-link:focus { left: 0; }

/* ----------------------------- Layout ----------------------------------- */
.container {
	max-width: var(--oa-container);
	width: 100%;
	margin: 0 auto;
	padding: 0 16px;
}
.layout-narrow {
	max-width: var(--oa-container-narrow);
	width: 100%;
	padding: 0 16px;
	margin: 0 auto;
}
.layout-full {
	max-width: 100%;
	padding: 0 16px;
}

/* 6" phones (≈360-380px) — slightly more padding */
@media (min-width: 380px) {
	.container, .layout-narrow, .layout-full { padding: 0 20px; }
}

/* 6.5"/7" phones (≈412-480px) */
@media (min-width: 480px) {
	.container, .layout-narrow, .layout-full { padding: 0 24px; }
}

/* Tablets portrait (768px) */
@media (min-width: 768px) {
	.container, .layout-narrow { padding: 0 32px; }
}

/* Tablets landscape / small desktops (1024px) */
@media (min-width: 1024px) {
	.container { padding: 0 40px; }
}

.layout-with-sidebar {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 32px;
	padding-top: 32px;
	padding-bottom: 48px;
}

@media (min-width: 1024px) {
	.layout-with-sidebar {
		grid-template-columns: minmax(0, 1fr) 320px;
		gap: var(--oa-gap);
		padding-top: 48px;
		padding-bottom: 64px;
	}
}

.section { padding: 40px 0; }

@media (min-width: 480px) {
	.section { padding: 52px 0; }
}

@media (min-width: 768px) {
	.section { padding: 68px 0; }
}

/* ------------------------------ Buttons --------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 11px 20px;
	border-radius: var(--oa-radius);
	font-weight: 600;
	font-size: .9rem;
	border: 1px solid transparent;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
	cursor: pointer;
	white-space: nowrap;
	text-decoration: none;
	min-height: 44px;
	max-width: 100%;
}
.btn-primary {
	background: linear-gradient(135deg, var(--oa-primary) 0%, var(--oa-primary-lt) 100%);
	color: #fff;
	box-shadow: 0 2px 0 var(--oa-primary-dk), 0 4px 14px rgba(108, 60, 225, .35);
}
.btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 0 var(--oa-primary-dk), 0 10px 24px rgba(108, 60, 225, .45);
	color: #fff;
}
.btn-primary:active {
	transform: translateY(0);
	box-shadow: 0 1px 0 var(--oa-primary-dk), 0 2px 8px rgba(108, 60, 225, .3);
}
.btn-ghost {
	background: var(--oa-bg);
	color: var(--oa-ink);
	border-color: var(--oa-line);
	box-shadow: 0 2px 0 var(--oa-line-soft);
}
.btn-ghost:hover {
	background: var(--oa-bg);
	color: var(--oa-primary);
	border-color: var(--oa-primary);
	transform: translateY(-2px);
	box-shadow: 0 4px 0 rgba(108, 60, 225, .15), 0 8px 20px rgba(108, 60, 225, .15);
}
.btn-outline {
	background: transparent;
	color: var(--oa-primary);
	border-color: var(--oa-primary);
}
.btn-outline:hover {
	background: var(--oa-primary);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(108, 60, 225, .3);
}
.btn-lg { padding: 14px 28px; font-size: .98rem; }
.btn-sm { padding: 8px 14px; font-size: .82rem; min-height: 38px; }
.btn:focus-visible { outline: 3px solid var(--oa-primary-lt); outline-offset: 2px; }

/* ------------------------------ Header ---------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255, 255, 255, .9);
	backdrop-filter: saturate(180%) blur(14px);
	-webkit-backdrop-filter: saturate(180%) blur(14px);
	border-bottom: 1px solid var(--oa-line);
	box-shadow: 0 1px 0 rgba(15, 23, 42, .03);
}
.site-header__top {
	display: flex;
	align-items: center;
	gap: 8px;
	min-height: var(--oa-header-h);
	flex-wrap: wrap;
	padding: 8px 0;
}
.site-branding { margin-right: auto; min-width: 0; flex-shrink: 1; }
.site-branding a { display: inline-flex; align-items: center; gap: 10px; min-width: 0; }
.site-logo-mark {
	display: inline-flex;
	width: 38px;
	height: 38px;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--oa-primary) 0%, var(--oa-secondary) 100%);
	color: #fff;
	border-radius: var(--oa-radius);
	box-shadow: 0 4px 12px rgba(108, 60, 225, .3);
}
.site-title {
	font-family: var(--oa-font-serif);
	font-weight: 700;
	font-size: 1.2rem;
	line-height: 1.1;
	color: var(--oa-ink);
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media (min-width: 480px) {
	.site-title { font-size: 1.3rem; }
}
.site-description {
	font-size: .76rem;
	color: var(--oa-muted);
	display: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media (min-width: 640px) {
	.site-description { display: block; }
}
.site-title-text {
	display: inline-flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.custom-logo-link img { max-height: 40px; width: auto; }

.main-navigation { display: none; }
.main-navigation .menu, .main-navigation ul {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: 22px; align-items: center;
	flex-wrap: wrap;
}
.main-navigation a {
	font-weight: 500;
	color: var(--oa-text);
	position: relative;
	padding: 8px 0;
}
.main-navigation a:hover, .main-navigation .current-menu-item > a { color: var(--oa-primary); }
.main-navigation .current-menu-item > a::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--oa-primary), var(--oa-secondary));
	border-radius: 2px;
}

@media (min-width: 1024px) {
	.main-navigation { display: block; flex: 1; min-width: 0; }
	.main-navigation .menu { justify-content: center; }
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
.search-toggle {
	width: 42px;
	height: 42px;
	border-radius: var(--oa-radius);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--oa-text);
	transition: background .2s ease, color .2s ease, transform .2s ease;
}
.search-toggle:hover {
	background: var(--oa-bg-cool);
	color: var(--oa-primary);
	transform: translateY(-1px);
}

.menu-toggle {
	width: 44px;
	height: 44px;
	border-radius: var(--oa-radius);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background .2s ease;
	flex-shrink: 0;
}
.menu-toggle:hover { background: var(--oa-bg-muted); }
.menu-toggle__bars { width: 22px; height: 16px; position: relative; display: block; }
.menu-toggle__bars span {
	position: absolute;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--oa-ink);
	border-radius: 2px;
	transition: transform .25s ease, top .25s ease, opacity .15s ease;
}
.menu-toggle__bars span:nth-child(1) { top: 0; }
.menu-toggle__bars span:nth-child(2) { top: 7px; }
.menu-toggle__bars span:nth-child(3) { top: 14px; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

@media (min-width: 1024px) {
	.menu-toggle { display: none; }
}

/* Mobile slide-down */
@media (max-width: 1023px) {
	.main-navigation {
		flex-basis: 100%;
		order: 99;
		display: none;
		padding: 12px 0 16px;
		border-top: 1px solid var(--oa-line-soft);
		margin-top: 8px;
	}
	.main-navigation.is-open { display: block; }
	.main-navigation .menu { flex-direction: column; gap: 2px; align-items: stretch; }
	.main-navigation a {
		display: block;
		padding: 14px 12px;
		border: 1px solid transparent;
		border-radius: var(--oa-radius);
		font-size: 1rem;
	}
	.main-navigation a:hover {
		color: var(--oa-primary);
		background: var(--oa-bg-cool);
		border-color: var(--oa-line-soft);
	}
}

.site-search-panel {
	border-top: 1px solid var(--oa-line-soft);
	padding: 16px 0;
	background: var(--oa-bg);
}
.site-search-panel[hidden] { display: none; }

.site-header__actions .btn { padding: 9px 16px; font-size: .85rem; min-height: 40px; }

/* Hide CTA button on small phones; menu/search remain */
@media (max-width: 479px) {
	.site-header__actions .btn { display: none; }
}

/* ------------------------------ Hero ------------------------------------ */
.hero {
	position: relative;
	padding: 48px 0 40px;
	overflow: hidden;
}

@media (min-width: 480px) {
	.hero { padding: 60px 0 48px; }
}

@media (min-width: 768px) {
	.hero { padding: 80px 0 64px; }
}

@media (min-width: 1024px) {
	.hero { padding: 96px 0 76px; }
}

.hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	background:
		radial-gradient(55% 55% at 85% 5%, rgba(108, 60, 225, .10) 0%, transparent 60%),
		radial-gradient(45% 45% at 5% 95%, rgba(249, 112, 102, .08) 0%, transparent 60%),
		radial-gradient(35% 35% at 50% 50%, rgba(6, 182, 212, .05) 0%, transparent 60%),
		linear-gradient(180deg, var(--oa-bg) 0%, var(--oa-bg-soft) 100%);
}
.hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
	align-items: end;
}

@media (min-width: 768px) {
	.hero__inner { gap: 40px; }
}

@media (min-width: 1024px) {
	.hero__inner { grid-template-columns: 1fr 1fr; gap: 56px; }
}

.hero__eyebrow {
	display: inline-block;
	font-size: .74rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--oa-primary);
	background: var(--oa-bg-cool);
	padding: 6px 12px;
	border-radius: 999px;
	font-weight: 700;
	border: 1px solid #C7D2FE;
}
.hero__title {
	font-size: clamp(1.85rem, 7vw + .2rem, 3.6rem);
	margin: 14px 0 12px;
}
.hero__brand {
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-secondary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	font-style: italic;
}
.hero__subtitle { font-size: 1rem; color: var(--oa-muted); max-width: 540px; line-height: 1.6; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }

/* Stack CTAs full-width on smallest phones */
@media (max-width: 379px) {
	.hero__cta { flex-direction: column; align-items: stretch; }
	.hero__cta .btn { width: 100%; }
}

.hero__meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	padding: 16px;
	background: rgba(255, 255, 255, .8);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	backdrop-filter: blur(8px);
	box-shadow: var(--oa-shadow-sm);
}

@media (min-width: 480px) {
	.hero__meta { gap: 14px; padding: 20px; }
}

@media (min-width: 768px) {
	.hero__meta { gap: 20px; padding: 24px; }
}

.hero__stat { min-width: 0; }
.hero__stat-num {
	display: block;
	font-family: var(--oa-font-serif);
	font-size: clamp(1.3rem, 4vw, 1.85rem);
	font-weight: 700;
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-secondary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1.1;
}
.hero__stat-label {
	display: block;
	font-size: .68rem;
	color: var(--oa-muted);
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-top: 4px;
	line-height: 1.3;
}

@media (min-width: 480px) {
	.hero__stat-label { font-size: .72rem; }
}

/* ------------------------------ Sections -------------------------------- */
.section__header {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 12px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}
.section__eyebrow {
	display: block;
	font-size: .73rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--oa-muted);
	margin-bottom: 6px;
	font-weight: 700;
}
.section__title { margin: 0; }
.section__link { font-weight: 600; color: var(--oa-primary); white-space: nowrap; }
.section__link:hover { color: var(--oa-secondary); }

/* ------------------------------ Featured -------------------------------- */
.featured-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 600px) {
	.featured-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
}

@media (min-width: 1024px) {
	.featured-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		grid-template-rows: auto auto;
		gap: 24px;
	}
	.featured-card--lead { grid-column: span 2; grid-row: span 2; }
}

.featured-card {
	display: flex;
	flex-direction: column;
	border-radius: var(--oa-radius-lg);
	overflow: hidden;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	box-shadow: var(--oa-shadow-sm);
	min-width: 0;
}
.featured-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--oa-shadow-hover);
	border-color: var(--oa-primary);
}
.featured-card__media {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--oa-bg-muted);
	position: relative;
}
.featured-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .5s ease;
}
.featured-card:hover .featured-card__media img { transform: scale(1.06); }
.featured-card__placeholder {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--oa-bg-muted) 0%, var(--oa-bg-cool) 100%);
	color: var(--oa-muted);
}
.featured-card__placeholder::after {
	content: '';
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(108, 60, 225, .15), rgba(249, 112, 102, .12));
}
.featured-card--lead .featured-card__media { aspect-ratio: 16 / 9; }
.featured-card__body {
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-width: 0;
}
@media (min-width: 768px) { .featured-card__body { padding: 22px; } }
.featured-card__title { font-size: 1.15rem; margin: 0; line-height: 1.3; }
.featured-card--lead .featured-card__title { font-size: clamp(1.3rem, 2.6vw, 1.85rem); }
.featured-card__title a { color: var(--oa-ink); }
.featured-card__title a:hover { color: var(--oa-primary); }
.featured-card__excerpt {
	color: var(--oa-muted);
	margin: 0;
	font-size: .92rem;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ------------------------------ Post grid ------------------------------- */
.post-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: minmax(0, 1fr);
}

/* 600px+ phones in landscape / small tablets: 2 columns */
@media (min-width: 600px) {
	.post-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
}

/* On tablets+ (with sidebar) keep 2-col with comfortable gap */
@media (min-width: 1024px) {
	.post-grid { gap: 24px; }
}

.post-grid--three { grid-template-columns: minmax(0, 1fr); }
@media (min-width: 600px) { .post-grid--three { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 900px) { .post-grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

.post-card {
	display: flex;
	flex-direction: column;
	border-radius: var(--oa-radius-lg);
	overflow: hidden;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	position: relative;
	box-shadow: var(--oa-shadow-sm);
	min-width: 0;
}
.post-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--oa-primary), var(--oa-secondary), var(--oa-tertiary));
	opacity: 0;
	transition: opacity .25s ease;
	z-index: 2;
}
.post-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--oa-shadow-hover);
	border-color: var(--oa-primary);
}
.post-card:hover::before { opacity: 1; }
.post-card__media {
	aspect-ratio: 16 / 10;
	background: var(--oa-bg-muted);
	display: block;
	overflow: hidden;
	position: relative;
}
.post-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .5s ease;
}
.post-card:hover .post-card__media img { transform: scale(1.06); }
.post-card__placeholder {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--oa-bg-muted) 0%, var(--oa-bg-cool) 100%);
	color: var(--oa-muted);
}
.post-card__body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
	min-width: 0;
}
@media (min-width: 768px) { .post-card__body { padding: 20px; } }
.post-card__title { font-size: 1.1rem; margin: 0; line-height: 1.3; }
.post-card__title a { color: var(--oa-ink); }
.post-card__title a:hover { color: var(--oa-primary); }
.post-card__excerpt {
	color: var(--oa-muted);
	margin: 0;
	font-size: .9rem;
	flex: 1;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ------------------------------ Meta / categories ----------------------- */
.post-category {
	display: inline-block;
	padding: 4px 10px;
	font-size: .68rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--oa-primary);
	background: var(--oa-bg-cool);
	border: 1px solid #C7D2FE;
	border-radius: var(--oa-radius-sm);
	font-weight: 700;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.post-category:hover { background: var(--oa-primary); color: #fff; border-color: var(--oa-primary); }
.post-category--lg { font-size: .74rem; padding: 6px 14px; margin-bottom: 14px; }
.post-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	font-size: .8rem;
	color: var(--oa-muted);
}
.post-meta__sep { opacity: .45; }
.post-meta a { color: inherit; }
.post-meta a:hover { color: var(--oa-primary); }

/* ------------------------------ Archive header -------------------------- */
.archive-header {
	text-align: center;
	margin-bottom: 28px;
	padding: 16px 0 4px;
}
.archive-eyebrow {
	display: inline-block;
	font-size: .76rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--oa-primary);
	background: var(--oa-bg-cool);
	border: 1px solid #C7D2FE;
	padding: 6px 14px;
	border-radius: 999px;
	font-weight: 700;
}
.archive-title { margin: 12px 0 8px; }
.archive-title em { font-style: normal; color: var(--oa-primary); }
.archive-description { color: var(--oa-muted); max-width: 600px; margin: 0 auto; }

/* ------------------------------ Single post ----------------------------- */
.single-post { padding-top: 32px; min-width: 0; }

@media (min-width: 768px) { .single-post { padding-top: 48px; } }

.single-post .entry-header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 28px;
}
.entry-title { font-size: clamp(1.6rem, 4.8vw + .2rem, 2.85rem); margin: 12px 0 14px; }
.entry-subtitle {
	color: var(--oa-muted);
	font-size: 1.05rem;
	max-width: 600px;
	margin: 0 auto 16px;
	line-height: 1.55;
}
.entry-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
	padding: 16px 0;
	border-top: 1px solid var(--oa-line-soft);
	border-bottom: 1px solid var(--oa-line-soft);
	margin-top: 14px;
}
.entry-meta__author {
	display: flex;
	align-items: center;
	gap: 12px;
	text-align: left;
	min-width: 0;
}
.entry-meta__avatar {
	border-radius: 50%;
	border: 2px solid var(--oa-bg-cool);
	flex-shrink: 0;
}
.entry-meta__byline { display: block; font-weight: 600; color: var(--oa-ink); }
.entry-meta__byline a { color: var(--oa-primary); }
.entry-meta__details { display: block; font-size: .82rem; color: var(--oa-muted); }
.entry-meta__actions {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.entry-featured {
	margin: 28px 0;
	border-radius: var(--oa-radius-lg);
	overflow: hidden;
	max-width: 100%;
	box-shadow: var(--oa-shadow);
	border: 1px solid var(--oa-line-soft);
}
.entry-featured img { width: 100%; max-height: 540px; object-fit: cover; }
.entry-featured figcaption {
	font-size: .82rem;
	color: var(--oa-muted);
	margin: 8px 0 0;
	padding: 0 12px 12px;
	text-align: center;
}

.entry-content {
	font-size: 1.02rem;
	line-height: 1.8;
	max-width: 700px;
	margin: 0 auto;
	min-width: 0;
}
.entry-content > * { max-width: 100%; }
.entry-content p,
.entry-content ul,
.entry-content ol,
.entry-content blockquote,
.entry-content figure,
.entry-content pre,
.entry-content table { margin-bottom: 1.4em; }
.entry-content h2 { margin-top: 1.8em; }
.entry-content h3 { margin-top: 1.5em; }
.entry-content blockquote {
	border-left: 4px solid var(--oa-primary);
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--oa-bg-cool) 0%, rgba(108, 60, 225, .04) 100%);
	font-family: var(--oa-font-serif);
	font-style: italic;
	color: var(--oa-ink);
	font-size: 1.1rem;
	border-radius: 0 var(--oa-radius) var(--oa-radius) 0;
}
.entry-content a {
	color: var(--oa-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1.5px;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.entry-content a:hover { color: var(--oa-secondary); }
.entry-content img {
	border-radius: var(--oa-radius);
	margin: 1.4em 0;
	height: auto;
}
.entry-content code {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
	background: var(--oa-bg-muted);
	padding: 2px 6px;
	border-radius: var(--oa-radius-sm);
	font-size: .9em;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.entry-content pre {
	background: var(--oa-ink);
	color: #E2E8F0;
	padding: 16px 20px;
	border-radius: var(--oa-radius);
	overflow-x: auto;
	font-size: .88rem;
	max-width: 100%;
	-webkit-overflow-scrolling: touch;
}
.entry-content pre code { background: transparent; color: inherit; padding: 0; }
.entry-content ul, .entry-content ol { padding-left: 1.4em; }
.entry-content li { margin-bottom: .4em; }
.entry-content hr { border: 0; border-top: 2px solid var(--oa-line); margin: 2em 0; }

/* Tables become horizontally scrollable on small screens */
.entry-content table,
.wp-block-table table {
	display: block;
	overflow-x: auto;
	max-width: 100%;
	border-collapse: collapse;
	-webkit-overflow-scrolling: touch;
}
@media (min-width: 768px) {
	.entry-content table,
	.wp-block-table table { display: table; width: 100%; }
}

/* alignwide / alignfull — only break out at wider breakpoints to avoid overflow */
.alignwide { margin-left: 0; margin-right: 0; max-width: 100%; width: 100%; }
@media (min-width: 1024px) {
	.alignwide { margin-left: -8%; margin-right: -8%; max-width: none; width: auto; }
}
.alignfull { margin-left: 0; margin-right: 0; max-width: 100%; width: 100%; }
@media (min-width: 768px) {
	.alignfull {
		margin-left: calc(50% - 50vw + 8px);
		margin-right: calc(50% - 50vw + 8px);
		max-width: none;
		width: calc(100vw - 16px);
	}
}
.aligncenter { text-align: center; margin: 1.5em auto; }

.entry-footer {
	max-width: 700px;
	margin: 28px auto 0;
	padding-top: 20px;
	border-top: 1px solid var(--oa-line-soft);
	display: flex;
	flex-wrap: wrap;
	gap: 12px 18px;
	align-items: center;
	justify-content: space-between;
}
.entry-tags { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.entry-tags__label { font-size: .82rem; color: var(--oa-muted); margin-right: 4px; font-weight: 600; }
.tag {
	display: inline-block;
	padding: 4px 10px;
	background: var(--oa-bg-muted);
	color: var(--oa-text);
	font-size: .82rem;
	border-radius: var(--oa-radius-sm);
	border: 1px solid var(--oa-line);
	transition: all .2s ease;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.tag:hover {
	background: var(--oa-bg-cool);
	color: var(--oa-primary);
	border-color: var(--oa-primary);
	transform: translateY(-1px);
	box-shadow: 0 4px 8px rgba(108, 60, 225, .15);
}
.entry-share { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.entry-share__label { font-size: .82rem; color: var(--oa-muted); font-weight: 600; }

.share-links { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.share-link {
	display: inline-flex;
	width: 38px;
	height: 38px;
	border-radius: var(--oa-radius);
	align-items: center;
	justify-content: center;
	color: var(--oa-muted);
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	transition: all .2s ease;
}
.share-link:hover {
	color: #fff;
	background: var(--oa-primary);
	border-color: var(--oa-primary);
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(108, 60, 225, .3);
}

.author-bio {
	display: flex;
	gap: 16px;
	padding: 20px;
	margin: 40px auto 0;
	max-width: 700px;
	background: linear-gradient(135deg, var(--oa-bg) 0%, var(--oa-bg-cool) 100%);
	border-radius: var(--oa-radius-lg);
	border: 1px solid var(--oa-line);
	box-shadow: var(--oa-shadow-sm);
	transition: box-shadow .25s ease, transform .25s ease;
}
.author-bio:hover { box-shadow: var(--oa-shadow); transform: translateY(-2px); }

@media (min-width: 480px) {
	.author-bio { padding: 24px; gap: 18px; }
}

.author-bio__avatar {
	border-radius: 50%;
	flex-shrink: 0;
	border: 3px solid var(--oa-bg);
	box-shadow: var(--oa-shadow-sm);
}
.author-bio__label {
	font-size: .73rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--oa-muted);
	display: block;
	margin-bottom: 4px;
	font-weight: 700;
}
.author-bio__name { margin: 0 0 6px; font-size: 1.2rem; }
.author-bio__name a { color: var(--oa-ink); }
.author-bio__desc { color: var(--oa-muted); margin: 0 0 10px; line-height: 1.55; }
.author-bio__more { color: var(--oa-primary); font-weight: 600; }

@media (max-width: 479px) {
	.author-bio { flex-direction: column; text-align: center; align-items: center; }
}

.related-posts { margin: 48px 0 24px; }
.related-posts__title { font-size: 1.35rem; margin-bottom: 18px; }

.post-navigation { margin: 36px auto 0; max-width: 800px; }
.post-navigation .nav-links {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}
@media (min-width: 600px) { .post-navigation .nav-links { grid-template-columns: 1fr 1fr; } }
.post-navigation a {
	display: block;
	padding: 14px 16px;
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	transition: all .2s ease;
	background: var(--oa-bg);
	box-shadow: var(--oa-shadow-sm);
}
.post-navigation a:hover {
	border-color: var(--oa-primary);
	transform: translateY(-3px);
	box-shadow: var(--oa-shadow-lg);
}
.post-navigation .nav-subtitle {
	display: block;
	font-size: .73rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--oa-muted);
	margin-bottom: 4px;
	font-weight: 700;
}
.post-navigation .nav-title {
	display: block;
	font-family: var(--oa-font-serif);
	font-weight: 700;
	color: var(--oa-ink);
}
.post-navigation .nav-next { text-align: right; }

/* ------------------------------ Pages ----------------------------------- */
.single-page { padding: 32px 0; }
.entry-header--page { text-align: center; margin-bottom: 28px; }
.prose { font-size: 1rem; line-height: 1.75; }
.prose h2 { margin-top: 1.8em; }
.prose h3 { margin-top: 1.5em; }

.oa-contact-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: minmax(0, 1fr);
	margin: 24px 0;
}

@media (min-width: 600px) {
	.oa-contact-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.oa-contact-card {
	padding: 18px;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	box-shadow: var(--oa-shadow-sm);
	transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
}
.oa-contact-card:hover {
	box-shadow: var(--oa-shadow-lg);
	border-color: var(--oa-primary);
	transform: translateY(-3px);
}
.oa-contact-card h3 { margin: 0 0 6px; font-size: 1.05rem; }
.oa-contact-card p { margin: 0 0 6px; color: var(--oa-muted); }

/* ------------------------------ Forms ----------------------------------- */
.oa-form {
	margin-top: 24px;
	padding: 20px;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	box-shadow: var(--oa-shadow-sm);
}

@media (min-width: 480px) { .oa-form { padding: 28px; } }
@media (min-width: 768px) { .oa-form { padding: 32px; } }

.oa-form__row {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 14px;
	margin-bottom: 14px;
}

@media (min-width: 600px) {
	.oa-form__row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.oa-form__field { display: flex; flex-direction: column; margin-bottom: 14px; }
.oa-form__field label {
	font-weight: 600;
	font-size: .9rem;
	margin-bottom: 6px;
	color: var(--oa-ink);
}
.oa-form__field .req { color: var(--oa-secondary); }
.oa-form__field small { color: var(--oa-muted); font-size: .8rem; margin-top: 4px; }
.oa-form input[type="text"],
.oa-form input[type="email"],
.oa-form input[type="url"],
.oa-form input[type="search"],
.oa-form input[type="file"],
.oa-form textarea,
.oa-form select {
	width: 100%;
	max-width: 100%;
	padding: 12px 14px;
	border: 1.5px solid var(--oa-line);
	border-radius: var(--oa-radius);
	background: var(--oa-bg-soft);
	transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.oa-form input:focus, .oa-form textarea:focus, .oa-form select:focus {
	outline: none;
	border-color: var(--oa-primary);
	box-shadow: 0 0 0 4px rgba(108, 60, 225, .12);
	background: var(--oa-bg);
}
.oa-form textarea { resize: vertical; min-height: 110px; }
.oa-form__check {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	margin: 14px 0;
	font-size: .9rem;
	color: var(--oa-muted);
}
.oa-form__check input { margin-top: 3px; accent-color: var(--oa-primary); }

/* WP comment form */
.comment-form {
	padding: 20px;
	background: var(--oa-bg);
	border-radius: var(--oa-radius-lg);
	border: 1px solid var(--oa-line);
	box-shadow: var(--oa-shadow-sm);
	margin-top: 24px;
}

@media (min-width: 480px) { .comment-form { padding: 26px; } }

.comment-form p { margin: 0 0 14px; }
.comment-form label { display: block; font-weight: 600; margin-bottom: 6px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	max-width: 100%;
	padding: 12px 14px;
	border: 1.5px solid var(--oa-line);
	border-radius: var(--oa-radius);
	background: var(--oa-bg-soft);
}
.comment-form input:focus, .comment-form textarea:focus {
	outline: none;
	border-color: var(--oa-primary);
	box-shadow: 0 0 0 4px rgba(108, 60, 225, .12);
	background: var(--oa-bg);
}

/* Search form */
.search-form__inner {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 5px 5px 5px 12px;
	background: var(--oa-bg);
	border: 1.5px solid var(--oa-line);
	border-radius: var(--oa-radius);
	transition: border-color .2s ease, box-shadow .2s ease;
	max-width: 100%;
}
.search-form__inner:focus-within {
	border-color: var(--oa-primary);
	box-shadow: 0 0 0 4px rgba(108, 60, 225, .12);
}
.search-form__icon { color: var(--oa-muted); flex-shrink: 0; }
.search-form .search-field {
	border: 0;
	flex: 1;
	padding: 10px 4px;
	background: transparent;
	min-width: 0;
	width: 100%;
}
.search-form .search-field:focus { outline: none; }
.search-form .search-submit {
	padding: 9px 16px;
	border-radius: var(--oa-radius-sm);
	min-height: 38px;
}

/* Alerts */
.alert {
	padding: 14px 16px;
	border-radius: var(--oa-radius);
	margin: 16px 0;
	border: 1px solid;
	border-left: 4px solid;
	box-shadow: var(--oa-shadow-sm);
}
.alert p { margin: 6px 0 0; }
.alert ul { margin: 8px 0 0; padding-left: 20px; }
.alert-success { background: #ECFDF5; border-color: #A7F3D0; color: #065F46; }
.alert-error   { background: #FEF2F2; border-color: #FECACA; color: #991B1B; }
.alert-info    { background: #EEF2FF; border-color: #C7D2FE; color: #3730A3; }
.alert-warning { background: #FFFBEB; border-color: #FDE68A; color: #92400E; }

/* ------------------------------ Sidebar / Widgets ----------------------- */
.widget-area {
	display: flex;
	flex-direction: column;
	gap: 20px;
	min-width: 0;
}
.widget {
	padding: 20px;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	box-shadow: var(--oa-shadow-sm);
	transition: box-shadow .25s ease, transform .25s ease;
	min-width: 0;
}
.widget:hover { box-shadow: var(--oa-shadow); transform: translateY(-2px); }
.widget-title {
	font-size: 1rem;
	letter-spacing: .03em;
	margin: 0 0 14px;
	padding-bottom: 12px;
	border-bottom: 2px solid transparent;
	border-image: linear-gradient(90deg, var(--oa-primary), var(--oa-secondary)) 1;
}
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget li {
	padding: 8px 0;
	border-bottom: 1px dashed var(--oa-line-soft);
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.widget li:last-child { border-bottom: 0; }
.widget li a { color: var(--oa-text); display: block; }
.widget li a:hover { color: var(--oa-primary); }
.widget_categories li,
.widget_archive li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
}
.widget_categories li a,
.widget_archive li a { flex: 1; min-width: 0; }

.widget-post-list { display: flex; flex-direction: column; gap: 4px; }
.widget-post-list__link {
	display: flex;
	gap: 10px;
	align-items: center;
	padding: 8px 0 !important;
	min-width: 0;
}
.widget-post-list__thumb {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: var(--oa-radius);
	overflow: hidden;
}
.widget-post-list__thumb img { width: 100%; height: 100%; object-fit: cover; }
.widget-post-list__body { min-width: 0; flex: 1; }
.widget-post-list__title {
	font-family: var(--oa-font-serif);
	font-weight: 600;
	line-height: 1.3;
	color: var(--oa-ink);
	display: block;
}
.widget-post-list__meta { font-size: .78rem; color: var(--oa-muted); }

.tagcloud a {
	display: inline-block;
	padding: 4px 10px;
	margin: 0 4px 6px 0;
	background: var(--oa-bg-muted);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-sm);
	font-size: .82rem !important;
	color: var(--oa-text);
	transition: all .2s ease;
}
.tagcloud a:hover {
	background: var(--oa-bg-cool);
	color: var(--oa-primary);
	border-color: var(--oa-primary);
	transform: translateY(-1px);
	box-shadow: 0 3px 8px rgba(108, 60, 225, .15);
}

/* ------------------------------ Pagination ------------------------------ */
.pagination {
	margin: 36px 0;
	display: flex;
	justify-content: center;
}
.pagination .page-numbers {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	justify-content: center;
}
.pagination .page-numbers li a,
.pagination .page-numbers li span {
	display: inline-flex;
	min-width: 42px;
	height: 42px;
	padding: 0 12px;
	align-items: center;
	justify-content: center;
	border-radius: var(--oa-radius);
	border: 1.5px solid var(--oa-line);
	color: var(--oa-text);
	font-weight: 600;
	font-size: .88rem;
	transition: all .2s ease;
	background: var(--oa-bg);
}
.pagination .page-numbers li a:hover {
	background: var(--oa-primary);
	color: #fff;
	border-color: var(--oa-primary);
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(108, 60, 225, .3);
}
.pagination .page-numbers li .current {
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-primary-lt));
	color: #fff;
	border-color: var(--oa-primary);
	box-shadow: 0 4px 12px rgba(108, 60, 225, .35);
}

/* ------------------------------ CTA Band -------------------------------- */
.cta-band { padding: 28px 0; }
.cta-band__inner {
	background: linear-gradient(135deg, var(--oa-ink) 0%, #1E1B4B 50%, var(--oa-primary-dk) 100%);
	color: #fff;
	border-radius: var(--oa-radius-lg);
	padding: 26px 22px;
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
	justify-content: space-between;
	box-shadow: var(--oa-shadow-xl);
	position: relative;
	overflow: hidden;
}
@media (min-width: 768px) {
	.cta-band__inner { padding: 36px 32px; }
}
.cta-band__inner::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -20%;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: rgba(249, 112, 102, .14);
	pointer-events: none;
}
.cta-band__title { color: #fff; margin: 0 0 6px; }
.cta-band__sub {
	color: #CBD5E1;
	margin: 0;
	max-width: 540px;
	line-height: 1.55;
}
.cta-band .btn-primary {
	background: linear-gradient(135deg, var(--oa-secondary) 0%, #FB923C 100%);
	box-shadow: 0 2px 0 #B91C1C, 0 6px 16px rgba(249, 112, 102, .4);
}
.cta-band .btn-primary:hover {
	background: #fff;
	color: var(--oa-ink);
	box-shadow: 0 4px 0 rgba(255, 255, 255, .2), 0 8px 18px rgba(255, 255, 255, .2);
}

@media (max-width: 479px) {
	.cta-band__inner { text-align: center; justify-content: center; }
	.cta-band__inner > * { width: 100%; }
}

/* ------------------------------ Footer ---------------------------------- */
.site-footer {
	background: linear-gradient(180deg, #0F172A 0%, #1E1B4B 100%);
	color: #94A3B8;
	margin-top: 48px;
}
.site-footer a { color: #CBD5E1; }
.site-footer a:hover { color: var(--oa-secondary); }
.site-footer__top {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 32px;
	padding: 48px 16px 32px;
}

@media (min-width: 480px) {
	.site-footer__top { padding: 52px 24px 36px; }
}

@media (min-width: 768px) {
	.site-footer__top {
		grid-template-columns: 1.5fr 2fr;
		gap: 40px;
		padding: 64px 32px 40px;
	}
}

.site-footer__logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.site-footer__logo .site-title { color: #fff; }
.site-footer__logo .site-logo-mark {
	background: linear-gradient(135deg, var(--oa-primary) 0%, var(--oa-secondary) 100%);
	color: #fff;
	width: 36px;
	height: 36px;
	border-radius: var(--oa-radius);
}
.site-footer__tagline {
	color: #64748B;
	max-width: 300px;
	margin: 12px 0 16px;
	line-height: 1.55;
}
.site-footer__widgets {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 24px;
}

@media (min-width: 480px) {
	.site-footer__widgets {
		grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
		gap: 28px;
	}
}

@media (min-width: 768px) {
	.site-footer__widgets {
		grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
		gap: 32px;
	}
}

.footer-widget-area .widget-title {
	color: #fff;
	font-size: .85rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	border-bottom: 0;
	padding: 0;
	margin-bottom: 12px;
	font-family: var(--oa-font-sans);
	font-weight: 700;
}
.footer-widget-area ul { list-style: none; padding: 0; margin: 0; }
.footer-widget-area li { padding: 4px 0; border: 0; }
.site-footer__bottom { border-top: 1px solid #1E293B; padding: 16px 0; }
.site-footer__bottom .container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}
.site-info { margin: 0; color: #475569; font-size: .82rem; }
.footer-menu ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	font-size: .82rem;
}

.social-menu ul {
	list-style: none;
	padding: 0;
	margin: 12px 0 0;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}
.social-menu a {
	display: inline-flex;
	width: 38px;
	height: 38px;
	align-items: center;
	justify-content: center;
	border-radius: var(--oa-radius);
	border: 1px solid #334155;
	transition: all .2s ease;
}
.social-menu a:hover {
	border-color: var(--oa-primary);
	background: rgba(108, 60, 225, .18);
	transform: translateY(-2px);
	box-shadow: 0 6px 14px rgba(108, 60, 225, .3);
}

/* ------------------------------ Back to top ----------------------------- */
.back-to-top {
	position: fixed;
	right: 14px;
	bottom: 14px;
	width: 44px;
	height: 44px;
	border-radius: var(--oa-radius);
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-primary-lt));
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 20px rgba(108, 60, 225, .4);
	transition: all .2s ease;
	z-index: 90;
}
.back-to-top:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 26px rgba(108, 60, 225, .5);
}
.back-to-top[hidden] { display: none; }

@media (min-width: 480px) {
	.back-to-top { right: 22px; bottom: 22px; width: 48px; height: 48px; }
}

/* ------------------------------ Status pills + dashboard ---------------- */
.status-pill {
	display: inline-block;
	padding: 4px 10px;
	border-radius: var(--oa-radius-sm);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.status-pill--pending { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.status-pill--approved { background: #D1FAE5; color: #065F46; border: 1px solid #A7F3D0; }
.status-pill--locked { background: #F1F5F9; color: #475569; border: 1px solid #E2E8F0; }

.dashboard-greeting {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 18px;
	background: linear-gradient(135deg, var(--oa-bg) 0%, var(--oa-bg-cool) 100%);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	margin: 18px 0 28px;
	flex-wrap: wrap;
	box-shadow: var(--oa-shadow-sm);
}

@media (min-width: 480px) {
	.dashboard-greeting { padding: 22px; gap: 16px; }
}

.dashboard-greeting img {
	border-radius: 50%;
	border: 3px solid var(--oa-bg);
	flex-shrink: 0;
}
.dashboard-greeting h2 { margin: 0; }
.dashboard-greeting__actions {
	margin-left: auto;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

@media (max-width: 479px) {
	.dashboard-greeting__actions { margin-left: 0; width: 100%; }
}

.dash-section { margin-bottom: 32px; }
.dash-section__title {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
	font-size: 1.1rem;
	padding-bottom: 10px;
	border-bottom: 2px solid transparent;
	border-image: linear-gradient(90deg, var(--oa-primary), var(--oa-secondary)) 1;
	flex-wrap: wrap;
}
.dash-section__title .count {
	color: var(--oa-muted);
	font-size: .86rem;
	font-family: var(--oa-font-sans);
	font-weight: 500;
}

.dash-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.dash-list__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	flex-wrap: wrap;
	box-shadow: var(--oa-shadow-sm);
	transition: box-shadow .2s ease, border-color .2s ease, transform .2s ease;
}
.dash-list__item:hover {
	box-shadow: var(--oa-shadow);
	border-color: var(--oa-primary);
	transform: translateY(-2px);
}
.dash-list__main { flex: 1; min-width: 0; }
.dash-list__title {
	display: block;
	font-family: var(--oa-font-serif);
	font-weight: 700;
	color: var(--oa-ink);
	margin-bottom: 2px;
}
.dash-list__meta { font-size: .82rem; color: var(--oa-muted); }
.dash-list__actions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

.dash-empty { color: var(--oa-muted); padding: 16px 0; }

.dash-help {
	margin: 32px 0 0;
	padding: 20px;
	background: linear-gradient(135deg, var(--oa-bg-cool) 0%, rgba(108, 60, 225, .05) 100%);
	border-radius: var(--oa-radius-lg);
	border: 1px solid #C7D2FE;
}
.dash-help h3 { margin: 0 0 8px; color: var(--oa-primary); }
.dash-help ol { margin: 0; padding-left: 20px; color: var(--oa-text); }
.dash-help li { margin-bottom: 4px; }

/* ------------------------------ 404 ------------------------------------- */
.error-404 { padding: 56px 16px; text-align: center; }
.error-404__inner { max-width: 540px; margin: 0 auto; }
.error-404__code {
	display: inline-block;
	font-family: var(--oa-font-serif);
	font-size: clamp(3.5rem, 16vw, 7rem);
	font-weight: 700;
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-secondary), var(--oa-tertiary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1;
}
.error-404__title { margin: 12px 0 10px; }
.error-404__sub { color: var(--oa-muted); margin-bottom: 22px; }
.error-404__actions {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 14px;
}

@media (max-width: 379px) {
	.error-404__actions { flex-direction: column; }
	.error-404__actions .btn { width: 100%; justify-content: center; }
}

/* ------------------------------ Comments -------------------------------- */
.comments-area { margin: 40px auto 0; max-width: 740px; min-width: 0; }
.comments-title { font-size: 1.3rem; margin-bottom: 18px; }
.comment-list {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.comment-list .comment, .comment-list .pingback {
	padding: 16px;
	background: var(--oa-bg);
	border: 1px solid var(--oa-line);
	border-radius: var(--oa-radius-lg);
	box-shadow: var(--oa-shadow-sm);
	min-width: 0;
}
.comment-list .children {
	list-style: none;
	padding-left: 14px;
	margin: 14px 0 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

@media (min-width: 480px) {
	.comment-list .children { padding-left: 24px; }
}

.comment-author {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 6px;
	flex-wrap: wrap;
}
.comment-author img { border-radius: 50%; }
.comment-author .fn { font-weight: 600; color: var(--oa-ink); font-style: normal; }
.comment-metadata { font-size: .78rem; color: var(--oa-muted); }
.comment-reply-link {
	display: inline-block;
	margin-top: 6px;
	font-size: .82rem;
	color: var(--oa-primary);
	font-weight: 600;
	transition: color .2s ease;
}
.comment-reply-link:hover { color: var(--oa-secondary); }

/* ------------------------------ No-results ------------------------------ */
.no-results {
	text-align: center;
	padding: 40px 20px;
	background: var(--oa-bg);
	border-radius: var(--oa-radius-lg);
	border: 1px solid var(--oa-line);
	box-shadow: var(--oa-shadow-sm);
}
.no-results__title { margin: 0 0 8px; }
.no-results__text { color: var(--oa-muted); max-width: 460px; margin: 0 auto 18px; }
.no-results .search-form { max-width: 460px; margin: 0 auto 16px; }

/* ------------------------------ Print / a11y / motion ------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0s !important; transition-duration: 0s !important; }
	html { scroll-behavior: auto; }
}

@media print {
	.site-header, .site-footer, .back-to-top, .entry-share, .related-posts, .post-navigation, .author-bio { display: none !important; }
	body { font-size: 12pt; background: #fff; }
}

/* ------------------------------ WP block fixes -------------------------- */
.wp-block-image figcaption { font-size: .82rem; color: var(--oa-muted); text-align: center; margin-top: 8px; }
.wp-block-quote, .wp-block-pullquote {
	font-family: var(--oa-font-serif);
	font-style: italic;
	font-size: 1.12rem;
	color: var(--oa-ink);
	border-left: 4px solid var(--oa-primary);
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--oa-bg-cool) 0%, rgba(108, 60, 225, .04) 100%);
	border-radius: 0 var(--oa-radius) var(--oa-radius) 0;
	margin: 1.5em 0;
}
.wp-block-pullquote {
	border-left: 0;
	border-top: 3px solid var(--oa-primary);
	border-bottom: 3px solid var(--oa-primary);
	border-radius: 0;
	text-align: center;
	padding: 22px;
}
.wp-block-table th, .wp-block-table td {
	border: 1px solid var(--oa-line);
	padding: 10px 12px;
	min-width: 80px;
}
.wp-block-table thead { background: var(--oa-bg-muted); }
.wp-block-button__link {
	background: linear-gradient(135deg, var(--oa-primary), var(--oa-primary-lt));
	color: #fff;
	border-radius: var(--oa-radius);
	padding: 12px 22px;
	font-weight: 600;
	box-shadow: 0 4px 12px rgba(108, 60, 225, .3);
	transition: transform .2s ease, box-shadow .2s ease;
}
.wp-block-button__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(108, 60, 225, .4);
	color: #fff;
}

/* WordPress embeds — keep videos responsive */
.wp-block-embed__wrapper, .wp-block-embed iframe { max-width: 100%; }
.wp-block-embed__wrapper { position: relative; }

/* Sticky post indicator */
.post-card.sticky::after, .featured-card.sticky::after {
	content: '\2605';
	position: absolute;
	top: 12px;
	left: 12px;
	width: 28px;
	height: 28px;
	background: linear-gradient(135deg, var(--oa-secondary), #FB923C);
	color: #fff;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: .8rem;
	font-weight: 700;
	box-shadow: 0 4px 10px rgba(249, 112, 102, .4);
	z-index: 3;
}
.post-card, .featured-card { position: relative; }
