/* ============================================================
   Guided Mind — main stylesheet
   Variables → reset → typography → layout → components → pages
   ============================================================ */

/* -------- 1. Tokens -------- */
:root {
	/* Color */
	--color-bg-primary: #0B1120;
	--color-bg-secondary: #141E33;
	--color-bg-tertiary: #1C2A45;
	--color-surface-warm: #1A1510;
	--color-text-primary: #E8E0D4;
	--color-text-secondary: #9BA4B5;
	--color-text-muted: #5C6478;
	--color-accent-gold: #C9A96E;
	--color-accent-gold-light: #DBBE82;
	--color-accent-gold-soft: rgba(201, 169, 110, 0.15);
	--color-accent-sage: #7A9E8E;
	--color-border: rgba(255, 255, 255, 0.06);
	--color-border-hover: rgba(201, 169, 110, 0.3);

	/* Type */
	--font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	/* Spacing */
	--space-xs: 4px;
	--space-sm: 8px;
	--space-md: 16px;
	--space-lg: 24px;
	--space-xl: 32px;
	--space-2xl: 48px;
	--space-3xl: 64px;
	--space-4xl: 96px;
	--space-5xl: 128px;
	--space-section: 120px;

	/* Sizes */
	--max-content: 1200px;
	--max-blog: 720px;
	--max-wide: 960px;

	/* Motion */
	--ease-out-soft: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--dur-fast: 0.3s;
	--dur-base: 0.4s;
	--dur-slow: 0.6s;

	/* Z */
	--z-header: 100;
	--z-overlay: 200;
}

@media (max-width: 768px) {
	:root { --space-section: 80px; }
}

/* -------- 2. Reset / base -------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	background: var(--color-bg-primary);
	color: var(--color-text-primary);
	font-family: var(--font-body);
	font-weight: 300;
	font-size: 1.0625rem;
	line-height: 1.75;
	letter-spacing: 0.01em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
:focus-visible {
	outline: 2px solid var(--color-accent-gold);
	outline-offset: 4px;
}
::selection { background: var(--color-accent-gold); color: var(--color-bg-primary); }

/* Skip link */
.gm-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--color-accent-gold);
	color: var(--color-bg-primary);
	padding: 12px 20px;
	font-weight: 500;
	z-index: 9999;
}
.gm-skip-link:focus { left: 16px; top: 16px; }

/* -------- 3. Typography -------- */
h1, h2, h3, h4 {
	font-family: var(--font-display);
	font-weight: 400;
	color: var(--color-text-primary);
	margin: 0 0 var(--space-md);
}
h1 {
	font-weight: 300;
	font-size: clamp(2.5rem, 5vw + 0.5rem, 4rem);
	line-height: 1.1;
	letter-spacing: -0.02em;
}
h2 {
	font-weight: 400;
	font-size: clamp(2rem, 3vw + 0.5rem, 2.75rem);
	line-height: 1.2;
	letter-spacing: -0.01em;
}
h3 {
	font-weight: 500;
	font-size: clamp(1.5rem, 2vw + 0.5rem, 1.75rem);
	line-height: 1.3;
}
h4 {
	font-weight: 500;
	font-size: clamp(1.125rem, 1vw + 0.5rem, 1.25rem);
	line-height: 1.4;
	letter-spacing: 0.01em;
}
p { margin: 0 0 var(--space-lg); }
.gm-eyebrow {
	display: inline-flex; align-items: center; gap: 12px;
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.8125rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-accent-gold);
	margin: 0 0 var(--space-md);
}
.gm-eyebrow::before {
	content: "";
	width: 24px;
	height: 1px;
	background: var(--color-accent-gold);
}
.gm-lede {
	font-size: 1.125rem;
	color: var(--color-text-secondary);
	max-width: 560px;
}

/* -------- 4. Layout -------- */
.gm-container { width: 100%; max-width: var(--max-content); margin: 0 auto; padding: 0 24px; }
.gm-container--narrow { max-width: var(--max-blog); }
.gm-container--wide { max-width: var(--max-wide); }
.gm-section { padding: var(--space-section) 0; }
.gm-section--warm { background: var(--color-surface-warm); }
.gm-section--secondary { background: var(--color-bg-secondary); }
.gm-section__head { text-align: center; margin-bottom: var(--space-3xl); }
.gm-section__head--left { text-align: left; }
.gm-section__subhead { color: var(--color-text-secondary); max-width: 540px; margin-left: auto; margin-right: auto; }
.gm-section__head--left .gm-section__subhead { margin-left: 0; }

.gm-divider {
	width: 200px; height: 1px;
	margin: var(--space-3xl) auto;
	background: linear-gradient(90deg, transparent, rgba(201, 169, 110, 0.4), transparent);
	border: 0;
}

