/**
 * Single Blog Post — premium editorial layout.
 *
 * @package Vantage_Journeys
 */

/* ═══════════════════════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════════════════════ */

.vj-blog-hero {
	background: var(--surface-brand-default);
	padding-block: var(--padding-xl);
	color: var(--color-text-on-primary);
	position: relative;
	overflow: hidden;
	text-align: center;
	border-radius: var(--radius-xl);
}

.vj-blog-hero::before {
	content: '';
	position: absolute;
	top: -30%;
	right: -10%;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(246, 135, 55, 0.12) 0%, transparent 70%);
	pointer-events: none;
}

/* Breadcrumbs */
.vj-blog-hero__breadcrumbs {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: var(--space-xs);
	margin-bottom: var(--space-lg);
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	opacity: 0.75;
}

.vj-blog-hero__breadcrumbs a {
	color: var(--color-text-on-primary);
	text-decoration: none;
	transition: opacity var(--duration-fast) var(--ease-standard);
}

.vj-blog-hero__breadcrumbs a:hover {
	opacity: 1;
	text-decoration: underline;
}

.vj-blog-hero__breadcrumbs-sep {
	opacity: 0.5;
}

.vj-blog-hero__breadcrumbs span[aria-current="page"] {
	opacity: 1;
	font-weight: var(--fw-medium);
}

/* Category badges */
.vj-blog-hero__categories {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-xs);
	margin-bottom: var(--space-md);
}

.vj-blog-hero__badge {
	display: inline-flex;
	align-items: center;
	padding: var(--space-2xs) var(--space-sm);
	background: var(--color-brand-secondary);
	color: var(--color-text-on-secondary);
	font-family: var(--font-primary);
	font-size: var(--fs-2xs);
	font-weight: var(--fw-bold);
	text-transform: uppercase;
	letter-spacing: var(--ls-wider);
	border-radius: var(--radius-sm);
}

/* Title */
.vj-blog-hero__title {
	font-family: var(--font-family-primary);
	font-size: var(--type-display-sm);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	color: var(--color-text-on-primary);
	margin-bottom: var(--space-lg);
}

/* Meta row */
.vj-blog-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-lg);
}

.vj-blog-hero__meta-item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	color: var(--color-text-on-primary);
	opacity: 0.85;
	text-decoration: none;
}

.vj-blog-hero__meta-item:hover {
	opacity: 1;
}

.vj-blog-hero__meta-item svg {
	flex-shrink: 0;
	opacity: 0.75;
}

/* ═══════════════════════════════════════════════════════════
   FEATURED IMAGE
   ═══════════════════════════════════════════════════════════ */

.vj-blog-featured {
	margin-top: calc(-1 * var(--space-lg));
	padding-bottom: var(--space-xl);
	position: relative;
	z-index: 2;
}

.vj-blog-featured__figure {
	margin: 0;
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
}

.vj-blog-featured__img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 21 / 9;
	object-fit: cover;
}

/* ═══════════════════════════════════════════════════════════
   CONTENT + SIDEBAR LAYOUT
   ═══════════════════════════════════════════════════════════ */

.vj-blog-body {
	padding-bottom: var(--space-2xl);
}

.vj-blog-body__grid {
	display: grid;
	grid-template-columns: 1fr var(--sidebar-width);
	gap: var(--space-xl);
	align-items: start;
}

/* Main content */
.vj-blog-content {
	max-width: 100%;
	font-size: var(--fs-md);
	line-height: var(--lh-relaxed);
}

.vj-blog-content h1,
.vj-blog-content h2,
.vj-blog-content h3,
.vj-blog-content h4,
.vj-blog-content h5,
.vj-blog-content h6 {
	font-family: var(--font-primary);
}

/* ═══════════════════════════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════════════════════════ */

