/* ============================================================
   TUTMS MAIN STYLESHEET
   Imports: style.css (tokens, reset, base) → this file (components)
   ============================================================ */

/* ============================================================
   SITE HEADER
   ============================================================ */

.site-header {
	position: sticky;
	top: 0;
	z-index: 200;
	background-color: var(--color-plum);
	box-shadow: var(--shadow-sm);
}

.site-header__inner {
	display: flex;
	align-items: center;
	gap: var(--space-6);
	height: 72px;
}

.site-header__logo img {
	height: 44px;
	width: auto;
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin-left: auto;
}

/* Client Login / My Library button */
.btn-client-area {
	display: inline-flex;
	align-items: center;
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-4);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	color: #fff;
	border: 2px solid rgba(255, 255, 255, 0.7);
	border-radius: var(--radius-full);
	transition: background-color var(--transition-fast), border-color var(--transition-fast);
	white-space: nowrap;
}

.btn-client-area:hover,
.btn-client-area:focus {
	background-color: rgba(255, 255, 255, 0.15);
	border-color: #fff;
	color: #fff;
}

/* ============================================================
   PRIMARY NAV (desktop only)
   ============================================================ */

.nav-primary {
	display: none; /* hidden on mobile/tablet */
}

@media (min-width: 1200px) {
	.nav-primary {
		display: block;
	}
}

.nav-primary__list {
	display: flex;
	align-items: center;
	gap: var(--space-1);
}

.nav-primary__link {
	display: flex;
	align-items: center;
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-3);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.85);
	border-radius: var(--radius-sm);
	transition: color var(--transition-fast), background-color var(--transition-fast);
	white-space: nowrap;
}

.nav-primary__link:hover,
.nav-primary__link:focus,
.current-menu-item .nav-primary__link {
	color: #fff;
	background-color: rgba(255, 255, 255, 0.12);
}

/* Hamburger — visible on mobile/tablet only */
.hamburger {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: var(--touch-target);
	height: var(--touch-target);
	padding: var(--space-3);
}

.hamburger__bar {
	display: block;
	height: 2px;
	background-color: #fff;
	border-radius: 2px;
	transition: transform var(--transition-base), opacity var(--transition-base);
}

.hamburger[aria-expanded="true"] .hamburger__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.hamburger[aria-expanded="true"] .hamburger__bar:nth-child(2) {
	opacity: 0;
}
.hamburger[aria-expanded="true"] .hamburger__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (min-width: 1200px) {
	.hamburger {
		display: none;
	}
}

/* ============================================================
   MOBILE DRAWER
   ============================================================ */

.drawer-overlay {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 299;
	background-color: rgba(0, 0, 0, 0.5);
}

.drawer-overlay.is-active {
	display: block;
}

.mobile-drawer {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 300;
	width: min(320px, 90vw);
	height: 100vh;
	background-color: var(--color-plum);
	transform: translateX(100%);
	transition: transform var(--transition-base);
	display: flex;
	flex-direction: column;
	overflow-y: auto;
}

.mobile-drawer.is-open {
	transform: translateX(0);
}

.mobile-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-4) var(--space-6);
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.mobile-drawer__header img {
	height: 36px;
	width: auto;
}

.drawer-close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--touch-target);
	height: var(--touch-target);
	color: #fff;
	font-size: var(--text-2xl);
	border-radius: var(--radius-sm);
	transition: background-color var(--transition-fast);
}

.drawer-close:hover,
.drawer-close:focus {
	background-color: rgba(255, 255, 255, 0.15);
}

.mobile-drawer__list {
	padding: var(--space-4) var(--space-6);
	flex: 1;
}

.mobile-drawer__link {
	display: flex;
	align-items: center;
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-3);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-lg);
	color: rgba(255, 255, 255, 0.85);
	border-radius: var(--radius-sm);
	transition: color var(--transition-fast), background-color var(--transition-fast);
}

.mobile-drawer__link:hover,
.mobile-drawer__link:focus {
	color: #fff;
	background-color: rgba(255, 255, 255, 0.12);
}

.mobile-drawer__footer {
	padding: var(--space-6);
	border-top: 1px solid rgba(255, 255, 255, 0.15);
}

/* ============================================================
   HOMEPAGE HERO
   ============================================================ */