/* -------- 5. Header / Nav -------- */
.gm-header {
	position: fixed; inset: 0 0 auto 0;
	height: 80px;
	display: flex; align-items: center;
	z-index: var(--z-header);
	background: transparent;
	transition: background var(--dur-fast) var(--ease-out-soft), height var(--dur-fast) var(--ease-out-soft), border-color var(--dur-fast) var(--ease-out-soft);
	border-bottom: 1px solid transparent;
}
.gm-header__inner {
	width: 100%; max-width: var(--max-content);
	margin: 0 auto; padding: 0 24px;
	display: flex; align-items: center; justify-content: space-between;
	gap: var(--space-xl);
}
.gm-header.is-scrolled,
body:not(.gm-home) .gm-header {
	background: rgba(11, 17, 32, 0.85);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	border-bottom-color: var(--color-border);
	height: 64px;
}

.gm-logo {
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 1.25rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-text-primary);
	line-height: 1;
	white-space: nowrap;
}
.gm-logo span { color: var(--color-accent-gold); }

.gm-nav { display: flex; align-items: center; gap: var(--space-2xl); }
.gm-nav__menu {
	display: flex; align-items: center; gap: var(--space-xl);
	list-style: none; margin: 0; padding: 0;
}
.gm-nav__menu a {
	font-weight: 500;
	font-size: 0.875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-primary);
	position: relative;
	padding: 4px 0;
	transition: color var(--dur-fast) var(--ease-out-soft);
}
.gm-nav__menu a::after {
	content: ""; position: absolute; left: 0; bottom: -4px;
	width: 0; height: 1px; background: var(--color-accent-gold);
	transition: width var(--dur-fast) var(--ease-out-soft);
}
.gm-nav__menu a:hover { color: var(--color-accent-gold); }
.gm-nav__menu a:hover::after,
.gm-nav__menu .current-menu-item > a::after,
.gm-nav__menu .current_page_item > a::after { width: 100%; }

.gm-nav__cta { /* YouTube subscribe — outlined gold */
	display: inline-flex; align-items: center; gap: 8px;
	padding: 10px 20px;
	font-weight: 500; font-size: 0.8125rem; letter-spacing: 0.1em; text-transform: uppercase;
	border: 1px solid var(--color-accent-gold);
	color: var(--color-accent-gold);
	transition: background var(--dur-fast), color var(--dur-fast);
}
.gm-nav__cta:hover { background: var(--color-accent-gold); color: var(--color-bg-primary); }
.gm-nav__cta svg { width: 16px; height: 16px; }

/* Mobile nav */
.gm-nav__toggle {
	display: none;
	background: transparent; border: 0; padding: 8px;
	color: var(--color-text-primary);
	width: 44px; height: 44px;
	align-items: center; justify-content: center;
}
.gm-nav__toggle-bars { width: 24px; height: 16px; position: relative; }
.gm-nav__toggle-bars span {
	display: block; position: absolute; left: 0; right: 0; height: 1px;
	background: currentColor;
	transition: transform var(--dur-fast) var(--ease-out-soft), opacity 0.2s, top var(--dur-fast) var(--ease-out-soft);
}
.gm-nav__toggle-bars span:nth-child(1) { top: 0; }
.gm-nav__toggle-bars span:nth-child(2) { top: 7px; }
.gm-nav__toggle-bars span:nth-child(3) { top: 14px; }
.is-menu-open .gm-nav__toggle-bars span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.is-menu-open .gm-nav__toggle-bars span:nth-child(2) { opacity: 0; }
.is-menu-open .gm-nav__toggle-bars span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

.gm-mobile-nav {
	position: fixed; inset: 0;
	background: var(--color-bg-primary);
	z-index: var(--z-overlay);
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: var(--space-2xl);
	padding: var(--space-3xl) 24px;
	opacity: 0; visibility: hidden;
	transform: translateY(-20px);
	transition: opacity var(--dur-fast), transform var(--dur-fast) var(--ease-out-soft), visibility 0s linear var(--dur-fast);
}
.is-menu-open .gm-mobile-nav {
	opacity: 1; visibility: visible; transform: translateY(0);
	transition: opacity var(--dur-fast), transform var(--dur-fast) var(--ease-out-soft), visibility 0s;
}
.gm-mobile-nav__menu { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-lg); text-align: center; }
.gm-mobile-nav__menu a {
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 2rem;
	color: var(--color-text-primary);
	letter-spacing: 0.02em;
}
.gm-mobile-nav__menu a:hover { color: var(--color-accent-gold); }
.gm-mobile-nav__cta { margin-top: var(--space-xl); }

@media (max-width: 768px) {
	.gm-nav__menu, .gm-nav__cta { display: none; }
	.gm-nav__toggle { display: inline-flex; }
}

/* Body padding so fixed header doesn't overlap content on inner pages */
body:not(.gm-home) { padding-top: 64px; }

