/**
 * Lopeix Travel — frontend do site (grid, cards, filtro, formulário, single).
 *
 * Sistema de design próprio (prefixo .lopeix-) — moderno, responsivo, elegante.
 * Não depende do tema (Travel Monster) nem do Elementor.
 *
 * @package Lopeix_Travel
 */

/* ====================================================================
   1. Tokens
   ==================================================================== */
.lopeix-travel,
.lopeix-single,
.lopeix-details,
.lopeix-quote-form {
	--lx-ocean: #0c4a5a;
	--lx-deep: #08323e;
	--lx-teal: #1f8fad;
	--lx-teal-dark: #166f88;
	--lx-aqua: #e8f5f7;
	--lx-aqua-2: #d3ecf0;
	--lx-sand: #d8a24a;
	--lx-sand-dark: #b9842f;
	--lx-ink: #16282e;
	--lx-muted: #5f7178;
	--lx-line: #e2ecef;
	--lx-bg: #ffffff;
	--lx-soft: #f5fafb;
	--lx-danger: #c0392b;
	--lx-success: #1f7a52;
	--lx-r: 18px;
	--lx-r-sm: 12px;
	--lx-r-pill: 999px;
	--lx-gap: 1.6rem;
	--lx-cols: 3;
	--lx-shadow: 0 2px 6px rgba(8, 50, 62, .05), 0 18px 40px -18px rgba(8, 50, 62, .25);
	--lx-shadow-lg: 0 8px 18px rgba(8, 50, 62, .1), 0 34px 60px -24px rgba(8, 50, 62, .4);
	--lx-font: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--lx-ease: cubic-bezier(.22, 1, .36, 1);
	color: var(--lx-ink);
	font-family: var(--lx-font);
}

.lopeix-travel,
.lopeix-travel *,
.lopeix-travel *::before,
.lopeix-travel *::after,
.lopeix-single,
.lopeix-single *,
.lopeix-single *::before,
.lopeix-single *::after,
.lopeix-quote-form,
.lopeix-quote-form *,
.lopeix-quote-form *::before,
.lopeix-quote-form *::after {
	box-sizing: border-box;
}

.lopeix-travel {
	max-width: 1220px;
	margin-inline: auto;
	padding-inline: 1rem;
	font-size: 16px;
	line-height: 1.6;
}

/* ====================================================================
   2. Botões
   ==================================================================== */
.lopeix-button,
.lopeix-card__cta,
.lopeix-filter__submit {
	--btn-bg: linear-gradient(135deg, var(--lx-teal), var(--lx-ocean));
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	padding: .85rem 1.6rem;
	font: inherit;
	font-weight: 600;
	line-height: 1.1;
	color: #fff;
	text-decoration: none;
	background: var(--btn-bg);
	border: 0;
	border-radius: var(--lx-r-pill);
	cursor: pointer;
	box-shadow: 0 10px 24px -10px rgba(12, 74, 90, .8);
	transition: transform .25s var(--lx-ease), box-shadow .25s var(--lx-ease), filter .25s var(--lx-ease);
}

.lopeix-button:hover,
.lopeix-card__cta:hover,
.lopeix-filter__submit:hover,
.lopeix-button:focus-visible,
.lopeix-card__cta:focus-visible,
.lopeix-filter__submit:focus-visible {
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 16px 30px -12px rgba(12, 74, 90, .9);
	filter: saturate(1.08);
}

.lopeix-button--ghost {
	background: transparent;
	color: #fff;
	border: 1.5px solid rgba(255, 255, 255, .65);
	box-shadow: none;
}

.lopeix-button--ghost:hover,
.lopeix-button--ghost:focus-visible {
	color: var(--lx-ocean);
	background: #fff;
	border-color: #fff;
}

.lopeix-button--small {
	padding: .6rem 1.1rem;
	font-size: .85rem;
}

:where(.lopeix-travel, .lopeix-single) a:focus-visible,
.lopeix-quote-form :focus-visible {
	outline: 2px solid var(--lx-teal);
	outline-offset: 3px;
}

/* ====================================================================
   3. Animações (reveal no scroll + hero)
   ==================================================================== */