.hero-homepage {
	display: flex;
	min-height: 580px;
	/* Coral fills the gap exposed by the diagonal clip on the left panel */
	background-color: var(--color-coral);
}

/* Left panel — Plum with a diagonal cut at the right edge */
.hero-homepage__left {
	flex: 0 0 56%;
	background-color: var(--color-plum);
	display: flex;
	align-items: center;
	/* Extra right padding keeps content clear of the diagonal */
	padding: var(--space-16) var(--space-12) var(--space-16) var(--space-8);
	clip-path: polygon(0 0, 100% 0, 95% 100%, 0 100%);
	position: relative;
	z-index: 1;
}

/* Right panel — inherits Coral from container; no background set here */
.hero-homepage__right {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-8);
	position: relative;
	overflow: hidden;
}

/* Soft radial glow centered behind the illustration */
.hero-homepage__right::before {
	content: '';
	position: absolute;
	width: 85%;
	padding-bottom: 85%;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.22) 0%, transparent 65%);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	pointer-events: none;
}

.hero-homepage__content {
	max-width: 520px;
}

.hero-homepage__logo {
	height: 80px;
	width: auto;
	margin-bottom: var(--space-6);
}

.hero-homepage__tagline {
	font-size: var(--text-4xl);
	color: #fff;
	margin-bottom: var(--space-4);
	line-height: 1.1;
}

.hero-homepage__intro {
	font-size: var(--text-lg);
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: var(--space-8);
}

.hero-homepage__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

.hero-homepage__lamp {
	max-height: 460px;
	width: auto;
	object-fit: contain;
	position: relative;
	z-index: 1;
	filter: drop-shadow(0 6px 20px rgba(0, 0, 0, 0.22));
}

.hero-homepage__illustration {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

/* Mobile: stacked, diagonal removed, right panel hidden */
@media (max-width: 767px) {
	.hero-homepage {
		flex-direction: column;
		min-height: auto;
		background-color: var(--color-plum);
	}

	.hero-homepage__left {
		flex: none;
		clip-path: none;
		padding: var(--space-12) var(--container-pad);
	}

	.hero-homepage__right {
		display: none;
	}

	.hero-homepage__tagline {
		font-size: var(--text-3xl);
	}
}

/* Tablet: equal panels, diagonal preserved, tighter padding */
@media (min-width: 768px) and (max-width: 1199px) {
	.hero-homepage__left {
		flex: 1;
		padding: var(--space-12) var(--space-8);
	}

	.hero-homepage__tagline {
		font-size: var(--text-3xl);
	}
}

/* Desktop: larger tagline */
@media (min-width: 1200px) {
	.hero-homepage__tagline {
		font-size: var(--text-5xl);
	}
}

/* ============================================================
   SECTION HEADINGS & INTROS
   ============================================================ */

.section-heading {
	margin-bottom: var(--space-8);
}

.page-title {
	margin-bottom: var(--space-4);
}

.page-intro {
	font-size: var(--text-lg);
	color: var(--color-body-text);
	max-width: 640px;
	margin-bottom: var(--space-8);
}

.section-cta {
	margin-top: var(--space-8);
	text-align: center;
}

/* ============================================================
   HOTEL GRID
   ============================================================ */

.hotel-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 768px) {
	.hotel-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1200px) {
	.hotel-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Hotel card */
.hotel-card {
	border-radius: var(--radius-md);
	overflow: hidden;
	/* Plum-tinted grey border + shadow — visible but neutral */
	border: 1px solid rgba(82, 62, 96, 0.18);
	box-shadow: 0 2px 8px rgba(82, 62, 96, 0.2);
	background-color: #fff;
	transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);
}

.hotel-card:hover {
	border-color: rgba(82, 62, 96, 0.28);
	box-shadow: 0 4px 16px rgba(82, 62, 96, 0.26);
	transform: translateY(-2px);
}

.hotel-card--featured {
	border: 2px solid var(--color-gold);
	box-shadow: 0 2px 8px rgba(82, 62, 96, 0.2);
}

.hotel-card__link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.hotel-card__image-wrap {
	position: relative;
	height: 210px;
	/* Diagonal cut matching the D1 landscape review card treatment */
	clip-path: polygon(0 0, 100% 0, 100% 82%, 0 100%);
}

.hotel-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-base);
	display: block;
}

