/**
 * Layer 5 — Testimonials page styles
 *
 * Purpose:  Google reviews + video testimonials sections.
 * Loaded:   vj_is_testimonials_page() and is_front_page()
 * Depends:  components.css, layout.css
 * Rule:     Page-only rules; do not duplicate components.css.
 *
 * @package Vantage_Journeys
 */

/* ─────────────────────────────────────────────────────────────
   Hero Section (matches About / Visa / Blog hero pattern)
   ───────────────────────────────────────────────────────────── */

.vj-testimonials-hero {
	margin-inline: 8px;
	margin-block-start: var(--space-md);
	position: relative;
	z-index: 1;
}

.vj-testimonials-hero__wrapper {
	position: relative;
	z-index: 1;
	background-color: var(--surface-brand-default);
	border-radius: 15px;
	padding-block: clamp(40px, 6vw, 80px);
	overflow: hidden;
}

.vj-testimonials-hero__breadcrumbs {
	font-family: var(--font-family-body);
	font-size: var(--fs-xs);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-block-end: var(--space-lg);
	color: rgba(255, 255, 255, 0.7);
}

.vj-testimonials-hero__breadcrumbs a {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	transition: color var(--duration-base);
}

.vj-testimonials-hero__breadcrumbs a:hover {
	color: var(--color-brand-secondary);
}

.vj-testimonials-hero__breadcrumbs-separator {
	margin-inline: var(--space-2xs);
	color: rgba(255, 255, 255, 0.4);
}

.vj-testimonials-hero__breadcrumbs-current {
	color: var(--color-white);
	font-weight: 600;
}

.vj-testimonials-hero__eyebrow {
	display: block;
	font-family: var(--font-family-accent);
	font-size: var(--type-h3);
	font-weight: 700;
	color: var(--color-brand-secondary);
	margin-block-end: var(--space-xs);
}

.vj-testimonials-hero__title {
	font-family: var(--font-family-primary);
	font-size: clamp(28px, 4.5vw, 56px);
	font-weight: var(--font-weight-extrabold);
	line-height: var(--lh-tight);
	color: var(--color-white);
	max-width: 900px;
	margin-inline: auto;
	margin-block-end: var(--space-md);
}

.vj-testimonials-hero__lead {
	font-family: var(--font-family-body);
	font-size: clamp(16px, 1.25vw, 20px);
	line-height: var(--lh-relaxed);
	color: var(--color-neutral-50);
	max-width: 760px;
	margin-inline: auto;
	margin-block-end: 0;
}

/* ─────────────────────────────────────────────────────────────
   Section Layout
   ───────────────────────────────────────────────────────────── */

.vj-testimonials {
	padding: var(--padding-section);
	background-color: transparent;
	overflow: hidden;
	position: relative;
}

.vj-testimonials--video {
	background-color: transparent;
	margin-top: var(--space-xl);
}

/* ─────────────────────────────────────────────────────────────
   Section Header (eyebrow + heading + sub-heading)
   ───────────────────────────────────────────────────────────── */

.vj-testimonials__header {
	margin-bottom: var(--space-xl);
}

.vj-testimonials__eyebrow {
	display: inline-block;
	font-family: var(--font-family-accent);
	color: var(--color-brand-secondary);
	font-size: var(--fs-3xl);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-wider);
	margin-bottom: var(--space-xs);
}

.vj-testimonials__heading {
	font-family: var(--font-primary);
	color: var(--color-brand-primary);
	font-size: var(--fs-3xl);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	margin: 0;
}

.vj-testimonials__sub-heading {
	color: var(--color-text-secondary);
	font-size: var(--fs-md);
	line-height: var(--lh-relaxed);
	margin: var(--space-sm) 0 0;
}

/* ─────────────────────────────────────────────────────────────
   Empty State
   ───────────────────────────────────────────────────────────── */

.vj-testimonials__empty {
	padding: var(--space-lg) 0;
	color: var(--color-text-secondary);
	text-align: center;
}

/* ─────────────────────────────────────────────────────────────
   Google Reviews Grid
   ───────────────────────────────────────────────────────────── */