@media (prefers-reduced-motion: no-preference) {
	@supports (animation-timeline: view()) {
		.lopeix-card,
		.lopeix-section,
		.lopeix-schedule-card,
		.lopeix-gallery-group,
		.lopeix-info-grid__item {
			animation: lx-reveal both linear;
			animation-timeline: view();
			animation-range: entry 0% cover 22%;
		}
	}

	@keyframes lx-reveal {
		from { opacity: 0; transform: translateY(26px); }
		to   { opacity: 1; transform: translateY(0); }
	}
}

/* ====================================================================
   4. Filtro
   ==================================================================== */
.lopeix-filter {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem 1.1rem;
	margin: 0 0 2rem;
	padding: 1.4rem 1.5rem;
	background: var(--lx-bg);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow);
}

.lopeix-filter__header {
	grid-column: 1 / -1;
	display: flex;
	align-items: center;
	gap: .6rem;
}

.lopeix-filter__header h3 {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 700;
	letter-spacing: -.01em;
	color: var(--lx-ocean);
}

.lopeix-filter__header::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, var(--lx-line), transparent);
}

.lopeix-filter__group { display: flex; flex-direction: column; gap: .4rem; min-width: 0; }

.lopeix-filter__label {
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: var(--lx-muted);
}

.lopeix-filter__control {
	width: 100%;
	min-height: 46px;
	padding: .6rem .85rem;
	font: inherit;
	color: var(--lx-ink);
	background-color: var(--lx-soft);
	border: 1.5px solid var(--lx-line);
	border-radius: var(--lx-r-sm);
	transition: border-color .2s var(--lx-ease), box-shadow .2s var(--lx-ease), background-color .2s var(--lx-ease);
}

select.lopeix-filter__control {
	appearance: none;
	padding-right: 2.4rem;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23166f88' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right .85rem center;
}

.lopeix-filter__control:hover { border-color: #bcd6dd; background-color: #fff; }

.lopeix-filter__control:focus,
.lopeix-filter__control:focus-visible {
	outline: none;
	background-color: #fff;
	border-color: var(--lx-teal);
	box-shadow: 0 0 0 4px rgba(31, 143, 173, .15);
}

.lopeix-filter__range { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: .5rem; }
.lopeix-filter__range-sep { color: var(--lx-muted); }

.lopeix-filter__actions { display: flex; flex-wrap: wrap; gap: .6rem; align-items: end; }

.lopeix-filter__reset {
	min-height: 46px;
	padding: .6rem 1.2rem;
	font: inherit;
	font-weight: 600;
	color: var(--lx-teal-dark);
	background: #fff;
	border: 1.5px solid var(--lx-line);
	border-radius: var(--lx-r-pill);
	cursor: pointer;
	transition: border-color .2s var(--lx-ease), background-color .2s var(--lx-ease);
}

.lopeix-filter__reset:hover,
.lopeix-filter__reset:focus-visible { border-color: var(--lx-teal); background: var(--lx-soft); }

@media (min-width: 700px) {
	.lopeix-filter { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1040px) {
	.lopeix-filter { grid-template-columns: 1.1fr 1.1fr 1.1fr 1fr 1.1fr auto; align-items: end; }
}

/* ====================================================================
   5. Grid de resultados
   ==================================================================== */
.lopeix-results {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lx-gap);
	min-height: 4rem;
}

@media (min-width: 600px) { .lopeix-results { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .lopeix-results { grid-template-columns: repeat(var(--lx-cols), minmax(0, 1fr)); } }

.lopeix-results.is-loading { opacity: .5; pointer-events: none; }
.lopeix-results.is-loading::after {
	content: "";
	position: absolute;
	top: 2rem;
	left: 50%;
	width: 2.4rem;
	height: 2.4rem;
	margin-left: -1.2rem;
	border: 3px solid var(--lx-aqua-2);
	border-top-color: var(--lx-teal);
	border-radius: 50%;
	animation: lx-spin .8s linear infinite;
}
@keyframes lx-spin { to { transform: rotate(360deg); } }

.lopeix-results__empty {
	grid-column: 1 / -1;
	margin: 0;
	padding: 3rem 1rem;
	text-align: center;
	color: var(--lx-muted);
	background: var(--lx-soft);
	border: 1px dashed var(--lx-line);
	border-radius: var(--lx-r);
}

/* ====================================================================
   6. Card
   ==================================================================== */
.lopeix-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	overflow: hidden;
	background: var(--lx-bg);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow);
	transition: transform .35s var(--lx-ease), box-shadow .35s var(--lx-ease);
}