.hotel-card:hover .hotel-card__image {
	transform: scale(1.03);
}

.hotel-card__featured-badge {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	background-color: var(--color-gold);
	color: var(--color-slate-navy);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-xs);
	padding: var(--space-1) var(--space-2);
	border-radius: var(--radius-sm);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.hotel-card__video-badge {
	position: absolute;
	bottom: calc(18% + var(--space-2)); /* sit above the diagonal cut */
	right: var(--space-3);
	background-color: rgba(0, 0, 0, 0.65);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-xs);
	padding: var(--space-1) var(--space-3);
	border-radius: var(--radius-sm);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.hotel-card__body {
	padding: var(--space-4);
}

.hotel-card__name {
	font-size: var(--text-lg);
	color: var(--color-heading);
	margin-bottom: var(--space-3);
}

.hotel-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

/* ============================================================
   META TAGS
   ============================================================ */

.meta-tag {
	display: inline-block;
	padding: var(--space-1) var(--space-2);
	font-size: var(--text-xs);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	border-radius: var(--radius-sm);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.meta-tag--destination { background-color: var(--color-blue);    color: #fff; }
.meta-tag--distance    { background-color: var(--color-blush);   color: var(--color-slate-navy); }
.meta-tag--price       { background-color: var(--color-plum);    color: #fff; }
.meta-tag--category    { background-color: var(--color-coral);   color: #fff; }

/* ============================================================
   REVIEW CARD — shared shell
   ============================================================ */

.review-card {
	background-color: #fff;
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
	display: flex;
}

/* Shared body */
.review-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex: 1;
}

.review-card__testimonial {
	flex: 1;
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--color-body-text);
	font-style: italic;
	margin: 0;
}

.review-card__testimonial p { margin: 0; }

.review-card__read-more a {
	font-weight: var(--font-weight-bold);
	color: var(--color-red);
}

.review-card__footer {
	padding-top: var(--space-3);
	border-top: 1px solid var(--color-blush);
}

.review-card__name {
	font-style: normal;
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	color: var(--color-plum);
	display: block;
}

.review-card__meta {
	display: flex;
	gap: var(--space-3);
	flex-wrap: wrap;
	margin-top: var(--space-1);
}

.review-card__advisor,
.review-card__date {
	font-size: var(--text-sm);
	color: var(--color-body-text);
}

/* ── No-photo card ────────────────────────────────────────── */

.review-card--no-photo {
	padding: var(--space-6);
	flex-direction: column;
	min-height: 180px;
}

/* ── Portrait photo — diagonal column on left (Option D) ──── */

.review-card--portrait {
	flex-direction: row;
	min-height: 220px;
}

.review-card--portrait .review-card__photo-wrap {
	width: 190px;
	flex-shrink: 0;
	position: relative;
	overflow: hidden;
}

.review-card--portrait .review-card__photo {
	position: absolute;
	inset: 0;
	width: 115%;  /* oversized slightly so diagonal clip has no gap */
	height: 100%;
	object-fit: cover;
	/* Diagonal cut: full height on left, clips ~18% on right */
	clip-path: polygon(0 0, 100% 0, 82% 100%, 0 100%);
}

.review-card--portrait .review-card__body {
	padding: var(--space-6) var(--space-6) var(--space-6) var(--space-5);
}

/* ── Landscape photo — full-width strip at top (Option D1) ── */

.review-card--landscape {
	flex-direction: column;
}

.review-card--landscape .review-card__photo-wrap {
	width: 100%;
	height: 220px;
	flex-shrink: 0;
	position: relative;
	overflow: hidden;
}

.review-card--landscape .review-card__photo {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	/* Diagonal cut: full height on left, ~22% off bottom-right */
	clip-path: polygon(0 0, 100% 0, 100% 78%, 0 100%);
}

.review-card--landscape .review-card__body {
	padding: var(--space-4) var(--space-6) var(--space-6);
}

/* Mobile: portrait cards switch to full-width strip layout */
@media (max-width: 767px) {
	.review-card--portrait {
		flex-direction: column;
	}

	.review-card--portrait .review-card__photo-wrap {
		width: 100%;
		height: 180px;
		clip-path: none;
	}

	.review-card--portrait .review-card__photo {
		width: 100%;
		clip-path: polygon(0 0, 100% 0, 100% 80%, 0 100%);
	}

	.review-card--portrait .review-card__body {
		padding: var(--space-4) var(--space-5) var(--space-5);
	}
}

/* ── Swiper carousel ─────────────────────────────────────── */

.tutms-reviews-carousel {
	padding-bottom: var(--space-12) !important;
}

.tutms-reviews-carousel .swiper-slide {
	height: auto;
	display: flex;
	align-items: stretch;
}

/* Card fills the slide so all visible cards match height */
.tutms-reviews-carousel .swiper-slide .review-card {
	width: 100%;
}

.tutms-reviews-carousel .swiper-button-prev,
.tutms-reviews-carousel .swiper-button-next {
	color: var(--color-plum);
}

/* ── Review grid (reviews page) ──────────────────────────── */

.review-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	align-items: start;
}

@media (min-width: 768px) {
	.review-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-layout {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: var(--space-12);
	align-items: start;
}

/* Message column */
.contact-message__heading {
	font-size: var(--text-3xl);
	color: var(--color-plum);
	margin-bottom: var(--space-6);
	line-height: 1.2;
}

.contact-message__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	color: var(--color-body-text);
	font-size: var(--text-base);
	line-height: 1.7;
}

.contact-message__body p { margin: 0; }

.contact-message__highlight {
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-lg);
	color: var(--color-plum);
}

