/* ─────────────────────────────────────────────────────────────────
 *  Falcon Vision — Home Page Components
 *
 *  Composable pieces for front-page.php and similar editorial layouts.
 * ───────────────────────────────────────────────────────────────── */


/* ╔════════════════════════════════════════════════════════════════╗
 *  HERO SLIDER
 *  Full-bleed crossfading hero, used on home + destination heroes.
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-hero {
	position: relative;
	width: 100%;
	height: 100vh;
	min-height: 640px;
	max-height: 900px;
	overflow: hidden;
	background: var(--fv-color-black);
	isolation: isolate;
}

.fv-hero__stage {
	position: absolute;
	inset: 0;
}

.fv-hero__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity var(--fv-dur-cinema) var(--fv-ease-in-out);
	pointer-events: none;
}

.fv-hero__slide.is-active {
	opacity: 1;
	pointer-events: auto;
}

.fv-hero__slide img,
.fv-hero__slide picture {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Subtle Ken-Burns zoom on active slide */
@media (prefers-reduced-motion: no-preference) {
	.fv-hero__slide.is-active img {
		animation: fv-kenburns 14s ease-out forwards;
	}
}
@keyframes fv-kenburns {
	0%   { transform: scale(1);     }
	100% { transform: scale(1.08);  }
}

/* Vignette */
.fv-hero__vignette {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(0, 0, 0, 0.55) 0%, rgba(0, 0, 0, 0.2) 35%, rgba(0, 0, 0, 0.85) 100%),
		radial-gradient(ellipse at center, transparent 0%, rgba(0, 0, 0, 0.4) 100%);
	pointer-events: none;
	z-index: 1;
}

/* Hero content layer */
.fv-hero__content {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: var(--fv-space-24) var(--fv-space-16);
	text-align: center;
}

.fv-hero__eyebrow {
	margin-bottom: var(--fv-space-6);
}

.fv-hero__title {
	font-size: clamp(2.5rem, 6.5vw, 6rem);
	letter-spacing: var(--fv-tracking-widest);
	margin: 0;
	text-shadow: 0 4px 40px rgba(0, 0, 0, 0.4);
}

.fv-hero__title .fv-display {
	display: block;
	font-size: clamp(3rem, 8vw, 7rem);
	letter-spacing: var(--fv-tracking-normal);
	margin-top: var(--fv-space-2);
	text-transform: none;
	font-weight: var(--fv-weight-regular);
}

.fv-hero__caption {
	margin-top: var(--fv-space-8);
	color: var(--fv-color-bone);
	font-size: clamp(var(--fv-text-lg), 2vw, var(--fv-text-xl));
	font-family: var(--fv-font-display);
	font-style: italic;
	letter-spacing: 0;
	text-transform: none;
	max-width: 38rem;
	margin-inline: auto;
	min-height: 2.5em;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity var(--fv-dur-slow) var(--fv-ease-out), transform var(--fv-dur-slow) var(--fv-ease-out);
}

.fv-hero__caption.is-in {
	opacity: 1;
	transform: translateY(0);
}

.fv-hero__cta {
	margin-top: var(--fv-space-10);
	display: inline-flex;
	gap: var(--fv-space-3);
	flex-wrap: wrap;
	justify-content: center;
}

/* Pagination dots */
.fv-hero__dots {
	position: absolute;
	left: 50%;
	bottom: var(--fv-space-10);
	transform: translateX(-50%);
	z-index: 3;
	display: flex;
	gap: var(--fv-space-3);
}

.fv-hero__dot {
	width: 28px;
	height: 2px;
	background: rgba(255, 255, 255, 0.3);
	border: 0;
	cursor: pointer;
	transition: background-color var(--fv-dur-fast) var(--fv-ease-soft), width var(--fv-dur-base) var(--fv-ease-out);
	padding: 0;
}
.fv-hero__dot.is-active {
	background: var(--fv-color-white);
	width: 56px;
}
.fv-hero__dot:focus-visible {
	outline: 2px solid var(--fv-color-blue-light);
	outline-offset: 4px;
}