/* -------- 6. Buttons -------- */
.gm-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 8px;
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 14px 32px;
	border: 1px solid transparent;
	border-radius: 0;
	transition: all var(--dur-fast) var(--ease-out-soft);
	cursor: pointer;
	line-height: 1;
}
.gm-btn--primary {
	background: var(--color-accent-gold);
	color: var(--color-bg-primary);
}
.gm-btn--primary:hover {
	background: var(--color-accent-gold-light);
	box-shadow: 0 4px 20px rgba(201, 169, 110, 0.3);
	transform: translateY(-1px);
}
.gm-btn--secondary {
	background: transparent;
	border-color: var(--color-accent-gold);
	color: var(--color-accent-gold);
}
.gm-btn--secondary:hover {
	background: var(--color-accent-gold-soft);
	border-color: var(--color-accent-gold-light);
}
.gm-btn--ghost {
	background: transparent;
	border: 0;
	color: var(--color-text-secondary);
	padding: 8px 0;
	position: relative;
}
.gm-btn--ghost::after {
	content: ""; position: absolute; left: 0; bottom: 0;
	height: 1px; width: 0; background: var(--color-accent-gold);
	transition: width var(--dur-fast) var(--ease-out-soft);
}
.gm-btn--ghost:hover { color: var(--color-accent-gold); }
.gm-btn--ghost:hover::after { width: 100%; }

/* Tag pills */
.gm-tag {
	display: inline-block;
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 4px 12px;
	border-radius: 24px;
	color: var(--color-accent-sage);
	background: rgba(122, 158, 142, 0.1);
	border: 1px solid rgba(122, 158, 142, 0.2);
	line-height: 1.4;
}
.gm-tag--gold { color: var(--color-accent-gold); background: var(--color-accent-gold-soft); border-color: rgba(201, 169, 110, 0.3); }
.gm-tag--filter { cursor: pointer; padding: 8px 18px; font-size: 0.8125rem; background: var(--color-bg-tertiary); color: var(--color-text-secondary); border: 1px solid var(--color-border); transition: all var(--dur-fast); }
.gm-tag--filter:hover, .gm-tag--filter.is-active { color: var(--color-accent-gold); background: var(--color-accent-gold-soft); border-color: var(--color-border-hover); }