.lopeix-card:hover,
.lopeix-card:focus-within { transform: translateY(-6px); box-shadow: var(--lx-shadow-lg); }

.lopeix-card__media {
	position: relative;
	aspect-ratio: 3 / 2;
	overflow: hidden;
	background: var(--lx-aqua);
}

.lopeix-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(8, 50, 62, .42));
	opacity: .85;
	transition: opacity .35s var(--lx-ease);
}

.lopeix-card:hover .lopeix-card__media::after { opacity: 1; }

.lopeix-card__media a, .lopeix-card__media img { display: block; width: 100%; height: 100%; }
.lopeix-card__media img { object-fit: cover; transition: transform .7s var(--lx-ease); }
.lopeix-card:hover .lopeix-card__media img { transform: scale(1.07); }

.lopeix-card__media--placeholder { display: grid; place-items: center; font-size: 2.6rem; color: var(--lx-teal); background: linear-gradient(135deg, var(--lx-aqua), var(--lx-aqua-2)); }
.lopeix-card__media--placeholder::after { display: none; }

.lopeix-card__body {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	flex: 1 1 auto;
	padding: 1.25rem 1.3rem 1.4rem;
}

.lopeix-card__title { margin: 0; font-size: 1.22rem; line-height: 1.25; font-weight: 700; letter-spacing: -.015em; }
.lopeix-card__title a { color: var(--lx-ink); text-decoration: none; background-image: linear-gradient(var(--lx-teal), var(--lx-teal)); background-size: 0% 2px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .3s var(--lx-ease), color .2s var(--lx-ease); }
.lopeix-card__title a:hover { color: var(--lx-teal-dark); background-size: 100% 2px; }

.lopeix-card__subtitle { margin: 0; font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--lx-teal); }

.lopeix-card__excerpt { margin: 0; font-size: .94rem; color: var(--lx-muted); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

.lopeix-card__price { margin: .35rem 0 0; font-size: 1.2rem; font-weight: 800; color: var(--lx-ocean); }
.lopeix-card__price span { display: block; font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--lx-muted); }

.lopeix-card__cta { margin-top: auto; align-self: flex-start; }
.lopeix-card__cta::after { content: "\2192"; font-weight: 600; transition: transform .25s var(--lx-ease); }
.lopeix-card__cta:hover::after { transform: translateX(4px); }

/* ====================================================================
   7. Paginação
   ==================================================================== */
.lopeix-pagination { display: flex; justify-content: center; margin: 2.4rem 0 .5rem; }
.lopeix-pagination__list { display: flex; flex-wrap: wrap; gap: .4rem; margin: 0; padding: 0; list-style: none; }
.lopeix-pagination__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.7rem;
	padding: .55rem .85rem;
	font-weight: 700;
	text-decoration: none;
	color: var(--lx-teal-dark);
	background: var(--lx-bg);
	border: 1.5px solid var(--lx-line);
	border-radius: var(--lx-r-pill);
	cursor: pointer;
	transition: all .2s var(--lx-ease);
}
.lopeix-pagination__link:hover,
.lopeix-pagination__link:focus-visible { border-color: var(--lx-teal); background: var(--lx-soft); transform: translateY(-1px); }
.lopeix-pagination__link.is-current { color: #fff; background: linear-gradient(135deg, var(--lx-teal), var(--lx-ocean)); border-color: transparent; cursor: default; }
.lopeix-pagination__link[aria-disabled="true"] { opacity: .45; pointer-events: none; }

/* ====================================================================
   8. Single — wrapper e hero
   ==================================================================== */
body.single-lopeix_viagem .entry-header > .entry-title,
body.single-lopeix_viagem h1.entry-title,
body.single-lopeix_viagem .page-header > .page-title,
body.single-lopeix_viagem h1.page-title,
body.single-lopeix_viagem .wp-block-post-title {
	display: none !important;
}

.lopeix-single {
	width: 100vw;
	max-width: 100vw;
	margin: -50px calc(50% - 50vw) 3rem;
	padding-inline: clamp(1rem, 2.5vw, 2rem);
	font-size: 16px;
	line-height: 1.65;
}

.lopeix-single {
	width: 100dvw;
	max-width: 100dvw;
	margin-inline: calc(50% - 50dvw);
}

.lopeix-single-hero {
	position: relative;
	overflow: hidden;
	min-height: clamp(340px, 52vh, 560px);
	display: flex;
	align-items: flex-end;
	padding: clamp(1.5rem, 4vw, 3.5rem);
	color: #fff;
	background: linear-gradient(135deg, var(--lx-ocean), var(--lx-deep));
	margin-inline: calc(50% - 50dvw);
	width: 100dvw;
}

.lopeix-single-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transform: scale(1.04);
	z-index: 0;
}