.vj-blog-sidebar {
	position: sticky;
	top: calc(var(--header-height) + var(--space-lg));
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.vj-blog-sidebar__card {
	background: var(--surface-grey-subtle);
	border-radius: var(--radius-lg);
	padding: var(--space-md);
}

.vj-blog-sidebar__card-title {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-weight: var(--fw-semibold);
	color: var(--color-text-primary);
	margin-bottom: var(--space-md);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
}

.vj-blog-sidebar__card-title svg {
	color: var(--color-brand-secondary);
}

/* TOC */
.vj-blog-toc__list {
	display: flex;
	flex-direction: column;
}

.vj-blog-toc__link {
	display: block;
	padding: var(--space-2xs) 0;
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	color: var(--color-text-secondary);
	text-decoration: none;
	border-bottom: 1px solid var(--border-grey-subtle);
	transition: color var(--duration-fast) var(--ease-standard), padding-left var(--duration-fast) var(--ease-standard);
}

.vj-blog-toc__link:last-child {
	border-bottom: none;
}

.vj-blog-toc__link:hover,
.vj-blog-toc__link.is-active {
	color: var(--color-brand-primary);
	padding-left: var(--space-xs);
}

.vj-blog-toc__link.is-active {
	font-weight: var(--fw-semibold);
	color: var(--color-brand-secondary);
	border-left: 3px solid var(--color-brand-secondary);
	padding-left: var(--space-sm);
}

.vj-blog-toc__link--h3 {
	padding-left: var(--space-md);
	font-size: var(--fs-xs);
}

.vj-blog-toc__link--h3:hover {
	padding-left: calc(var(--space-md) + var(--space-xs));
}

/* Recent posts */
.vj-blog-sidebar__recent-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.vj-blog-sidebar__recent-item {
	display: flex;
	gap: var(--space-sm);
	text-decoration: none;
	padding: var(--space-xs);
	border-radius: var(--radius-md);
	transition: background var(--duration-fast) var(--ease-standard);
}

.vj-blog-sidebar__recent-item:hover {
	background: var(--surface-grey-muted);
}

.vj-blog-sidebar__recent-img {
	width: 56px;
	height: 56px;
	border-radius: var(--radius-md);
	object-fit: cover;
	flex-shrink: 0;
}

.vj-blog-sidebar__recent-info {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	min-width: 0;
}

.vj-blog-sidebar__recent-title {
	font-family: var(--font-primary);
	font-size: var(--fs-xs);
	font-weight: var(--fw-semibold);
	color: var(--color-text-primary);
	line-height: var(--lh-snug);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.vj-blog-sidebar__recent-date {
	font-size: var(--fs-2xs);
	color: var(--color-text-muted);
}

/* CTA Card */
.vj-blog-sidebar__card--cta {
	background: var(--surface-brand-default);
	text-align: center;
	color: var(--color-white);
}

.vj-blog-sidebar__cta-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	margin: 0 auto var(--space-md);
	background: rgba(246, 135, 55, 0.15);
	border-radius: 50%;
	color: var(--color-brand-secondary);
}

.vj-blog-sidebar__cta-title {
	font-family: var(--font-primary);
	font-size: var(--fs-lg);
	font-weight: var(--fw-bold);
	color: var(--color-white);
	margin-bottom: var(--space-xs);
}

.vj-blog-sidebar__cta-text {
	font-size: var(--fs-sm);
	color: var(--color-white);
	opacity: 0.8;
	margin-bottom: var(--space-md);
	line-height: var(--lh-relaxed);
}

/* Category tags */
.vj-blog-sidebar__tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
}

.vj-blog-sidebar__tag {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2xs);
	padding: var(--space-2xs) var(--space-sm);
	background: var(--surface-grey-muted);
	border-radius: var(--radius-pill);
	font-family: var(--font-body);
	font-size: var(--fs-xs);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: all var(--duration-fast) var(--ease-standard);
}

.vj-blog-sidebar__tag:hover {
	background: var(--color-brand-secondary);
	color: var(--color-text-on-secondary);
}

.vj-blog-sidebar__tag-count {
	font-size: var(--fs-2xs);
	font-weight: var(--fw-semibold);
	background: rgba(0, 0, 0, 0.06);
	border-radius: var(--radius-pill);
	padding: 0 var(--space-xs);
	line-height: 1.8;
}

.vj-blog-sidebar__tag:hover .vj-blog-sidebar__tag-count {
	background: rgba(255, 255, 255, 0.2);
}

.vj-blog-sidebar__tags .vj-blog-sidebar__tag--fullwidth {
	flex-basis: 100%;
	justify-content: space-between;
}

/* ═══════════════════════════════════════════════════════════
   TAGS BAR
   ═══════════════════════════════════════════════════════════ */

.vj-blog-tags {
	padding-bottom: var(--space-xl);
}

.vj-blog-tags__inner {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-md) var(--space-lg);
	background: var(--surface-grey-subtle);
	border-radius: var(--radius-lg);
	flex-wrap: wrap;
}

.vj-blog-tags__label {
	display: flex;
	align-items: center;
	gap: var(--space-2xs);
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-weight: var(--fw-semibold);
	color: var(--color-text-primary);
	flex-shrink: 0;
}

.vj-blog-tags__label svg {
	color: var(--color-brand-secondary);
}

.vj-blog-tags__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
}

.vj-blog-tags__link {
	padding: var(--space-2xs) var(--space-sm);
	background: var(--surface-grey-default);
	border: 1px solid var(--border-grey-subtle);
	border-radius: var(--radius-pill);
	font-family: var(--font-body);
	font-size: var(--fs-xs);
	color: var(--color-text-secondary);
	text-decoration: none;
	transition: all var(--duration-fast) var(--ease-standard);
}