/* -------- 7. Cards -------- */
.gm-card {
	display: block;
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: 2px;
	overflow: hidden;
	transition: transform var(--dur-base) var(--ease-out-soft), border-color var(--dur-base), box-shadow var(--dur-base);
	color: inherit;
}
.gm-card:hover {
	transform: translateY(-4px);
	border-color: var(--color-border-hover);
	box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.gm-card__media { position: relative; aspect-ratio: 16 / 9; overflow: hidden; background: var(--color-bg-tertiary); }
.gm-card__image {
	width: 100%; height: 100%; object-fit: cover;
	filter: saturate(0.85) brightness(0.9);
	transition: transform var(--dur-slow) var(--ease-out-soft), filter var(--dur-slow);
}
.gm-card:hover .gm-card__image { transform: scale(1.03); filter: saturate(1) brightness(1); }
.gm-card__image--placeholder {
	background: linear-gradient(135deg, var(--color-bg-tertiary), var(--color-bg-secondary));
}
.gm-card__body { padding: var(--space-lg) var(--space-xl); }
.gm-card__title { font-family: var(--font-display); font-weight: 500; font-size: 1.5rem; line-height: 1.3; margin: var(--space-sm) 0 var(--space-md); transition: color var(--dur-fast); }
.gm-card:hover .gm-card__title { color: var(--color-accent-gold); }
.gm-card__excerpt { color: var(--color-text-secondary); font-size: 1rem; line-height: 1.65; margin: 0 0 var(--space-md);
	display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.gm-card__meta { color: var(--color-text-muted); font-size: 0.8125rem; letter-spacing: 0.03em; display: flex; gap: 10px; align-items: center; }

/* Featured card (large on blog index) */
.gm-card--featured { display: grid; grid-template-columns: 1fr; }
.gm-card--featured .gm-card__media { aspect-ratio: 21 / 9; }
.gm-card--featured .gm-card__title { font-size: 2.25rem; }
.gm-card--featured .gm-card__body { padding: var(--space-2xl); }

/* Horizontal card (homepage blog preview, related posts) */
.gm-card--horizontal { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.gm-card--horizontal .gm-card__media { aspect-ratio: 4 / 3; }
.gm-card--horizontal .gm-card__body { display: flex; flex-direction: column; justify-content: center; padding: var(--space-xl); }
@media (max-width: 768px) {
	.gm-card--horizontal { grid-template-columns: 1fr; }
}

/* Category cards */
.gm-cat-card {
	position: relative;
	display: flex; flex-direction: column; justify-content: space-between;
	min-height: 320px;
	padding: var(--space-xl);
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: 2px;
	overflow: hidden;
	color: var(--color-text-primary);
	transition: transform var(--dur-base) var(--ease-out-soft), border-color var(--dur-base), box-shadow var(--dur-base);
}
.gm-cat-card__image {
	position: absolute; inset: 0;
	background-size: cover;
	background-position: center;
	opacity: 0.45;
	filter: saturate(0.85) brightness(0.95);
	transform: scale(1);
	transition: opacity 0.6s ease, filter 0.6s ease, transform 0.6s ease;
	z-index: 0;
}
.gm-cat-card::before {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(11, 17, 32, 0.30) 0%, rgba(11, 17, 32, 0.62) 50%, rgba(11, 17, 32, 0.92) 100%);
	transition: opacity var(--dur-base);
	z-index: 1;
}
.gm-cat-card:hover { transform: translateY(-4px); border-color: var(--color-border-hover); box-shadow: 0 12px 40px rgba(0,0,0,0.4); }
.gm-cat-card:hover .gm-cat-card__image,
.gm-cat-card:focus-within .gm-cat-card__image {
	opacity: 0.7;
	filter: saturate(1) brightness(1);
	transform: scale(1.05);
}
.gm-cat-card__icon { position: relative; z-index: 2; color: var(--color-accent-gold); }
.gm-cat-card__body { position: relative; z-index: 2; }
.gm-cat-card__title { font-family: var(--font-display); font-weight: 500; font-size: 1.5rem; margin: 0 0 8px; color: #fff; }
.gm-cat-card__desc { color: rgba(232, 224, 212, 0.85); font-size: 0.9375rem; margin: 0; }

/* Post CTA — contextual link to matching meditation category */
.gm-post-cta {
	max-width: 720px;
	margin: var(--space-2xl) auto;
	padding: var(--space-lg) var(--space-xl);
	background: var(--color-bg-secondary);
	border-left: 3px solid var(--color-accent-gold);
	border-radius: 2px;
}
.gm-post-cta__text {
	font-family: var(--font-display);
	font-size: 1.125rem;
	color: var(--color-text-secondary);
	margin: 0 0 6px;
	letter-spacing: 0;
}
.gm-post-cta__link {
	display: inline-block;
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: 500;
	color: var(--color-accent-gold);
	text-decoration: none;
	transition: color var(--dur-fast);
}
.gm-post-cta__link:hover { color: #d8bb85; text-decoration: underline; }

/* Video post variant — facade replaces featured image */
.gm-post-featured--video { aspect-ratio: 16 / 9; max-width: 960px; margin: 0 auto var(--space-2xl); }
.gm-post-featured--video .gm-yt-facade { aspect-ratio: 16 / 9; }

/* -------- 8. Grids -------- */
.gm-grid { display: grid; gap: var(--space-xl); }
.gm-grid--3 { grid-template-columns: repeat(3, 1fr); }
.gm-grid--2 { grid-template-columns: repeat(2, 1fr); max-width: 880px; margin: 0 auto; }
.gm-grid--1 { grid-template-columns: minmax(0, 480px); justify-content: center; }
.gm-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) {
	.gm-grid--3, .gm-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.gm-grid--3, .gm-grid--2, .gm-grid--4 { grid-template-columns: 1fr; }
	.gm-grid--1 { grid-template-columns: 1fr; }
}

/* -------- 9. Hero -------- */
.gm-hero {
	position: relative;
	min-height: 100vh;
	display: flex; align-items: center; justify-content: center;
	text-align: center;
	padding: 120px 24px var(--space-2xl);
	overflow: hidden;
	background:
		radial-gradient(ellipse at center, #0B1120 0%, #060A14 70%);
}
@media (max-width: 768px) { .gm-hero { min-height: 85vh; } }

.gm-hero__bloom {
	position: absolute; pointer-events: none;
	width: 720px; height: 720px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(201,169,110,0.10) 0%, rgba(201,169,110,0) 60%);
	top: 40%; left: 50%; transform: translate(-50%, -50%);
	animation: gm-drift 18s ease-in-out infinite alternate;
	filter: blur(40px);
}
@keyframes gm-drift {
	0%   { transform: translate(-55%, -55%) scale(1); opacity: 0.7; }
	50%  { transform: translate(-45%, -50%) scale(1.05); opacity: 1; }
	100% { transform: translate(-50%, -45%) scale(0.95); opacity: 0.8; }
}

.gm-hero__inner { position: relative; z-index: 2; max-width: 800px; width: 100%; }
.gm-hero__title { font-family: var(--font-display); font-weight: 300; font-size: clamp(2rem, 5vw + 0.5rem, 4rem); line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 var(--space-lg); color: var(--color-text-primary); overflow-wrap: break-word; }
/* Editorial line break on desktop: turn the inline space-span into a forced wrap; on mobile leave as a regular space. */
.gm-hero__title .gm-hero__break { display: inline; }
@media (min-width: 720px) { .gm-hero__title .gm-hero__break { display: block; height: 0; font-size: 0; } }
.gm-hero__lede { font-family: var(--font-body); font-weight: 300; font-size: clamp(1rem, 1vw + 0.5rem, 1.125rem); color: var(--color-text-secondary); margin: 0 auto var(--space-2xl); max-width: 560px; line-height: 1.7; }
.gm-hero__cta-row { display: flex; flex-direction: column; align-items: center; gap: var(--space-md); }
.gm-hero__cta-note { font-size: 0.8125rem; color: var(--color-text-muted); letter-spacing: 0.05em; display: inline-flex; gap: 6px; align-items: center; }
.gm-hero__cta-note svg { width: 14px; height: 14px; }

.gm-hero__scroll {
	position: absolute; left: 50%; bottom: 36px;
	transform: translateX(-50%);
	color: var(--color-text-muted);
	display: flex; flex-direction: column; align-items: center; gap: 8px;
	font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase;
	animation: gm-pulse 3s ease-in-out infinite;
}
.gm-hero__scroll-line { display: block; width: 1px; height: 32px; background: linear-gradient(180deg, transparent, var(--color-text-muted)); }
@keyframes gm-pulse {
	0%, 100% { opacity: 0.4; transform: translateX(-50%) translateY(0); }
	50%      { opacity: 0.9; transform: translateX(-50%) translateY(4px); }
}

/* -------- 10. YouTube facade -------- */
.gm-yt-facade {
	position: relative;
	aspect-ratio: 16 / 9;
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: 2px;
	overflow: hidden;
	cursor: pointer;
	display: block;
}
.gm-yt-facade__thumb { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.7); transition: filter var(--dur-base), transform var(--dur-base); }
.gm-yt-facade:hover .gm-yt-facade__thumb { filter: brightness(0.85); transform: scale(1.02); }
.gm-yt-facade__play {
	position: absolute; inset: 0; margin: auto;
	width: 80px; height: 80px;
	background: transparent; border: 0; padding: 0;
	display: flex; align-items: center; justify-content: center;
	transition: transform var(--dur-base);
}
.gm-yt-facade:hover .gm-yt-facade__play { transform: scale(1.08); }
.gm-yt-facade__title {
	position: absolute; left: 0; right: 0; bottom: 0;
	padding: var(--space-lg);
	color: #fff;
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 1.125rem;
	background: linear-gradient(180deg, transparent, rgba(11, 17, 32, 0.9));
}

.gm-yt-grid { display: grid; gap: var(--space-xl); grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1024px) { .gm-yt-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .gm-yt-grid { grid-template-columns: 1fr; } }

/* Embed inside post content */
.gm-post-content .gm-yt-facade,
.gm-yt-block { max-width: var(--max-wide); margin: var(--space-2xl) auto; }

/* -------- 11. Footer -------- */
.gm-footer {
	background: var(--color-bg-primary);
	border-top: 1px solid var(--color-border);
	padding: var(--space-3xl) 0 0;
	margin-top: var(--space-section);
}
.gm-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--space-2xl); padding-bottom: var(--space-3xl); }
@media (max-width: 768px) { .gm-footer__grid { grid-template-columns: 1fr; gap: var(--space-xl); } }
.gm-footer__col h4 {
	font-family: var(--font-body); font-weight: 500;
	font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase;
	color: var(--color-accent-gold); margin: 0 0 var(--space-md);
}
.gm-footer__brand .gm-logo { display: inline-block; margin-bottom: var(--space-md); }
.gm-footer__tagline { color: var(--color-text-secondary); font-size: 0.9375rem; max-width: 320px; line-height: 1.6; }
.gm-footer__links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.gm-footer__links a { color: var(--color-text-secondary); font-size: 0.9375rem; transition: color var(--dur-fast); }
.gm-footer__links a:hover { color: var(--color-accent-gold); }
.gm-footer__bottom {
	border-top: 1px solid var(--color-border);
	padding: var(--space-lg) 0;
	color: var(--color-text-muted);
	font-size: 0.8125rem;
	text-align: center;
}