@media (prefers-reduced-motion: no-preference) {
	.lopeix-single-hero.has-image .lopeix-single-hero__bg { animation: lx-kenburns 18s ease-in-out infinite alternate; }
	@keyframes lx-kenburns { from { transform: scale(1.04); } to { transform: scale(1.13); } }
}

.lopeix-single-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(0deg, rgba(8, 50, 62, .82) 8%, rgba(8, 50, 62, .35) 55%, rgba(8, 50, 62, .15));
}

.lopeix-single-hero__content {
	position: relative;
	z-index: 2;
	max-width: 720px;
	margin-inline: auto;
	width: calc(100% - 2rem);
	max-width: 1220px;
	padding-inline: 1rem;
}

.lopeix-single-hero__type {
	display: inline-block;
	margin-bottom: 1rem;
	padding: .35rem .9rem;
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--lx-deep);
	background: rgba(255, 255, 255, .92);
	border-radius: var(--lx-r-pill);
}

.lopeix-single-hero h1 { margin: 0; font-size: clamp(1.9rem, 4.5vw, 3.2rem); line-height: 1.05; font-weight: 800; letter-spacing: -.02em; text-shadow: 0 2px 18px rgba(0, 0, 0, .25); }

.lopeix-single-hero__description { margin: 1rem 0 0; font-size: clamp(1rem, 1.4vw, 1.18rem); color: rgba(255, 255, 255, .92); max-width: 60ch; }

.lopeix-single-hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.8rem; }

/* ====================================================================
   9. Single — seções
   ==================================================================== */
.lopeix-section {
	margin-top: clamp(2.4rem, 5vw, 4rem);
	margin-inline: auto;
	max-width: 1220px;
	padding-inline: 1rem;
	width: calc(100% - 2rem);
}

.lopeix-section__head { margin-bottom: 1.6rem; }
.lopeix-section__head > span {
	display: inline-block;
	margin-bottom: .5rem;
	font-size: .74rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .14em;
	color: var(--lx-teal);
}
.lopeix-section__head h3 { margin: 0; font-size: clamp(1.5rem, 3vw, 2.05rem); font-weight: 800; letter-spacing: -.02em; color: var(--lx-ocean); }
.lopeix-section__head p { margin: .6rem 0 0; color: var(--lx-muted); max-width: 60ch; }
.lopeix-section__head--center { text-align: center; }
.lopeix-section__head--center p { margin-inline: auto; }

.lopeix-single-copy {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.2rem;
	margin-top: 1.4rem;
}

@media (min-width: 760px) {
	.lopeix-single-copy { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.lopeix-single-copy__block {
	padding: 1.4rem 1.5rem;
	background: var(--lx-soft);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r);
}

.lopeix-single-copy__block--wide { grid-column: 1 / -1; }
.lopeix-single-copy__block h4 { margin: 0 0 .8rem; font-size: 1.05rem; color: var(--lx-ocean); }
.lopeix-single-copy__block p { margin: 0; color: var(--lx-muted); }
.lopeix-single-content { color: var(--lx-ink); }
.lopeix-single-content > :first-child { margin-top: 0; }
.lopeix-single-content > :last-child { margin-bottom: 0; }
.lopeix-single-content a { color: var(--lx-teal-dark); font-weight: 700; }

/* Calendário / agenda */
.lopeix-schedule-public {
	display: grid;
	gap: 1.4rem;
}

.lopeix-schedule-card {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.4rem;
	padding: 1.5rem;
	background: var(--lx-bg);
	border: 1px solid var(--lx-line);
	border-left: 4px solid var(--lx-teal);
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow);
	position: relative;
}
.lopeix-schedule-card.is-esgotado { border-left-color: var(--lx-danger); opacity: .92; }
.lopeix-schedule-card.is-confirmada { border-left-color: var(--lx-success); }
.lopeix-schedule-card__summary { min-width: 0; }
.lopeix-schedule-card__status {
	display: inline-block;
	padding: .25rem .75rem;
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--lx-teal-dark);
	background: var(--lx-aqua);
	border-radius: var(--lx-r-pill);
}
.lopeix-schedule-card.is-esgotado .lopeix-schedule-card__status { color: var(--lx-danger); background: #fbeae8; }
.lopeix-schedule-card__summary h4 { margin: .7rem 0 0; font-size: 1.3rem; font-weight: 700; color: var(--lx-ink); }
.lopeix-schedule-card__dates { display: flex; flex-wrap: wrap; gap: 1.2rem; margin: 1rem 0; }
.lopeix-schedule-card__dates > div { display: flex; flex-direction: column; }
.lopeix-schedule-card__dates span { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--lx-muted); }
.lopeix-schedule-card__dates strong { font-size: 1.05rem; color: var(--lx-ocean); }
.lopeix-schedule-card__meta { display: flex; flex-wrap: wrap; gap: .5rem; margin: 0 0 1rem; padding: 0; list-style: none; }
.lopeix-schedule-card__meta li { padding: .3rem .75rem; font-size: .82rem; font-weight: 600; color: var(--lx-teal-dark); background: var(--lx-aqua); border-radius: var(--lx-r-pill); }