.contact-message__sign-off {
	margin-top: var(--space-5);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-lg);
	color: var(--color-body-text);
}

.contact-message__info {
	margin-top: var(--space-5);
	padding-top: var(--space-5);
	border-top: 2px solid var(--color-plum);
}

.contact-message__email {
	color: var(--color-red);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	word-break: break-all;
}

.contact-message__email:hover {
	text-decoration: underline;
}

/* Form column */
.contact-form__heading {
	font-size: var(--text-2xl);
	color: var(--color-plum);
	margin-bottom: var(--space-5);
}

/* Mobile: stack columns */
@media (max-width: 767px) {
	.contact-layout {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}
}

/* ============================================================
   FEEDBACK LAYOUT
   ============================================================ */

.feedback-layout {
	max-width: 680px;
	margin-inline: auto;
}

.feedback-layout__header {
	margin-bottom: var(--space-8);
}

.feedback-layout__header h1 {
	margin-bottom: var(--space-4);
}

/* ============================================================
   PRODUCT GRID
   ============================================================ */

.product-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 768px) {
	.product-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1200px) {
	.product-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1440px) {
	.product-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* Product card */
.product-card {
	background-color: #fff;
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
}

.product-card__image-wrap {
	aspect-ratio: 1;
	overflow: hidden;
}

.product-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.product-card__body {
	padding: var(--space-4);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex: 1;
}

.product-card__name {
	font-size: var(--text-lg);
	color: var(--color-heading);
}

.product-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.product-card__review {
	font-size: var(--text-sm);
	line-height: 1.6;
	color: var(--color-body-text);
	flex: 1;
}

.product-card__cta {
	align-self: flex-start;
	margin-top: auto;
}

/* ============================================================
   AMAZON LISTS
   ============================================================ */

.amazon-lists {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

.amazon-list-link {
	display: inline-flex;
	align-items: center;
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-4);
	background-color: rgba(255, 255, 255, 0.15);
	color: #fff;
	border: 2px solid rgba(255, 255, 255, 0.5);
	border-radius: var(--radius-md);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.amazon-list-link:hover,
.amazon-list-link:focus {
	background-color: rgba(255, 255, 255, 0.25);
	border-color: #fff;
	color: #fff;
}

/* ============================================================
   FILTERS
   ============================================================ */

.filter-bar {
	margin-bottom: var(--space-8);
}

/* Mobile: collapsible toggle */
.filter-toggle {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-4);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-base);
	color: var(--color-plum);
	border: 2px solid var(--color-plum);
	border-radius: var(--radius-md);
	background: transparent;
}

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

.filter-panel {
	display: none;
	padding-top: var(--space-4);
}

.filter-panel.is-open {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-4);
	align-items: flex-end;
}

@media (min-width: 768px) {
	.filter-panel {
		display: flex !important;
		flex-wrap: wrap;
		gap: var(--space-4) var(--space-6);
		align-items: flex-end;
		padding-top: 0;
	}
}

.filter-group {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	min-width: 180px;
}

