/* =========================================================
   eSupport Tour Destinations — frontend styles (v1.1)
   Theme: red #EA3A22 · Poppins · soft shadows · rounded cards
   --esup-primary / --esup-primary-dark / --esup-radius are
   injected from the backend settings.
   ========================================================= */

:root {
	--esup-primary: #EA3A22;
	--esup-primary-dark: #c12c17;
	--esup-radius: 16px;
	--esup-ink: #34373d;
	--esup-ink-soft: #54585f;
	--esup-muted: #8a8f96;
	--esup-line: #ececec;
	--esup-bg-soft: #faf7f6;
	--esup-shadow: 0 18px 50px -18px rgba(40, 30, 28, .22);
	--esup-shadow-sm: 0 8px 24px -12px rgba(40, 30, 28, .18);
	--esup-maxw: 1180px;
	--esup-ease: cubic-bezier(.21, .61, .35, 1);
}

.esup-single,
.esup-archive,
.esup-grid-wrap,
.esup-booking,
.esup-card {
	font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	color: var(--esup-ink);
	box-sizing: border-box;
	-webkit-font-smoothing: antialiased;
}
.esup-single *,
.esup-grid-wrap *,
.esup-booking * { box-sizing: border-box; }

/* ---------------- Hero ---------------- */
.esup-hero {
	position: relative;
	min-height: 460px;
	display: flex;
	align-items: flex-end;
	background: linear-gradient(135deg, #2b1a13, #7c2516);
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.esup-hero__inner {
	position: relative;
	z-index: 2;
	max-width: var(--esup-maxw);
	width: 100%;
	margin: 0 auto;
	padding: 0 28px 52px;
}
.esup-hero__title {
	color: #fff !important;
	font-size: clamp(36px, 5.6vw, 60px);
	font-weight: 700;
	letter-spacing: -.6px;
	line-height: 1.03;
	margin: 0;
	text-shadow: 0 2px 24px rgba(0, 0, 0, .5);
}
.esup-hero__title::before {
	content: "";
	display: block;
	width: 56px;
	height: 4px;
	border-radius: 4px;
	background: var(--esup-primary);
	margin-bottom: 20px;
}
.esup-hero__subtitle {
	color: rgba(255, 255, 255, .95) !important;
	font-size: clamp(15px, 1.5vw, 18px);
	font-weight: 400;
	line-height: 1.7;
	max-width: 620px;
	margin: 16px 0 0;
	text-shadow: 0 1px 14px rgba(0, 0, 0, .55);
}

/* ---------------- Single layout ---------------- */
.esup-single__layout {
	max-width: var(--esup-maxw);
	margin: 0 auto;
	padding: 48px 28px 16px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 372px;
	gap: 48px;
	align-items: start;
}
.esup-section-title {
	color: var(--esup-primary);
	font-size: clamp(24px, 3.4vw, 34px);
	font-weight: 700;
	letter-spacing: -.4px;
	margin: 0 0 6px;
}
.esup-section-title::after {   /* short underline accent */
	content: "";
	display: block;
	width: 56px;
	height: 4px;
	border-radius: 4px;
	background: var(--esup-primary);
	margin-top: 12px;
	opacity: .9;
}
.esup-location {
	color: var(--esup-muted);
	font-size: 14px;
	font-weight: 500;
	margin: 14px 0 18px;
}
.esup-intro,
.esup-extra {
	color: var(--esup-ink-soft);
	font-size: 15.5px;
	line-height: 1.95;
}
.esup-intro p,
.esup-extra p { margin: 0 0 1.1em; }
.esup-extra { margin-top: 30px; }

/* ---------------- Galleries ---------------- */
.esup-gallery {
	display: grid;
	gap: 18px;
	margin: 30px 0;
}
.esup-gallery--two { grid-template-columns: repeat(2, 1fr); }
.esup-gallery--grid { grid-template-columns: repeat(3, 1fr); }
.esup-gallery__item {
	display: block;
	border-radius: var(--esup-radius);
	overflow: hidden;
	box-shadow: var(--esup-shadow-sm);
	aspect-ratio: 4 / 3;
	transition: transform .45s var(--esup-ease), box-shadow .45s var(--esup-ease);
}
.esup-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .6s var(--esup-ease);
}
.esup-gallery__item:hover {
	transform: translateY(-5px);
	box-shadow: var(--esup-shadow);
}
.esup-gallery__item:hover img { transform: scale(1.05); }

/* ---------------- Booking card ---------------- */
.esup-booking {
	position: sticky;
	top: 24px;
	padding: 30px 28px 28px;
	border-radius: 20px;
	border: 1px solid #efe7e5;
	background-color: #fff;
	/* faint geometric watermark, like the reference */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48'%3E%3Cg fill='none' stroke='%23f4e3df' stroke-width='1'%3E%3Cpath d='M0 48 48 0M-12 12 12 -12M36 60 60 36'/%3E%3Cpath d='M0 0 48 48M-12 36 12 60M36 -12 60 12'/%3E%3C/g%3E%3C/svg%3E");
	box-shadow: var(--esup-shadow);
}
.esup-booking__title {
	color: var(--esup-primary);
	font-size: 24px;
	font-weight: 700;
	letter-spacing: -.3px;
	text-align: center;
	margin: 0 0 22px;
}
.esup-field { display: block; margin-bottom: 15px; }
.esup-field > span {
	display: block;
	font-size: 12.5px;
	font-weight: 500;
	color: var(--esup-muted);
	margin-bottom: 6px;
}
.esup-field input,
.esup-field select {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid #e6dedc;
	border-radius: 11px;
	font-family: inherit;
	font-size: 14px;
	color: var(--esup-ink);
	background: rgba(255, 255, 255, .85);
	transition: border-color .2s, box-shadow .2s, background .2s;
	appearance: none;
}
.esup-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%23999' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 34px;
}
.esup-field input::placeholder { color: #b7bcc2; }
.esup-field input:focus,
.esup-field select:focus {
	outline: none;
	border-color: var(--esup-primary);
	box-shadow: 0 0 0 3px rgba(234, 58, 34, .14);
	background: #fff;
}
.esup-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	width: 100%;
	background: var(--esup-primary);
	color: #fff;
	border: 0;
	border-radius: 12px;
	padding: 15px 18px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	cursor: pointer;
	margin-top: 10px;
	box-shadow: 0 12px 26px -10px rgba(234, 58, 34, .65);
	transition: background .2s, transform .12s var(--esup-ease), box-shadow .2s;
}
.esup-btn::after {
	content: "";
	width: 7px; height: 7px;
	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform .2s var(--esup-ease);
}
.esup-btn:hover {
	background: var(--esup-primary-dark);
	transform: translateY(-2px);
	box-shadow: 0 16px 30px -10px rgba(234, 58, 34, .7);
}
.esup-btn:hover::after { transform: rotate(45deg) translate(2px, -2px); }
.esup-btn:active { transform: translateY(0); }
.esup-booking__error {
	color: var(--esup-primary);
	font-size: 13px;
	text-align: center;
	margin: 12px 0 0;
}