/* Scroll cue */
.fv-hero__scroll {
	position: absolute;
	left: 50%;
	bottom: var(--fv-space-4);
	transform: translateX(-50%);
	z-index: 3;
	font-size: var(--fv-text-2xs);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.6);
	display: none;
}
@media (min-width: 1024px) {
	.fv-hero__scroll {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: var(--fv-space-2);
	}
}
.fv-hero__scroll::after {
	content: "";
	width: 1px;
	height: 28px;
	background: rgba(255, 255, 255, 0.4);
	display: block;
	animation: fv-scroll-cue 2.2s ease-in-out infinite;
}
@keyframes fv-scroll-cue {
	0%,100% { transform: scaleY(0.3); opacity: 0.3; transform-origin: top; }
	50%     { transform: scaleY(1);   opacity: 1;   transform-origin: top; }
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  EDITORIAL INTRO SECTION
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-intro {
	position: relative;
	padding-block: var(--fv-section-y-loose);
	overflow: hidden;
}

.fv-intro__heading {
	font-size: clamp(var(--fv-text-3xl), 5vw, var(--fv-text-6xl));
	max-width: 26ch;
}

.fv-intro__heading .fv-display {
	display: inline;
}

.fv-intro__copy {
	font-size: var(--fv-text-lg);
	color: var(--fv-fg-muted);
	line-height: var(--fv-leading-relaxed);
	max-width: 36rem;
}

.fv-intro__meta {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--fv-space-6);
	margin-top: var(--fv-space-10);
	padding-top: var(--fv-space-8);
	border-top: 1px solid var(--fv-border);
}
@media (min-width: 640px) {
	.fv-intro__meta { grid-template-columns: repeat(3, 1fr); }
}

.fv-intro__meta-item .fv-num {
	font-family: var(--fv-font-display);
	font-style: italic;
	font-size: var(--fv-text-4xl);
	color: var(--fv-color-white);
	display: block;
	margin-bottom: var(--fv-space-1);
}
.fv-intro__meta-item .fv-label {
	font-size: var(--fv-text-2xs);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	color: var(--fv-fg-muted);
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  DESTINATION CARD
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-card {
	position: relative;
	display: block;
	overflow: hidden;
	color: var(--fv-color-white);
	background: var(--fv-bg-card);
	isolation: isolate;
	transition: transform var(--fv-dur-base) var(--fv-ease-out);
}

.fv-card:hover {
	transform: translateY(-4px);
}

.fv-card__media {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 5;
}
.fv-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--fv-dur-cinema) var(--fv-ease-out);
}
.fv-card:hover .fv-card__media img {
	transform: scale(1.08);
}

.fv-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,0.95) 100%);
	pointer-events: none;
}

.fv-card__content {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--fv-space-6) var(--fv-space-6) var(--fv-space-8);
	z-index: 2;
}

.fv-card__tagline {
	font-size: var(--fv-text-2xs);
	font-weight: var(--fv-weight-bold);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	color: var(--fv-color-blue-light);
	margin-bottom: var(--fv-space-2);
}

.fv-card__title {
	font-size: var(--fv-text-3xl);
	letter-spacing: var(--fv-tracking-wide);
	margin: 0;
	transition: color var(--fv-dur-base) var(--fv-ease-soft);
}

.fv-card__excerpt {
	color: var(--fv-color-bone);
	font-size: var(--fv-text-sm);
	line-height: var(--fv-leading-relaxed);
	margin-top: var(--fv-space-3);
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: max-height var(--fv-dur-slow) var(--fv-ease-out), opacity var(--fv-dur-slow) var(--fv-ease-out), margin-top var(--fv-dur-base) var(--fv-ease-out);
}
.fv-card:hover .fv-card__excerpt,
.fv-card:focus-within .fv-card__excerpt {
	max-height: 6em;
	opacity: 1;
}