/* Amenities group spans the full row and uses horizontal checkboxes */
.filter-group:has(fieldset) {
	flex-basis: 100%;
	min-width: 0;
}

.filter-group fieldset {
	width: 100%;
	box-sizing: border-box;
	padding: var(--space-2) var(--space-4) var(--space-3);
	border: 1px solid #d9cfe0; /* muted plum-tinted grey, matches card border family */
	border-radius: var(--radius-sm);
}

.filter-group fieldset legend {
	padding-inline: var(--space-2);
	color: var(--color-heading);
}

.filter-label {
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	color: var(--color-heading);
}

.filter-select {
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-3);
	border: 2px solid var(--color-blush);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-body-text);
	background-color: #fff;
	cursor: pointer;
	transition: border-color var(--transition-fast);
}

.filter-select:focus {
	border-color: var(--color-plum);
	outline: none;
}

.filter-checkboxes {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: var(--space-2) var(--space-6);
}

.filter-checkboxes label {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	min-height: var(--touch-target);
	cursor: pointer;
	font-size: var(--text-sm);
}

.filter-reset {
	min-height: var(--touch-target);
	padding: var(--space-2) var(--space-4);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	color: var(--color-action);
	border: 2px solid var(--color-action);
	border-radius: var(--radius-md);
	background: transparent;
	align-self: flex-end;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.filter-reset:hover,
.filter-reset:focus {
	background-color: var(--color-action);
	color: #fff;
}

.filter-results-count {
	font-size: var(--text-sm);
	color: var(--color-body-text);
	margin-bottom: var(--space-4);
}

/* Hidden card (filtered out) */
.hotel-card[hidden],
.product-card[hidden] {
	display: none;
}

/* ============================================================
   HOTEL DETAIL MODAL
   ============================================================ */

.hotel-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 400;
	align-items: center;
	justify-content: center;
}

.hotel-modal.is-open {
	display: flex;
}

.hotel-modal__backdrop {
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.6);
}

.hotel-modal__panel {
	position: relative;
	z-index: 401;
	background-color: #fff;
	border-radius: var(--radius-lg);
	width: min(900px, 95vw);
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: var(--shadow-lg);
}

.hotel-modal__close {
	position: sticky;
	top: var(--space-4);
	float: right;
	margin: var(--space-4);
	width: var(--touch-target);
	height: var(--touch-target);
	background-color: var(--color-blush);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--text-xl);
	color: var(--color-slate-navy);
	transition: background-color var(--transition-fast);
}

.hotel-modal__close:hover,
.hotel-modal__close:focus {
	background-color: var(--color-plum);
	color: #fff;
}

.hotel-modal__content {
	padding: var(--space-8);
	clear: both;
}

.hotel-modal__loading {
	text-align: center;
	padding: var(--space-16);
	color: var(--color-body-text);
}

/* Hide modal on mobile */
@media (max-width: 767px) {
	.hotel-modal {
		display: none !important;
	}
}

/* ============================================================
   HOTEL DETAIL PAGE
   ============================================================ */

.hotel-hero-image {
	max-height: 480px;
	overflow: hidden;
}

.hotel-hero-image img {
	width: 100%;
	height: 480px;
	object-fit: cover;
}

.hotel-detail__header {
	margin-bottom: var(--space-6);
}

.hotel-detail__name {
	margin-bottom: var(--space-3);
}

.hotel-detail__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.hotel-detail__writeup,
.hotel-detail__amenities,
.hotel-detail__videos,
.hotel-detail__gallery,
.hotel-detail__cta {
	margin-bottom: var(--space-8);
}

.amenity-list {
	list-style: disc;
	padding-left: var(--space-6);
}

.amenity-list li {
	margin-bottom: var(--space-2);
}

.photo-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: var(--space-4);
}

.photo-gallery img {
	border-radius: var(--radius-sm);
	aspect-ratio: 3/2;
	object-fit: cover;
}

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

.breadcrumb a {
	font-weight: var(--font-weight-bold);
	color: var(--color-plum);
}

/* YouTube oEmbed responsive wrapper */
.hotel-detail__videos iframe {
	aspect-ratio: 16 / 9;
	width: 100%;
	height: auto;
	border: 0;
	border-radius: var(--radius-sm);
	margin-bottom: var(--space-4);
}