.lopeix-schedule-card__calendar { background: var(--lx-soft); border: 1px solid var(--lx-line); border-radius: var(--lx-r-sm); padding: 1.2rem; }
.lopeix-schedule-card__calendar-head span { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--lx-muted); }
.lopeix-schedule-card__calendar-head strong { display: block; font-size: 1.05rem; color: var(--lx-ocean); margin: .15rem 0; }
.lopeix-schedule-card__calendar-head p { margin: 0 0 1rem; font-size: .85rem; color: var(--lx-muted); }

@media (min-width: 1024px) {
	.lopeix-schedule-card { grid-template-columns: 1fr 1.2fr; align-items: start; gap: 2rem; }
	.lopeix-schedule-card__calendar { position: relative; }
}

/* Calendário (markup do helper) */
.lopeix-calendar-months { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }
.lopeix-calendar h4 { margin: 0 0 .6rem; font-size: .95rem; font-weight: 700; text-transform: capitalize; color: var(--lx-ocean); text-align: center; }
.lopeix-calendar__weekdays, .lopeix-calendar__days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.lopeix-calendar__weekdays span { font-size: .68rem; font-weight: 700; color: var(--lx-muted); text-align: center; padding: .2rem 0; }
.lopeix-calendar__days span {
	display: grid;
	place-items: center;
	aspect-ratio: 1;
	font-size: .8rem;
	color: var(--lx-ink);
	border-radius: 8px;
}
.lopeix-calendar__days span.is-empty { background: none; }
.lopeix-calendar__days span.is-active { background: var(--lx-aqua-2); color: var(--lx-teal-dark); font-weight: 700; }
.lopeix-calendar__days span.is-start,
.lopeix-calendar__days span.is-end { background: linear-gradient(135deg, var(--lx-teal), var(--lx-ocean)); color: #fff; box-shadow: 0 6px 14px -6px rgba(12, 74, 90, .9); }
.lopeix-calendar-legend { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1rem; font-size: .78rem; color: var(--lx-muted); }
.lopeix-calendar-legend span { display: inline-flex; align-items: center; gap: .4rem; }
.lopeix-calendar-legend i { width: 14px; height: 14px; border-radius: 4px; background: var(--lx-aqua-2); }
.lopeix-calendar-legend i.is-edge { background: linear-gradient(135deg, var(--lx-teal), var(--lx-ocean)); }

.lopeix-empty-box { padding: 2rem; text-align: center; background: var(--lx-soft); border: 1px dashed var(--lx-line); border-radius: var(--lx-r); }
.lopeix-empty-box p { margin: 0 0 1rem; color: var(--lx-muted); }

.lopeix-calendar-extras {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.2rem;
	width: 100%;
	margin-top: 1.35rem;
}

.lopeix-calendar-extras > :only-child { grid-column: auto; }

.lopeix-pricing-public,
.lopeix-calendar-note {
	padding: 1.4rem 1.5rem;
	background: var(--lx-bg);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow);
}

.lopeix-schedule-card__summary .lopeix-pricing-public,
.lopeix-schedule-card__summary .lopeix-calendar-note {
	padding: 1rem;
	background: rgba(236, 250, 251, .55);
	box-shadow: none;
}