/* ---------------- Back link ---------------- */
.esup-back-wrap {
	max-width: var(--esup-maxw);
	margin: 0 auto;
	padding: 8px 28px 56px;
}
.esup-back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--esup-primary);
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	transition: gap .2s var(--esup-ease);
}
.esup-back:hover { gap: 11px; }

/* ---------------- Grid ---------------- */
.esup-grid-wrap {
	max-width: var(--esup-maxw);
	margin: 0 auto;
	padding: 56px 28px;
}
.esup-grid-heading {
	color: var(--esup-primary);
	font-size: clamp(26px, 4vw, 38px);
	font-weight: 700;
	letter-spacing: -.5px;
	text-align: center;
	margin: 0 0 8px;
}
.esup-grid-heading + .esup-grid { margin-top: 40px; }
.esup-grid-wrap > .esup-grid-heading::after {
	content: "";
	display: block;
	width: 64px; height: 4px;
	border-radius: 4px;
	background: var(--esup-primary);
	margin: 14px auto 0;
}
.esup-grid { display: grid; gap: 30px; }
.esup-grid--2 { grid-template-columns: repeat(2, 1fr); }
.esup-grid--3 { grid-template-columns: repeat(3, 1fr); }
.esup-grid--4 { grid-template-columns: repeat(4, 1fr); }