.fv-card__arrow {
	position: absolute;
	top: var(--fv-space-5);
	right: var(--fv-space-5);
	width: 2.5rem;
	height: 2.5rem;
	background: rgba(0, 0, 0, 0.5);
	color: var(--fv-color-white);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.15);
	transition: background-color var(--fv-dur-base) var(--fv-ease-soft), transform var(--fv-dur-base) var(--fv-ease-out);
}
.fv-card:hover .fv-card__arrow {
	background: var(--fv-color-blue);
	border-color: var(--fv-color-blue);
	transform: translate(4px, -2px);
}

/* Compact / wide variants */
.fv-card--wide .fv-card__media { aspect-ratio: 16 / 11; }
.fv-card--compact .fv-card__media { aspect-ratio: 1 / 1; }


/* ╔════════════════════════════════════════════════════════════════╗
 *  EXPERIENCE CARD (smaller, denser than destination card)
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-exp-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--fv-bg-card);
	border: 1px solid var(--fv-border);
	overflow: hidden;
	color: var(--fv-color-white);
	transition: border-color var(--fv-dur-base) var(--fv-ease-soft), transform var(--fv-dur-base) var(--fv-ease-out);
}
.fv-exp-card:hover {
	border-color: var(--fv-color-blue);
	transform: translateY(-3px);
}

.fv-exp-card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.fv-exp-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--fv-dur-cinema) var(--fv-ease-out);
}
.fv-exp-card:hover .fv-exp-card__media img { transform: scale(1.05); }

.fv-exp-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.7) 100%);
	pointer-events: none;
}

.fv-exp-card__badge {
	position: absolute;
	top: var(--fv-space-3);
	left: var(--fv-space-3);
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: var(--fv-color-white);
	font-size: var(--fv-text-2xs);
	font-weight: var(--fv-weight-bold);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	padding: 0.35rem 0.75rem;
	z-index: 2;
}

.fv-exp-card__body {
	padding: var(--fv-space-6);
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--fv-space-3);
}

.fv-exp-card__title {
	font-size: var(--fv-text-xl);
	letter-spacing: var(--fv-tracking-wide);
	margin: 0;
}

.fv-exp-card__tagline {
	color: var(--fv-fg-muted);
	font-size: var(--fv-text-sm);
	line-height: var(--fv-leading-relaxed);
}

.fv-exp-card__meta {
	margin-top: auto;
	padding-top: var(--fv-space-4);
	border-top: 1px solid var(--fv-border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: var(--fv-text-xs);
	color: var(--fv-fg-muted);
	letter-spacing: var(--fv-tracking-wide);
}
.fv-exp-card__price {
	color: var(--fv-color-blue-light);
	font-weight: var(--fv-weight-semibold);
	text-transform: uppercase;
	letter-spacing: var(--fv-tracking-wider);
	font-size: var(--fv-text-2xs);
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  EXPERIENCES STRAP (full-bleed editorial banner before grid)
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-strap {
	position: relative;
	min-height: 60vh;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--fv-color-white);
	text-align: center;
}

.fv-strap__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.fv-strap__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.fv-strap__bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.85) 100%);
}

.fv-strap__content {
	position: relative;
	z-index: 1;
	padding-block: clamp(4rem, 10vw, 8rem);
}

.fv-strap__title {
	font-size: clamp(var(--fv-text-3xl), 6vw, var(--fv-text-6xl));
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  TESTIMONIAL SLIDER
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-testimonial-slider {
	position: relative;
	overflow: hidden;
}

.fv-testimonial-slider__viewport {
	overflow: hidden;
}

.fv-testimonial-slider__track {
	display: flex;
	transition: transform var(--fv-dur-cinema) var(--fv-ease-out);
}

.fv-testimonial-slider__slide {
	flex: 0 0 100%;
	min-width: 0;
	padding-inline: var(--fv-space-6);
}

.fv-testimonial {
	max-width: 56rem;
	margin-inline: auto;
	text-align: center;
}

.fv-testimonial__quote {
	font-family: var(--fv-font-display);
	font-style: italic;
	font-size: clamp(var(--fv-text-xl), 2.5vw, var(--fv-text-3xl));
	line-height: var(--fv-leading-snug);
	color: var(--fv-color-white);
	margin: 0;
	position: relative;
}

.fv-testimonial__quote::before,
.fv-testimonial__quote::after {
	content: '"';
	color: var(--fv-color-blue);
	opacity: 0.4;
	font-size: 4em;
	font-family: var(--fv-font-display);
	position: absolute;
	line-height: 0.7;
}
.fv-testimonial__quote::before {
	left: -0.05em;
	top: -0.2em;
}

.fv-testimonial__author {
	display: block;
	margin-top: var(--fv-space-8);
	font-family: var(--fv-font-heading);
	font-size: var(--fv-text-xs);
	font-weight: var(--fv-weight-bold);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	color: var(--fv-color-white);
}

.fv-testimonial__location {
	display: block;
	margin-top: var(--fv-space-2);
	font-size: var(--fv-text-2xs);
	letter-spacing: var(--fv-tracking-wider);
	color: var(--fv-fg-muted);
	text-transform: uppercase;
}

.fv-testimonial-slider__controls {
	display: flex;
	justify-content: center;
	gap: var(--fv-space-6);
	margin-top: var(--fv-space-10);
	align-items: center;
}

.fv-testimonial-slider__arrow {
	width: 3rem;
	height: 3rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--fv-border-strong);
	color: var(--fv-color-white);
	background: transparent;
	cursor: pointer;
	transition: all var(--fv-dur-fast) var(--fv-ease-soft);
}
.fv-testimonial-slider__arrow:hover {
	background: var(--fv-color-blue);
	border-color: var(--fv-color-blue);
}
.fv-testimonial-slider__arrow:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.fv-testimonial-slider__counter {
	font-family: var(--fv-font-display);
	font-style: italic;
	font-size: var(--fv-text-lg);
	color: var(--fv-fg-muted);
	min-width: 4rem;
	text-align: center;
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  BLOG STRIP (3-up article cards)
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-blog-card {
	display: block;
	color: var(--fv-color-white);
}

.fv-blog-card__media {
	overflow: hidden;
	aspect-ratio: 4 / 3;
	margin-bottom: var(--fv-space-5);
}
.fv-blog-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--fv-dur-cinema) var(--fv-ease-out);
}
.fv-blog-card:hover .fv-blog-card__media img { transform: scale(1.06); }

.fv-blog-card__date {
	font-size: var(--fv-text-2xs);
	letter-spacing: var(--fv-tracking-widest);
	text-transform: uppercase;
	color: var(--fv-color-mist);
	margin-bottom: var(--fv-space-2);
}

.fv-blog-card__title {
	font-size: var(--fv-text-xl);
	line-height: var(--fv-leading-snug);
	letter-spacing: var(--fv-tracking-wide);
	margin: 0 0 var(--fv-space-3);
	transition: color var(--fv-dur-base) var(--fv-ease-soft);
}
.fv-blog-card:hover .fv-blog-card__title { color: var(--fv-color-blue-light); }

.fv-blog-card__excerpt {
	color: var(--fv-fg-muted);
	font-size: var(--fv-text-sm);
	line-height: var(--fv-leading-relaxed);
}


/* ╔════════════════════════════════════════════════════════════════╗
 *  SECTION HEADERS
 *  ╚════════════════════════════════════════════════════════════════╝ */

.fv-section-header {
	display: flex;
	flex-direction: column;
	gap: var(--fv-space-6);
	margin-bottom: var(--fv-space-16);
	align-items: flex-start;
}
.fv-section-header--center {
	align-items: center;
	text-align: center;
}
@media (min-width: 768px) {
	.fv-section-header:not(.fv-section-header--center) {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-end;
	}
}

.fv-section-header__title {
	font-size: clamp(var(--fv-text-2xl), 4vw, var(--fv-text-5xl));
	max-width: 24ch;
	margin: 0;
}
.fv-section-header__title .fv-display {
	display: inline;
}

.fv-section-header__copy {
	color: var(--fv-fg-muted);
	max-width: 32rem;
	font-size: var(--fv-text-base);
	line-height: var(--fv-leading-relaxed);
}