.lopeix-pricing-public__head { margin-bottom: 1rem; }
.lopeix-pricing-public__head span {
	display: inline-block;
	margin-bottom: .35rem;
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0;
	color: var(--lx-teal);
}
.lopeix-pricing-public__head h4,
.lopeix-calendar-note h4 { margin: 0; font-size: 1.15rem; color: var(--lx-ocean); }

.lopeix-pricing-list {
	display: grid;
	gap: 1px;
	overflow: hidden;
	background: var(--lx-line);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r-sm);
}

.lopeix-pricing-list__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 1.1rem;
	background: var(--lx-bg);
}

.lopeix-pricing-list__row div { min-width: 0; }
.lopeix-pricing-list__row strong { display: block; color: var(--lx-ocean); }
.lopeix-pricing-list__row span { display: block; margin-top: .2rem; color: var(--lx-muted); }
.lopeix-pricing-list__row b { flex: 0 0 auto; font-size: 1.08rem; color: var(--lx-teal-dark); }
.lopeix-calendar-note p { margin: .75rem 0 0; color: var(--lx-muted); }

@media (max-width: 520px) {
	.lopeix-pricing-list__row {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* Info grid + inclui/não inclui */
.lopeix-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1px; background: var(--lx-line); border: 1px solid var(--lx-line); border-radius: var(--lx-r); overflow: hidden; }
.lopeix-info-grid__item { padding: 1.1rem 1.25rem; background: var(--lx-bg); }
.lopeix-info-grid__item span { display: block; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--lx-muted); }
.lopeix-info-grid__item strong { font-size: 1.05rem; color: var(--lx-ocean); }

.lopeix-booking-info { display: grid; gap: 1.2rem; margin-top: 1.4rem; grid-template-columns: 1fr; }
@media (min-width: 760px) { .lopeix-booking-info { grid-template-columns: 1fr 1fr; } }
.lopeix-booking-info__panel { padding: 1.4rem 1.5rem; background: var(--lx-soft); border: 1px solid var(--lx-line); border-radius: var(--lx-r); }
.lopeix-booking-info__panel--wide { grid-column: 1 / -1; }
.lopeix-booking-info__panel h4 { margin: 0 0 .8rem; font-size: 1.05rem; color: var(--lx-ocean); }
.lopeix-booking-info__panel ul { margin: 0; padding: 0; list-style: none; display: grid; gap: .5rem; }
.lopeix-booking-info__panel li { position: relative; padding-left: 1.5rem; color: var(--lx-ink); }
.lopeix-booking-info__panel li::before { content: ""; position: absolute; left: 0; top: .5em; width: .6rem; height: .6rem; border-radius: 50%; background: var(--lx-teal); }
.lopeix-booking-info__panel--wide p { margin: 0; color: var(--lx-muted); }

/* CTA band */
.lopeix-cta-band {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	margin-top: clamp(2.4rem, 5vw, 4rem);
	padding: clamp(1.8rem, 4vw, 3rem);
	color: #fff;
	background: radial-gradient(120% 140% at 0% 0%, var(--lx-teal), var(--lx-ocean) 55%, var(--lx-deep));
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow-lg);
	margin-inline: auto;
	max-width: 1220px;
	width: calc(100% - 2rem);
	padding-inline: clamp(1.8rem, 4vw, 3rem);
}
.lopeix-cta-band span { font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: rgba(255, 255, 255, .8); }
.lopeix-cta-band h3 { margin: .4rem 0 .5rem; font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800; letter-spacing: -.02em; }
.lopeix-cta-band p { margin: 0; max-width: 54ch; color: rgba(255, 255, 255, .9); }

/* Galerias */
.lopeix-gallery-group + .lopeix-gallery-group { margin-top: 2rem; }
.lopeix-gallery-group h4 { margin: 0 0 1rem; font-size: 1.1rem; color: var(--lx-ocean); }
.lopeix-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: .8rem; margin: 0; padding: 0; list-style: none; }
@media (min-width: 600px) { .lopeix-gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .lopeix-gallery { grid-template-columns: repeat(4, 1fr); } }
.lopeix-gallery__item { margin: 0; aspect-ratio: 4 / 3; overflow: hidden; border-radius: var(--lx-r-sm); box-shadow: var(--lx-shadow); }
.lopeix-gallery__item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--lx-ease); }
.lopeix-gallery__item:hover img { transform: scale(1.08); }