/* -------- 12. Blog post content -------- */
.gm-post-header { max-width: var(--max-wide); margin: var(--space-3xl) auto var(--space-2xl); padding: 0 24px; text-align: center; }
.gm-post-header .gm-tag { margin-bottom: var(--space-lg); }
.gm-post-header__title { font-family: var(--font-display); font-weight: 300; font-size: clamp(2rem, 4vw + 0.5rem, 2.75rem); line-height: 1.2; margin: 0 0 var(--space-lg); }
.gm-post-header__meta { color: var(--color-text-muted); font-size: 0.875rem; letter-spacing: 0.03em; display: flex; gap: 14px; justify-content: center; align-items: center; flex-wrap: wrap; }
.gm-post-header__meta span { display: inline-flex; align-items: center; }
.gm-post-header__meta .gm-sep { color: var(--color-text-muted); }
.gm-post-featured { max-width: var(--max-wide); margin: 0 auto var(--space-3xl); padding: 0 24px; }
.gm-post-featured img { width: 100%; border-radius: 2px; aspect-ratio: 16 / 9; object-fit: cover; }

.gm-post-content {
	max-width: var(--max-blog);
	margin: 0 auto;
	padding: 0 24px;
	font-size: 1.125rem;
	line-height: 1.85;
	color: var(--color-text-primary);
}
.gm-post-content > p { margin: 0 0 1.5em; font-weight: 300; }
.gm-post-content > h2 { font-family: var(--font-display); font-weight: 400; font-size: 2rem; margin: 3rem 0 1rem; line-height: 1.25; }
.gm-post-content > h3 { font-family: var(--font-display); font-weight: 500; font-size: 1.5rem; margin: 2.5rem 0 1rem; line-height: 1.3; }
.gm-post-content > h4 { font-family: var(--font-body); font-weight: 500; font-size: 1.0625rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-accent-gold); margin: 2rem 0 0.75rem; }
.gm-post-content a { color: var(--color-accent-gold); border-bottom: 1px solid transparent; transition: border-color var(--dur-fast); }
.gm-post-content a:hover { border-bottom-color: var(--color-accent-gold); }