.vj-blog-tags__link:hover {
	background: var(--color-brand-secondary);
	border-color: var(--color-brand-secondary);
	color: var(--color-text-on-secondary);
}

/* ═══════════════════════════════════════════════════════════
   PREV / NEXT NAVIGATION
   ═══════════════════════════════════════════════════════════ */

.vj-blog-nav {
	padding-bottom: var(--space-2xl);
}

.vj-blog-nav__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-md);
}

.vj-blog-nav__item {
	padding: var(--space-lg) var(--space-xl);
	background: var(--surface-grey-subtle);
	border-radius: var(--radius-lg);
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-decoration: none;
	transition: background var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard);
}

a.vj-blog-nav__item:hover {
	background: var(--surface-grey-muted);
	box-shadow: var(--shadow-md);
}

.vj-blog-nav__item--next {
	text-align: right;
	align-items: flex-end;
}

.vj-blog-nav__label {
	display: flex;
	align-items: center;
	gap: var(--space-2xs);
	font-family: var(--font-primary);
	font-size: var(--fs-2xs);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	letter-spacing: var(--ls-wider);
	color: var(--color-brand-secondary);
	margin-bottom: var(--space-xs);
}

.vj-blog-nav__item--next .vj-blog-nav__label {
	justify-content: flex-end;
}

.vj-blog-nav__title {
	font-family: var(--font-primary);
	font-size: var(--fs-lg);
	font-weight: var(--fw-semibold);
	color: var(--color-brand-primary);
	line-height: var(--lh-snug);
}

a.vj-blog-nav__item:hover .vj-blog-nav__title {
	color: var(--color-brand-secondary);
}

.vj-blog-nav__item--empty {
	opacity: 0.5;
}

.vj-blog-nav__no-post {
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-style: italic;
	color: var(--color-text-muted);
}

/* ═══════════════════════════════════════════════════════════
   RELATED POSTS
   ═══════════════════════════════════════════════════════════ */

.vj-blog-related {
	padding-block: var(--space-2xl);
	background: var(--surface-grey-subtle);
}

.vj-blog-related__header {
	text-align: center;
	margin-bottom: var(--space-xl);
}

.vj-blog-related__eyebrow {
	display: block;
	font-family: var(--font-accent);
	font-size: var(--type-h4);
	font-weight: var(--fw-bold);
	color: var(--color-brand-secondary);
	letter-spacing: var(--ls-wider);
	margin-bottom: var(--space-xs);
}

.vj-blog-related__heading {
	font-family: var(--font-primary);
	font-size: var(--type-h2);
	font-weight: var(--fw-extrabold);
	color: var(--color-brand-primary);
	line-height: var(--lh-tight);
}

.vj-blog-related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-lg);
}

.vj-blog-related__card {
	background: var(--surface-grey-default);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform var(--duration-base) var(--ease-standard), box-shadow var(--duration-base) var(--ease-standard);
}

.vj-blog-related__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.vj-blog-related__card-image-wrap {
	position: relative;
	overflow: hidden;
}

.vj-blog-related__card-image-wrap a {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.vj-blog-related__card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-slow) var(--ease-standard);
}

.vj-blog-related__card:hover .vj-blog-related__card-img {
	transform: scale(1.06);
}

.vj-blog-related__card-cat {
	position: absolute;
	top: var(--space-sm);
	left: var(--space-sm);
	display: inline-flex;
	padding: var(--space-2xs) var(--space-xs);
	background: var(--color-brand-secondary);
	color: var(--color-text-on-secondary);
	font-family: var(--font-body);
	font-size: var(--fs-2xs);
	font-weight: var(--fw-bold);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
	border-radius: var(--radius-sm);
}

.vj-blog-related__card-body {
	padding: var(--space-md);
}

.vj-blog-related__card-date {
	display: flex;
	align-items: center;
	gap: var(--space-2xs);
	font-family: var(--font-body);
	font-size: var(--fs-2xs);
	color: var(--color-text-muted);
	margin-bottom: var(--space-xs);
}

.vj-blog-related__card-date svg {
	color: var(--color-brand-secondary);
	flex-shrink: 0;
}

.vj-blog-related__card-title {
	font-family: var(--font-primary);
	font-size: var(--fs-lg);
	font-weight: var(--fw-semibold);
	line-height: var(--lh-snug);
	margin-bottom: var(--space-xs);
}

.vj-blog-related__card-title a {
	color: var(--color-brand-primary);
	text-decoration: none;
	transition: color var(--duration-fast) var(--ease-standard);
}

.vj-blog-related__card-title a:hover {
	color: var(--color-brand-secondary);
}