/* "Plan with us" CTA block */
.hotel-detail__cta {
	background-color: var(--color-blush);
	border-radius: var(--radius-md);
	padding: var(--space-8);
	text-align: center;
}

.hotel-detail__cta h2,
.hotel-detail__cta h3 {
	color: var(--color-plum);
	margin-bottom: var(--space-2);
}

.hotel-detail__cta p {
	margin-bottom: var(--space-4);
}

/* Instagram link */
.hotel-detail__instagram a {
	font-weight: var(--font-weight-bold);
	color: var(--color-plum);
}

/* body scroll lock when modal is open */
body.modal-open {
	overflow: hidden;
}

/* ============================================================
   GATED RESOURCE (R4)
   ============================================================ */

.resource-type-badge {
	display: inline-block;
	padding: var(--space-1) var(--space-3);
	border-radius: var(--radius-full);
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--space-3);
}

.resource-type-badge--article  { background-color: var(--color-blue);  color: #fff; }
.resource-type-badge--video    { background-color: var(--color-coral); color: #fff; }
.resource-type-badge--link     { background-color: var(--color-plum);  color: #fff; }
.resource-type-badge--download { background-color: var(--color-gold);  color: var(--color-slate-navy); }

/* ============================================================
   CLIENT LIBRARY PAGE (R4)
   ============================================================ */

.library-header {
	margin-bottom: var(--space-8);
}

/* Resource grid */
.resource-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	margin-top: var(--space-6);
}

@media (min-width: 768px) {
	.resource-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1200px) {
	.resource-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Resource card */
.card-resource {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid rgba(62, 75, 109, 0.15);
	border-radius: var(--radius-md);
	box-shadow: 0 2px 8px rgba(62, 75, 109, 0.08);
	overflow: hidden;
	transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.card-resource:hover {
	box-shadow: 0 6px 20px rgba(62, 75, 109, 0.14);
	transform: translateY(-2px);
}

/* Card image */
.card-resource__image-wrap {
	height: 180px;
	overflow: hidden;
	flex-shrink: 0;
}

.card-resource__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Placeholder color blocks when no image — keyed to content type */
.card-resource__image-wrap--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
}

.card-resource__image-wrap--article  { background-color: var(--color-blue); }
.card-resource__image-wrap--video    { background-color: var(--color-coral); }
.card-resource__image-wrap--link     { background-color: var(--color-plum); }
.card-resource__image-wrap--download { background-color: var(--color-dark-rose); }

/* Card body */
.card-resource__body {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	padding: var(--space-5);
	gap: var(--space-3);
}

/* Meta row: badge + destination */
.card-resource__meta {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	flex-wrap: wrap;
}

.card-resource__destination {
	font-family: var(--font-heading);
	font-size: var(--text-xs);
	color: var(--color-body-text);
	opacity: 0.7;
}

/* Title */
.card-resource__title {
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-lg);
	color: var(--color-heading);
	margin: 0;
	line-height: 1.3;
}

/* Excerpt */
.card-resource__excerpt {
	font-size: var(--text-sm);
	color: var(--color-body-text);
	margin: 0;
	flex-grow: 1;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* CTA button — pushed to card bottom */
.card-resource__cta {
	align-self: flex-start;
	margin-top: auto;
}

/* Empty state */
.resource-no-results {
	text-align: center;
	color: var(--color-body-text);
	font-style: italic;
	padding: var(--space-8);
}

/* ============================================================
   RCP LOGIN / REGISTER FORM STYLES
   ============================================================ */

.rcp_form {
	max-width: 480px;
	margin: var(--space-8) auto;
	padding: var(--space-8);
	background: #fff;
	border: 1px solid rgba(62, 75, 109, 0.15);
	border-radius: var(--radius-md);
	box-shadow: 0 2px 12px rgba(62, 75, 109, 0.08);
}

.rcp_form fieldset {
	border: none;
	padding: 0;
	margin: 0;
}

.rcp_form legend,
.rcp_form h3 {
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-xl);
	color: var(--color-heading);
	margin-bottom: var(--space-6);
}

.rcp_form p {
	margin-bottom: var(--space-4);
}

.rcp_form label {
	display: block;
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-sm);
	color: var(--color-body-text);
	margin-bottom: var(--space-1);
}

.rcp_form input[type="text"],
.rcp_form input[type="email"],
.rcp_form input[type="password"] {
	width: 100%;
	padding: var(--space-3) var(--space-4);
	border: 1px solid rgba(62, 75, 109, 0.3);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-body-text);
	background: #fff;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.rcp_form input[type="text"]:focus,
.rcp_form input[type="email"]:focus,
.rcp_form input[type="password"]:focus {
	outline: none;
	border-color: var(--color-plum);
	box-shadow: 0 0 0 3px rgba(158, 64, 140, 0.15);
}

.rcp_form input[type="submit"],
.rcp_form .rcp_submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: var(--touch-target);
	padding: var(--space-3) var(--space-6);
	background-color: var(--color-action);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: var(--font-weight-bold);
	font-size: var(--text-base);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background-color var(--transition-fast);
	width: 100%;
	margin-top: var(--space-4);
}