.gm-post-content ul, .gm-post-content ol { margin: 0 0 1.5em 1.25em; padding: 0; }
.gm-post-content li { margin-bottom: 0.75em; }
.gm-post-content ul li::marker { color: var(--color-accent-gold); }
.gm-post-content ol li::marker { color: var(--color-accent-gold); font-weight: 500; }

.gm-post-content blockquote {
	margin: 2em 0;
	padding-left: 24px;
	border-left: 2px solid var(--color-accent-gold);
	font-family: var(--font-display);
	font-style: italic;
	font-weight: 300;
	font-size: 1.5rem;
	line-height: 1.5;
	color: var(--color-text-primary);
}

.gm-post-content img,
.gm-post-content .wp-block-image,
.gm-post-content figure {
	max-width: var(--max-wide);
	margin: 2rem auto;
	border-radius: 2px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}
.gm-post-content figure img { box-shadow: none; }
.gm-post-content figcaption { color: var(--color-text-muted); font-size: 0.875rem; text-align: center; margin-top: 8px; }

.gm-post-content pre {
	background: var(--color-bg-secondary);
	padding: 24px;
	border-radius: 2px;
	overflow-x: auto;
	font-size: 0.9375rem;
}
.gm-post-content code { font-family: ui-monospace, "SFMono-Regular", Menlo, monospace; font-size: 0.9em; background: var(--color-bg-secondary); padding: 2px 6px; border-radius: 2px; }
.gm-post-content pre code { background: transparent; padding: 0; }

.gm-post-content table { width: 100%; border-collapse: collapse; margin: 2rem 0; font-size: 0.9375rem; }
.gm-post-content th, .gm-post-content td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--color-border); }
.gm-post-content th { font-family: var(--font-body); font-weight: 500; color: var(--color-accent-gold); text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.8125rem; }

/* TOC (sidebar on desktop, collapsible on mobile) */
.gm-toc {
	max-width: var(--max-wide);
	margin: 0 auto var(--space-2xl);
	padding: var(--space-lg) 24px;
	background: rgba(20, 30, 51, 0.5);
	border: 1px solid var(--color-border);
	border-radius: 2px;
}
.gm-toc summary {
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.8125rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-accent-gold);
	cursor: pointer;
	list-style: none;
}
.gm-toc summary::-webkit-details-marker { display: none; }
.gm-toc summary::after { content: " ▾"; }
.gm-toc[open] summary::after { content: " ▴"; }
.gm-toc ol { margin: var(--space-md) 0 0 1.25em; padding: 0; counter-reset: tocnum; list-style: none; }
.gm-toc li { counter-increment: tocnum; padding: 6px 0; font-size: 0.9375rem; position: relative; }
.gm-toc li::before { content: counter(tocnum, decimal-leading-zero); color: var(--color-text-muted); position: absolute; left: -1.75em; font-size: 0.75rem; top: 10px; }
.gm-toc a { color: var(--color-text-secondary); transition: color var(--dur-fast); }
.gm-toc a:hover { color: var(--color-accent-gold); }
.gm-toc .gm-toc--h3 { margin-left: 1.25em; font-size: 0.875rem; }

/* Author box */
.gm-author-box {
	max-width: var(--max-blog);
	margin: var(--space-3xl) auto;
	padding: var(--space-xl) 24px;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	background: var(--color-bg-secondary);
	text-align: center;
}
.gm-author-box__name { font-family: var(--font-display); font-weight: 500; font-size: 1.25rem; margin: 0 0 8px; }
.gm-author-box__bio { color: var(--color-text-secondary); font-size: 0.9375rem; margin: 0 0 var(--space-md); }
.gm-author-box__cta { font-size: 0.875rem; }

/* Social share */
.gm-share { max-width: var(--max-blog); margin: var(--space-2xl) auto; padding: 0 24px; display: flex; gap: var(--space-md); align-items: center; justify-content: center; }
.gm-share__label { color: var(--color-text-muted); font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase; }
.gm-share a, .gm-share button { color: var(--color-text-muted); transition: color var(--dur-fast); background: transparent; border: 0; padding: 8px; line-height: 1; }
.gm-share a:hover, .gm-share button:hover { color: var(--color-accent-gold); }
.gm-share svg { width: 18px; height: 18px; }