.vj-testimonials__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gap-grid-col-lg);
	margin: 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 640px) {
	.vj-testimonials__grid--text {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.vj-testimonials__grid--text {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

/* ─────────────────────────────────────────────────────────────
   Video Grid — 2 → 3 → 4 columns
   ───────────────────────────────────────────────────────────── */

.vj-testimonials__grid--video {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--gap-grid-col-md);
}

@media (min-width: 640px) {
	.vj-testimonials__grid--video {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.vj-testimonials__grid--video {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

/* ─────────────────────────────────────────────────────────────
   Review Card
   ───────────────────────────────────────────────────────────── */

.vj-testimonials-card {
	background: var(--surface-grey-default);
	border: 1px solid var(--border-grey-default);
	border-radius: var(--radius-card);
	padding: var(--padding-card);
	box-shadow: var(--shadow-sm);
}

.vj-testimonials-card__rating {
	margin: 0 0 var(--space-sm);
	color: var(--color-brand-secondary);
	letter-spacing: var(--ls-wide);
}

.vj-testimonials-card__quote {
	margin: 0;
}

.vj-testimonials-card__quote p {
	margin: 0;
	font-size: var(--fs-md);
	line-height: var(--lh-relaxed);
	color: var(--color-text-primary);
}

.vj-testimonials-card__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gap-inline-sm);
	margin-top: var(--space-md);
	font-size: var(--fs-sm);
	color: var(--color-text-secondary);
}

.vj-testimonials-card__meta-left {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--gap-inline-sm);
}

.vj-testimonials-card__author {
	font-style: normal;
	font-weight: var(--fw-semibold);
	color: var(--color-text-primary);
}

.vj-testimonials-card__source {
	display: inline-flex;
	align-items: center;
	color: #4285F4;
}

.vj-testimonials-card__source svg {
	width: var(--icon-size-sm, 16px);
	height: var(--icon-size-sm, 16px);
}

/* ─────────────────────────────────────────────────────────────
   Video Card
   ───────────────────────────────────────────────────────────── */

.vj-testimonials-card--video {
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
	overflow: hidden;
	border-radius: var(--radius-card);
	cursor: pointer;
	transition: transform var(--duration-base) var(--ease-standard);
}

@media (hover: hover) {
	.vj-testimonials-card--video:hover {
		transform: scale(1.03);
	}
}

/* ─────────────────────────────────────────────────────────────
   Video Player
   ───────────────────────────────────────────────────────────── */

.vj-testimonial-player {
	width: 100%;
}

.vj-testimonial-player__stage {
	position: relative;
	width: 100%;
	aspect-ratio: 9 / 16;
	background: var(--surface-grey-inverse);
	overflow: hidden;
	border-radius: var(--radius-card);
}

.vj-testimonial-player__poster {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
	transition: transform var(--duration-base) ease;
}

@media (hover: hover) {
	.vj-testimonials-card--video:hover .vj-testimonial-player__poster {
		transform: scale(1.05);
	}
}

.vj-testimonial-player__poster--default {
	background: linear-gradient(
		145deg,
		var(--surface-grey-inverse) 0%,
		var(--surface-grey-inverse-muted) 100%
	);
}

.vj-testimonial-player__play {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.vj-testimonial-player__play-icon {
	display: block;
	width: 3rem;
	height: 3rem;
	border-radius: var(--radius-pill);
	background: color-mix(in srgb, var(--color-brand-secondary) 90%, transparent);
	box-shadow: var(--shadow-md);
	position: relative;
	transition: transform var(--duration-base) var(--ease-spring);
}

@media (hover: hover) {
	.vj-testimonials-card--video:hover .vj-testimonial-player__play-icon {
		transform: scale(1.12);
	}
}

.vj-testimonial-player__play-icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 54%;
	transform: translate(-50%, -50%);
	border-style: solid;
	border-width: 0.5rem 0 0.5rem 0.85rem;
	border-color: transparent transparent transparent var(--color-text-on-secondary);
}

/* Hide inline video/embed — modal handles playback now */
.vj-testimonial-player__video,
.vj-testimonial-player__embed {
	display: none;
}

/* ─────────────────────────────────────────────────────────────
   Video Modal
   ───────────────────────────────────────────────────────────── */

.vj-video-modal {
	position: fixed;
	inset: 0;
	z-index: 1000000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
}

.vj-video-modal.is-active {
	opacity: 1;
	pointer-events: auto;
}

.vj-video-modal__overlay {
	position: absolute;
	inset: 0;
	background: var(--color-overlay-scrim);
}

.vj-video-modal__dialog {
	position: relative;
	z-index: 1;
	width: min(90vw, 420px);
	max-height: 90vh;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-black);
	transform: scale(0.95);
	opacity: 0;
	transition: transform var(--duration-base) var(--ease-spring), opacity var(--duration-base) ease;
}

.vj-video-modal.is-active .vj-video-modal__dialog {
	transform: scale(1);
	opacity: 1;
}

.vj-video-modal__video-wrap {
	position: relative;
	width: 100%;
	aspect-ratio: 9 / 16;
	max-height: 85vh;
	background: var(--color-black);
}

.vj-video-modal__video-wrap video,
.vj-video-modal__video-wrap iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	border: 0;
}

.vj-video-modal__close {
	position: absolute;
	top: var(--space-sm);
	right: var(--space-sm);
	z-index: 2;
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0;
	border-radius: var(--radius-pill);
	background: rgba(0, 0, 0, 0.5);
	color: var(--color-white);
	cursor: pointer;
	font-size: var(--fs-lg);
	line-height: 1;
	transition: background var(--duration-fast) ease;
}

.vj-video-modal__close:hover {
	background: rgba(0, 0, 0, 0.75);
}

body.vj-video-modal-open {
	overflow: hidden;
}

/* ─────────────────────────────────────────────────────────────
   Modal — Reduced motion
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.vj-video-modal__dialog {
		transition: none;
	}
}