.esup-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid #f0eae8;
	border-radius: var(--esup-radius);
	overflow: hidden;
	box-shadow: var(--esup-shadow-sm);
	text-decoration: none;
	color: inherit;
	transition: transform .4s var(--esup-ease), box-shadow .4s var(--esup-ease);
}
.esup-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--esup-shadow);
}
.esup-card__media {
	position: relative;
	aspect-ratio: 16 / 11;
	background: #eef1f3;
	overflow: hidden;
}
.esup-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .6s var(--esup-ease);
}
.esup-card:hover .esup-card__media img { transform: scale(1.07); }
.esup-card__media::after {     /* gentle bottom gradient for the pin */
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	height: 45%;
	background: linear-gradient(to top, rgba(0, 0, 0, .28), transparent);
	opacity: 0;
	transition: opacity .4s var(--esup-ease);
}
.esup-card:hover .esup-card__media::after { opacity: 1; }
.esup-card__placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 42px;
}
.esup-card__pin {
	position: absolute;
	left: 14px;
	bottom: 14px;
	z-index: 2;
	background: rgba(255, 255, 255, .94);
	color: var(--esup-primary);
	font-size: 11.5px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	box-shadow: var(--esup-shadow-sm);
}
.esup-card__body {
	padding: 18px 20px 20px;
	text-align: center;
}
.esup-card__subtitle {
	font-size: 11.5px;
	font-weight: 600;
	letter-spacing: .8px;
	text-transform: uppercase;
	color: var(--esup-primary);
	margin: 0;
	order: -1;
}
.esup-card__title {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: -.3px;
	margin: 0;
	color: var(--esup-ink);
}
.esup-card__excerpt {
	font-size: 13.5px;
	line-height: 1.65;
	color: var(--esup-muted);
	margin: 2px 0 0;
}
.esup-card__more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: auto;
	padding-top: 14px;
	font-size: 13px;
	font-weight: 600;
	color: var(--esup-primary);
	transition: gap .2s var(--esup-ease);
}
.esup-card:hover .esup-card__more { gap: 11px; }
.esup-empty {
	text-align: center;
	color: var(--esup-muted);
	padding: 48px 0;
}

/* ---------------- Lightbox ---------------- */
.esup-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(20, 14, 12, .88);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 99999;
	opacity: 0;
	pointer-events: none;
	transition: opacity .25s var(--esup-ease);
	padding: 4vw;
}
.esup-lightbox.is-open { opacity: 1; pointer-events: auto; }
.esup-lightbox img {
	max-width: 100%;
	max-height: 90vh;
	border-radius: 12px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, .6);
}
.esup-lightbox__close {
	position: absolute;
	top: 18px; right: 26px;
	color: #fff;
	font-size: 36px;
	background: none;
	border: 0;
	cursor: pointer;
	line-height: 1;
}

/* ---------------- Standalone form ---------------- */
.esup-booking-standalone { max-width: 480px; margin: 28px auto; }
.esup-booking-standalone .esup-booking { position: static; }

/* ---------------- Responsive ---------------- */
@media (max-width: 1000px) {
	.esup-single__layout { grid-template-columns: 1fr; gap: 36px; }
	.esup-booking { position: static; max-width: 560px; }
	.esup-grid--3, .esup-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
	.esup-gallery--two,
	.esup-gallery--grid,
	.esup-grid--2,
	.esup-grid--3,
	.esup-grid--4 { grid-template-columns: 1fr; }
	.esup-hero { min-height: 260px; }
	.esup-single__layout { padding: 34px 20px 8px; }
}