/* Related posts */
.gm-related { padding: var(--space-3xl) 0; }
.gm-related h2 { text-align: center; margin-bottom: var(--space-2xl); }
.gm-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
@media (max-width: 900px) { .gm-related__grid { grid-template-columns: 1fr; } }

/* Breadcrumbs */
.gm-breadcrumbs { max-width: var(--max-content); margin: 0 auto; padding: var(--space-md) 24px 0; font-size: 0.8125rem; color: var(--color-text-muted); }
.gm-breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.gm-breadcrumbs a { color: var(--color-text-muted); transition: color var(--dur-fast); }
.gm-breadcrumbs a:hover { color: var(--color-accent-gold); }
.gm-breadcrumbs__sep { color: var(--color-text-muted); margin: 0 6px; }
.gm-breadcrumbs span[aria-current="page"] { color: var(--color-text-secondary); }

/* -------- 13. Blog index -------- */
.gm-archive-head { text-align: center; max-width: 640px; margin: 0 auto var(--space-2xl); padding: 0 24px; }
.gm-archive-filters {
	display: flex; flex-wrap: wrap; gap: 8px;
	justify-content: center;
	margin: 0 auto var(--space-3xl);
	padding: 0 24px;
	max-width: var(--max-content);
}
.gm-archive-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-xl); }
@media (max-width: 768px) { .gm-archive-grid { grid-template-columns: 1fr; } }

.gm-pagination { display: flex; justify-content: center; margin-top: var(--space-3xl); }
.gm-pagination a, .gm-pagination span {
	display: inline-block; padding: 8px 14px; margin: 0 4px;
	color: var(--color-text-secondary);
	border: 1px solid var(--color-border);
	font-size: 0.875rem;
	transition: all var(--dur-fast);
}
.gm-pagination a:hover, .gm-pagination .current { color: var(--color-accent-gold); border-color: var(--color-border-hover); }

/* -------- 14. About / Mission / Quote -------- */
.gm-quote-block {
	max-width: 640px; margin: 0 auto; text-align: center;
	position: relative; padding: var(--space-3xl) var(--space-xl) 0;
}
.gm-quote-block::before {
	content: "\201C";
	font-family: var(--font-display);
	font-size: 6rem;
	line-height: 1;
	color: var(--color-accent-gold);
	opacity: 0.2;
	position: absolute;
	top: 0; left: 50%;
	transform: translateX(-50%);
}
.gm-quote-block p { font-family: var(--font-display); font-style: italic; font-weight: 400; font-size: 1.5rem; line-height: 1.6; color: var(--color-text-primary); margin: 0 0 var(--space-xl); }

/* Signup */
.gm-signup { max-width: 560px; margin: 0 auto; text-align: center; padding: 0 24px; }
.gm-signup__form { display: flex; gap: 0; margin-top: var(--space-lg); }
.gm-signup__input { flex: 1; padding: 14px 18px; background: var(--color-bg-secondary); color: var(--color-text-primary); border: 1px solid var(--color-border); border-right: 0; border-radius: 0; font-family: var(--font-body); font-size: 0.9375rem; }
.gm-signup__input:focus { outline: none; border-color: var(--color-accent-gold); box-shadow: 0 0 0 2px var(--color-accent-gold-soft); }
.gm-signup__btn { border: 0; padding: 14px 28px; background: var(--color-accent-gold); color: var(--color-bg-primary); font-family: var(--font-body); font-weight: 500; font-size: 0.875rem; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; transition: background var(--dur-fast); }
.gm-signup__btn:hover { background: var(--color-accent-gold-light); }
@media (max-width: 480px) { .gm-signup__form { flex-direction: column; } .gm-signup__input { border-right: 1px solid var(--color-border); margin-bottom: 8px; } }

/* WP default search form (used on 404 + search) */
.search-form { display: flex; gap: 0; max-width: 560px; margin: 0 auto; }
.search-form label { flex: 1; display: block; }
.search-form .search-field {
	width: 100%;
	padding: 14px 18px;
	background: var(--color-bg-secondary);
	color: var(--color-text-primary);
	border: 1px solid var(--color-border);
	border-right: 0;
	border-radius: 0;
	font-family: var(--font-body);
	font-size: 0.9375rem;
}
.search-form .search-field::placeholder { color: var(--color-text-muted); }
.search-form .search-field:focus { outline: none; border-color: var(--color-accent-gold); box-shadow: 0 0 0 2px var(--color-accent-gold-soft); }
.search-form .search-submit {
	border: 0;
	padding: 14px 28px;
	background: var(--color-accent-gold);
	color: var(--color-bg-primary);
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--dur-fast);
}
.search-form .search-submit:hover { background: var(--color-accent-gold-light); }
@media (max-width: 480px) {
	.search-form { flex-direction: column; }
	.search-form .search-field { border-right: 1px solid var(--color-border); margin-bottom: 8px; }
}