.vj-blog-related__card-excerpt {
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	color: var(--color-text-secondary);
	line-height: var(--lh-relaxed);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════
   GSAP ANIMATION STATES
   ═══════════════════════════════════════════════════════════ */

[data-vj-animate="hero"] {
	opacity: 0;
	transform: translateY(30px);
}

[data-vj-animate="title"] {
	opacity: 0;
	transform: translateY(20px);
}

[data-vj-animate="meta"] {
	opacity: 0;
	transform: translateY(15px);
}

[data-vj-animate="image"] {
	opacity: 0;
	transform: translateY(40px) scale(0.98);
}

[data-vj-animate="content"] {
	opacity: 0;
	transform: translateY(30px);
}

[data-vj-animate="sidebar"] {
	opacity: 0;
	transform: translateX(30px);
}

[data-vj-animate="postnav"] {
	opacity: 0;
	transform: translateY(20px);
}

[data-vj-animate="related"] .vj-blog-related__card {
	opacity: 0;
	transform: translateY(40px);
}

[data-vj-animate="tags"] {
	opacity: 0;
	transform: translateY(15px);
}

/* ═══════════════════════════════════════════════════════════
   CONTENT IMAGE & BLOCKQUOTE STYLING
   ═══════════════════════════════════════════════════════════ */

.vj-blog-content figure {
	margin-block: var(--space-xl);
}

.vj-blog-content figure img {
	border-radius: var(--radius-lg);
	width: 100%;
	height: auto;
}

.vj-blog-content figcaption {
	margin-top: var(--space-xs);
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	text-align: center;
	font-style: italic;
}

.vj-blog-content blockquote {
	margin-block: var(--space-xl);
	padding: var(--space-lg) var(--space-xl);
	border-left: 4px solid var(--color-brand-secondary);
	background: var(--surface-brand-subtle);
	border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
	font-family: var(--font-primary);
	font-size: var(--fs-lg);
	font-style: italic;
	color: var(--color-brand-primary);
	line-height: var(--lh-relaxed);
}

.vj-blog-content blockquote p:last-child {
	margin-block-end: 0;
}

.vj-blog-content iframe,
.vj-blog-content .wp-block-embed {
	max-width: 100%;
	margin-block: var(--space-xl);
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.vj-blog-content .wp-block-embed iframe {
	width: 100%;
	border: none;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — TABLET
   ═══════════════════════════════════════════════════════════ */

@media screen and (max-width: 1024px) {
	.vj-blog-body__grid {
		grid-template-columns: 1fr;
	}

	.vj-blog-sidebar {
		position: static;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--space-md);
	}

	.vj-blog-sidebar__card--cta {
		grid-column: 1 / -1;
	}

	.vj-blog-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
   ═══════════════════════════════════════════════════════════ */

@media screen and (max-width: 767px) {
	.vj-blog-hero {
		padding-block: clamp(40px, 6vw, 80px);
	}

	.vj-blog-hero__breadcrumbs {
		gap: var(--space-2xs);
		font-size: var(--fs-xs);
	}

	.vj-blog-hero__title {
		font-size: var(--type-display-xs);
	}

	.vj-blog-hero__meta {
		gap: var(--space-sm);
	}

	.vj-blog-featured {
		margin-top: calc(-1 * var(--space-md));
	}

	.vj-blog-featured__figure {
		border-radius: var(--radius-md);
	}

	.vj-blog-sidebar {
		grid-template-columns: 1fr;
	}

	.vj-blog-nav__grid {
		grid-template-columns: 1fr;
		gap: var(--space-sm);
	}

	.vj-blog-nav__item {
		padding: var(--space-md);
	}

	.vj-blog-nav__item--next {
		text-align: left;
		align-items: flex-start;
	}

	.vj-blog-nav__item--next .vj-blog-nav__label {
		justify-content: flex-start;
		flex-direction: row-reverse;
	}

	.vj-blog-nav__title {
		font-size: var(--fs-md);
	}

	.vj-blog-related__grid {
		grid-template-columns: 1fr;
	}

	.vj-blog-related__card-image-wrap a {
		aspect-ratio: 16 / 9;
	}

	.vj-blog-content blockquote {
		padding: var(--space-md);
	}
}

/* ═══════════════════════════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
	[data-vj-animate],
	[data-vj-animate="hero"],
	[data-vj-animate="title"],
	[data-vj-animate="meta"],
	[data-vj-animate="image"],
	[data-vj-animate="content"],
	[data-vj-animate="sidebar"],
	[data-vj-animate="postnav"],
	[data-vj-animate="tags"],
	[data-vj-animate="related"] .vj-blog-related__card {
		opacity: 1 !important;
		transform: none !important;
	}

	.vj-blog-related__card,
	.vj-blog-related__card-img {
		transition: none !important;
	}
}