/* Mapa */
.lopeix-details__map-embed { width: 100%; aspect-ratio: 16 / 9; border: 0; border-radius: var(--lx-r); box-shadow: var(--lx-shadow); }
.lopeix-details__map-link { display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; color: var(--lx-teal-dark); }

/* Related */
.lopeix-related-trips { display: grid; gap: var(--lx-gap); grid-template-columns: 1fr; }
@media (min-width: 600px) { .lopeix-related-trips { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .lopeix-related-trips { grid-template-columns: repeat(3, 1fr); } }

/* ====================================================================
   10. Formulário de orçamento
   ==================================================================== */
.lopeix-quote-form {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.1rem;
	margin: 1.5rem 0 0;
	padding: clamp(1.4rem, 3vw, 2.2rem);
	background: var(--lx-bg);
	border: 1px solid var(--lx-line);
	border-radius: var(--lx-r);
	box-shadow: var(--lx-shadow);
}
.lopeix-quote-form__title { grid-column: 1 / -1; margin: 0; font-size: 1.35rem; font-weight: 800; color: var(--lx-ocean); }
.lopeix-quote-form__field { display: flex; flex-direction: column; gap: .35rem; }
.lopeix-quote-form__field--full { grid-column: 1 / -1; }
.lopeix-quote-form__label { font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--lx-muted); }
.lopeix-quote-form__req { color: var(--lx-danger); }
.lopeix-quote-form__input,
.lopeix-quote-form__textarea {
	width: 100%;
	padding: .75rem .9rem;
	font: inherit;
	color: var(--lx-ink);
	background: var(--lx-soft);
	border: 1.5px solid var(--lx-line);
	border-radius: var(--lx-r-sm);
	transition: border-color .2s var(--lx-ease), box-shadow .2s var(--lx-ease), background-color .2s var(--lx-ease);
}
.lopeix-quote-form__input:focus,
.lopeix-quote-form__textarea:focus { outline: none; background: #fff; border-color: var(--lx-teal); box-shadow: 0 0 0 4px rgba(31, 143, 173, .15); }
.lopeix-quote-form__textarea { min-height: 7rem; resize: vertical; }
.lopeix-quote-form__hp { position: absolute !important; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.lopeix-quote-form__feedback { grid-column: 1 / -1; margin: 0; font-weight: 700; }
.lopeix-quote-form__feedback:empty { display: none; }
.lopeix-quote-form__feedback.is-error { color: var(--lx-danger); }
.lopeix-quote-form__feedback.is-success { color: var(--lx-success); }
.lopeix-quote-form__actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.lopeix-quote-form__submit {
	padding: .85rem 1.8rem;
	font: inherit;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(135deg, var(--lx-teal), var(--lx-ocean));
	border: 0;
	border-radius: var(--lx-r-pill);
	cursor: pointer;
	box-shadow: 0 10px 24px -10px rgba(12, 74, 90, .8);
	transition: transform .25s var(--lx-ease), box-shadow .25s var(--lx-ease);
}
.lopeix-quote-form__submit:hover:not(:disabled),
.lopeix-quote-form__submit:focus-visible { transform: translateY(-2px); box-shadow: 0 16px 30px -12px rgba(12, 74, 90, .9); }
.lopeix-quote-form__submit:disabled { opacity: .6; cursor: progress; }
.lopeix-quote-form__whatsapp { display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; text-decoration: none; color: var(--lx-success); }
.lopeix-quote-form__whatsapp:hover { text-decoration: underline; }
@media (min-width: 620px) { .lopeix-quote-form { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* ====================================================================
   11. Admin — meta box da galeria (mínimo; o restante é do Codex em lopeix-admin.css)
   ==================================================================== */
.lopeix-gallery-preview { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.lopeix-gallery-item { position: relative; width: 80px; height: 80px; border: 1px solid #dcdcde; border-radius: 6px; overflow: hidden; background: #f0f0f1; }
.lopeix-gallery-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lopeix-gallery-remove { position: absolute; top: 2px; right: 2px; width: 20px; height: 20px; line-height: 18px; padding: 0; font-size: 14px; font-weight: 700; color: #fff; background: rgba(192, 57, 43, .9); border: 0; border-radius: 50%; cursor: pointer; }
.lopeix-gallery-add { margin-top: 6px; }