/* Contact form (CF7 / WPForms reset) */
.gm-contact-form input[type="text"],
.gm-contact-form input[type="email"],
.gm-contact-form input[type="tel"],
.gm-contact-form textarea,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea {
	width: 100%;
	padding: 14px 18px;
	background: var(--color-bg-secondary);
	color: var(--color-text-primary);
	border: 1px solid var(--color-border);
	font-family: var(--font-body);
	font-size: 1rem;
	margin-bottom: var(--space-md);
	border-radius: 2px;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus { outline: none; border-color: var(--color-accent-gold); box-shadow: 0 0 0 2px var(--color-accent-gold-soft); }
.wpcf7-form label { display: block; color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.75rem; font-weight: 500; margin-bottom: 8px; }
.wpcf7-form input[type="submit"] { background: var(--color-accent-gold); color: var(--color-bg-primary); border: 0; padding: 14px 32px; font-family: var(--font-body); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; font-size: 0.875rem; }
.wpcf7-form input[type="submit"]:hover { background: var(--color-accent-gold-light); }

/* -------- 15. 404 -------- */
.gm-404 { text-align: center; max-width: 640px; margin: 0 auto; padding: var(--space-5xl) 24px; }
.gm-404 h1 { margin-bottom: var(--space-md); }
.gm-404 p { color: var(--color-text-secondary); margin-bottom: var(--space-xl); }
.gm-404__buttons { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; }

/* -------- 16. Animations -------- */
.gm-reveal {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity var(--dur-slow) var(--ease-out-soft), transform var(--dur-slow) var(--ease-out-soft);
}
.gm-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.gm-stagger > * {
	opacity: 0;
	transform: translateY(20px);
	animation: gm-fade-up 0.7s var(--ease-out-soft) forwards;
}
.gm-stagger > *:nth-child(1) { animation-delay: 0s; }
.gm-stagger > *:nth-child(2) { animation-delay: 0.15s; }
.gm-stagger > *:nth-child(3) { animation-delay: 0.3s; }
.gm-stagger > *:nth-child(4) { animation-delay: 0.45s; }
@keyframes gm-fade-up { to { opacity: 1; transform: translateY(0); } }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001s !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001s !important;
		scroll-behavior: auto !important;
	}
	.gm-reveal { opacity: 1 !important; transform: none !important; }
	.gm-hero__bloom { display: none; }
}

/* -------- 17. Misc utilities -------- */
.screen-reader-text {
	border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
	height: 1px; width: 1px; overflow: hidden; position: absolute !important; word-wrap: normal !important;
}
.gm-center { text-align: center; }
.gm-mt-lg { margin-top: var(--space-xl); }

/* Easy TOC plugin override — version-agnostic (matches v2_0_x). */
div#ez-toc-container,
div#ez-toc-container[class*="ez-toc-v"] {
	background: var(--color-bg-secondary) !important;
	border: 1px solid var(--color-border) !important;
	color: var(--color-text-primary) !important;
	padding: var(--space-lg) var(--space-xl) !important;
	margin: var(--space-2xl) auto !important;
	max-width: var(--max-wide);
	border-radius: 2px !important;
}
#ez-toc-container .ez-toc-title-container, #ez-toc-container p.ez-toc-title {
	color: var(--color-accent-gold) !important;
	font-family: var(--font-body) !important;
	font-weight: 500 !important;
	font-size: 0.8125rem !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	margin-bottom: var(--space-md) !important;
}
#ez-toc-container .ez-toc-list a,
#ez-toc-container a { color: var(--color-text-secondary) !important; }
#ez-toc-container a:hover { color: var(--color-accent-gold) !important; }
#ez-toc-container .ez-toc-list { background: transparent !important; }
#ez-toc-container ul li, #ez-toc-container ol li { color: var(--color-text-secondary) !important; }

/* Hide unwanted Astra / default WP cruft if any sneaks in */
.gm-home #colophon, .gm-home #secondary { display: none; }

/* ── Transcript posts ───────────────────────────────────────── */
.gm-transcript {
	max-width: 720px;
	margin: var(--space-2xl) auto;
	padding: var(--space-xl);
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: 2px;
	font-family: 'Cormorant Garamond', Georgia, serif;
	font-weight: 300;
	font-style: italic;
	font-size: 1.125rem;
	line-height: 1.85;
	color: var(--color-text-secondary);
}
.gm-transcript p { margin-bottom: 1.5em; }
.gm-transcript p:last-child { margin-bottom: 0; }
.gm-transcript .pause-marker {
	display: block;
	text-align: center;
	color: var(--color-accent-gold);
	font-size: 0.875rem;
	font-style: normal;
	font-family: 'Inter', sans-serif;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 2em 0;
	opacity: 0.6;
}
.gm-glossary-toc {
	margin: var(--space-xl) 0;
	padding: var(--space-xl);
	background: var(--color-bg-secondary);
	border: 1px solid var(--color-border);
	border-radius: 2px;
	font-size: 0.95rem;
	line-height: 1.9;
}
.gm-glossary-toc p { margin: 0 0 0.5em; }
.gm-glossary-toc p:last-child { margin-bottom: 0; }