.rcp_form input[type="submit"]:hover,
.rcp_form .rcp_submit:hover {
	background-color: var(--color-dark-rose);
}

.rcp_errors,
.rcp_success {
	padding: var(--space-3) var(--space-4);
	border-radius: var(--radius-sm);
	font-size: var(--text-sm);
	margin-bottom: var(--space-4);
}

.rcp_errors {
	background-color: rgba(225, 71, 87, 0.1);
	border: 1px solid rgba(225, 71, 87, 0.3);
	color: var(--color-red);
}

.rcp_success {
	background-color: rgba(53, 72, 156, 0.1);
	border: 1px solid rgba(53, 72, 156, 0.3);
	color: var(--color-blue);
}

/* ============================================================
   SITE FOOTER
   ============================================================ */

.site-footer {
	margin-top: auto;
}

.site-footer__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	padding-block: var(--space-12);
}

@media (min-width: 768px) {
	.site-footer__inner {
		grid-template-columns: 2fr 1fr 1fr;
		align-items: start;
	}
}

.site-footer__logo {
	margin-bottom: var(--space-3);
}

.site-footer__tagline {
	font-family: var(--font-accent);
	font-size: var(--text-lg);
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}

.footer-nav-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.footer-nav-list a {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--text-sm);
	transition: color var(--transition-fast);
}

.footer-nav-list a:hover,
.footer-nav-list a:focus {
	color: #fff;
}

.site-footer__social {
	display: flex;
	gap: var(--space-4);
	align-items: center;
}

.social-icon img {
	filter: brightness(0) invert(1);
	opacity: 0.8;
	transition: opacity var(--transition-fast);
}

.social-icon:hover img,
.social-icon:focus img {
	opacity: 1;
}

.site-footer__legal {
	grid-column: 1 / -1;
	padding-top: var(--space-6);
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-4);
	justify-content: space-between;
}

.site-footer__legal p {
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.6);
	margin: 0;
}

.site-footer__legal a {
	color: rgba(255, 255, 255, 0.8);
}

.site-footer__legal a:hover {
	color: #fff;
}

/* ============================================================
   CONTACT CTA SECTION (homepage)
   ============================================================ */

.section--contact-cta {
	text-align: center;
}

.section--contact-cta .section-intro {
	color: rgba(255, 255, 255, 0.9);
	max-width: 560px;
	margin: var(--space-4) auto var(--space-8);
}

/* ============================================================
   PLACEHOLDER NOTICE
   ============================================================ */

.placeholder-notice {
	color: var(--color-body-text);
	font-style: italic;
	padding: var(--space-8);
	text-align: center;
	background-color: var(--color-blush);
	border-radius: var(--radius-md);
}

/* ============================================================
   WORDPRESS ALIGNMENT CLASSES
   ============================================================ */

.alignleft  { float: left;  margin-right: var(--space-6); margin-bottom: var(--space-4); }
.alignright { float: right; margin-left:  var(--space-6); margin-bottom: var(--space-4); }
.aligncenter { display: block; margin-inline: auto; }
.alignwide  { width: 100%; }
.alignfull  { width: 100vw; margin-left: calc(50% - 50vw); }

/* ============================================================
   PRINT
   ============================================================ */

@media print {
	.site-header,
	.site-footer,
	.nav-primary,
	.mobile-drawer,
	.hotel-modal,
	.filter-bar,
	.btn-client-area,
	.hamburger { display: none !important; }
}
