/* =========================================================================
   Levantades — Modern luxury yacht-club design system.

   Original implementation using conventional luxury-yacht web design
   patterns (deep navy + white + champagne gold, Playfair Display + Raleway,
   full-viewport hero, generous whitespace). All .lv-* class hooks from
   the existing PHP templates are preserved.
   ========================================================================= */

:root {
	/* --- Palette --- */
	--white: #ffffff;
	--off-white: #f7f4ec;
	--mist: #eef0f3;

	--navy: #0a1f3d;
	--navy-deep: #050f1f;
	--navy-mid: #1b3458;
	--navy-soft: #233d63;

	--gold: #c9a861;
	--gold-bright: #d9b878;
	--gold-soft: #e7d5a8;
	--gold-deep: #a4853f;

	--ink: #15233a;
	--text: #2a3650;
	--muted: #6b7689;
	--rule-soft: rgba(20, 35, 60, .12);
	--rule-gold: rgba(201, 168, 97, .55);

	--shadow-card: 0 22px 60px -28px rgba(10, 31, 61, .25);
	--shadow-deep: 0 36px 90px -30px rgba(10, 31, 61, .45);
	--shadow-cta:  0 16px 32px -14px rgba(201, 168, 97, .55);

	/* --- Typography --- */
	--font-display: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
	--font-body:    'Raleway', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
	--font-sc:      'Raleway', system-ui, sans-serif;

	/* Legacy aliases — keep so any leftover class still resolves */
	--cream: var(--off-white);
	--cream-2: var(--mist);
	--mahogany: var(--navy);
	--mahogany-dark: var(--navy-deep);
	--brass: var(--gold);
	--brass-dark: var(--gold-deep);

	--container: 1240px;
	--gutter: clamp(20px, 4vw, 64px);
}

/* ------- Reset / base -------------------------------------------------- */

body.levantades-themed {
	margin: 0;
	font-family: var(--font-body);
	font-weight: 400;
	font-size: 17px;
	line-height: 1.7;
	color: var(--text);
	background: var(--white);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

body.levantades-themed::before {
	content: none; /* vintage grain overlay removed */
}

body.levantades-themed .levantades-page {
	position: relative;
}

.levantades-page * { box-sizing: border-box; }

.levantades-page a {
	color: var(--gold-deep);
	text-decoration: none;
	transition: color .2s;
	border-bottom: 0;
}
.levantades-page a:hover { color: var(--gold); }

.levantades-container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--gutter);
}

/* ------- Type primitives ---------------------------------------------- */

.lv-display {
	font-family: var(--font-display);
	font-weight: 400;
	letter-spacing: .005em;
	line-height: 1.15;
	color: var(--navy-deep);
}

.lv-sc,
.lv-eyebrow {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 11px;
	color: var(--gold-deep);
	display: inline-block;
}

.lv-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	color: var(--gold);
}
.lv-eyebrow::before,
.lv-eyebrow::after {
	content: "";
	display: inline-block;
	width: 28px;
	height: 1px;
	background: var(--gold);
}

/* ------- Top strip (slim utility bar) --------------------------------- */

.lv-topstrip {
	background: var(--navy-deep);
	color: rgba(255, 255, 255, .7);
	padding: 11px 0;
	font-size: 11px;
}
.lv-topstrip__inner {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 24px;
	align-items: center;
}
.lv-topstrip__inner > * {
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .3em;
	font-size: 10.5px;
	color: rgba(255, 255, 255, .68);
}
.lv-topstrip__left { display: inline-flex; align-items: center; gap: 10px; }
.lv-topstrip__center { text-align: center; }
.lv-topstrip__right { text-align: right; }
.lv-topstrip svg { width: 14px; height: 14px; fill: var(--gold); }

/* ------- Masthead ------------------------------------------------------ */

.lv-masthead {
	background: var(--navy-deep);
	color: var(--white);
	text-align: center;
	padding: 64px 0 40px;
	position: relative;
}
.lv-masthead .lv-eyebrow { color: var(--gold); }
.lv-masthead .lv-eyebrow::before,
.lv-masthead .lv-eyebrow::after { background: var(--gold); }
.lv-masthead__brand {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(56px, 10vw, 132px);
	color: var(--white);
	line-height: 1;
	margin: 18px 0 8px;
	letter-spacing: .005em;
}
.lv-masthead__brand a {
	color: inherit;
	display: inline-block;
	line-height: 0;
}
.lv-masthead__logo {
	display: block;
	height: clamp(60px, 10vw, 120px);
	width: auto;
	max-width: 100%;
}
.lv-masthead__tagline {
	font-family: var(--font-body);
	font-weight: 300;
	font-style: italic;
	font-size: clamp(16px, 2vw, 20px);
	color: rgba(255, 255, 255, .78);
	margin: 0 0 18px;
}
.lv-masthead__crest {
	font-family: var(--font-body);
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: rgba(231, 213, 168, .85);
}
.lv-masthead__crest span { margin: 0 12px; color: var(--gold); }

.lv-masthead--compact { padding: 48px 0 24px; }
.lv-masthead--compact .lv-masthead__brand { font-size: clamp(40px, 6vw, 80px); }
.lv-masthead--compact .lv-masthead__logo { height: clamp(45px, 6.25vw, 75px); }

/* ------- Primary nav -------------------------------------------------- */

.lv-nav {
	background: var(--navy-deep);
	border-top: 1px solid rgba(201, 168, 97, .25);
}
.lv-nav__list {
	display: flex;
	justify-content: center;
	gap: clamp(18px, 3vw, 44px);
	list-style: none;
	margin: 0;
	padding: 18px 0;
	flex-wrap: wrap;
}
.lv-nav__item a {
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .28em;
	font-size: 11px;
	color: rgba(255, 255, 255, .7);
	padding: 4px 2px;
	transition: color .2s;
	border-bottom: 1px solid transparent;
}
.lv-nav__item a:hover { color: var(--gold); }
.lv-nav__item.is-current a {
	color: var(--gold);
	border-bottom-color: var(--gold);
}

/* Hamburger toggle — hidden on desktop, shown on mobile */
.lv-nav__toggle {
	display: none;
	background: transparent;
	border: 1px solid rgba(201, 168, 97, .45);
	border-radius: 2px;
	padding: 10px;
	width: 44px;
	height: 44px;
	cursor: pointer;
	margin: 10px auto;
	position: relative;
}
.lv-nav__toggle-bar {
	display: block;
	width: 22px;
	height: 1.5px;
	background: var(--gold);
	margin: 4px auto;
	transition: transform .25s ease, opacity .2s ease;
}
.lv-nav__toggle[aria-expanded="true"] .lv-nav__toggle-bar:nth-child(1) {
	transform: translateY(5.5px) rotate(45deg);
}
.lv-nav__toggle[aria-expanded="true"] .lv-nav__toggle-bar:nth-child(2) {
	opacity: 0;
}
.lv-nav__toggle[aria-expanded="true"] .lv-nav__toggle-bar:nth-child(3) {
	transform: translateY(-5.5px) rotate(-45deg);
}

/* ------- Hero (the big one) ------------------------------------------- */

.lv-hero {
	position: relative;
	background: var(--navy-deep);
}
.lv-hero__frame {
	padding: 0;
	background: var(--navy-deep);
	border: 0;
	box-shadow: none;
	position: relative;
}
.lv-hero__inner {
	position: relative;
	aspect-ratio: auto;
	min-height: clamp(420px, 70vh, 760px);
	overflow: hidden;
	border: 0;
	background: var(--navy-deep);
}
.lv-hero__inner::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(5, 15, 31, .25) 0%, rgba(5, 15, 31, .55) 70%, rgba(5, 15, 31, .85) 100%);
	pointer-events: none;
	z-index: 1;
}
.lv-hero__inner img,
.lv-hero__inner .lv-hero__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(1.05) contrast(1.04) brightness(.92);
	transform: scale(1.02);
	transition: transform 1.4s ease-out;
}
.lv-hero:hover .lv-hero__inner img { transform: scale(1.06); }

.lv-hero__img--placeholder {
	background:
		radial-gradient(60% 80% at 30% 30%, rgba(201, 168, 97, .35), transparent 60%),
		linear-gradient(180deg, #0a1f3d 0%, #1b3458 50%, #0a1f3d 100%);
}

/* Floating plate becomes a centered hero caption */
.lv-hero__plate {
	position: absolute;
	left: 50%;
	bottom: clamp(40px, 8vh, 96px);
	transform: translateX(-50%);
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
	text-align: center;
	color: var(--white);
	z-index: 2;
	min-width: 0;
	width: 100%;
	max-width: 760px;
}
.lv-hero__plate small {
	display: block;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .5em;
	font-size: 11px;
	color: var(--gold);
	margin-bottom: 14px;
}
.lv-hero__plate strong {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(28px, 4.5vw, 52px);
	color: var(--white);
	display: block;
	letter-spacing: .005em;
}

/* ------- Section frame ------------------------------------------------ */

.lv-section { padding: clamp(64px, 9vw, 128px) 0; }
.lv-section--tight { padding: clamp(48px, 6vw, 88px) 0; }

/* Alternating section backgrounds for rhythm */
.lv-section:nth-of-type(even) { background: var(--off-white); }

.lv-section-head {
	text-align: center;
	margin-bottom: clamp(40px, 5vw, 72px);
}
.lv-section-head .lv-eyebrow { margin-bottom: 18px; }
.lv-section-head h2 {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(32px, 4.6vw, 56px);
	color: var(--navy-deep);
	margin: 0;
	letter-spacing: -.005em;
	line-height: 1.1;
}

/* Hairline rule with optional ornament — kept minimal */
.lv-rule {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin: 28px 0;
	color: var(--gold);
}
.lv-rule::before,
.lv-rule::after {
	content: "";
	flex: 1;
	max-width: 180px;
	height: 1px;
	background: var(--gold);
	opacity: .55;
}
.lv-rule span { font-size: 12px; color: var(--gold); letter-spacing: .1em; }

/* ------- Lead row ----------------------------------------------------- */

.lv-lead {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: clamp(40px, 6vw, 88px);
	align-items: start;
}
.lv-lead--single { grid-template-columns: 1fr; }
.lv-lead__copy--center { max-width: 780px; margin: 0 auto; text-align: center; }

.lv-lead__kicker {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .5em;
	color: var(--gold-deep);
	font-size: 11px;
	margin-bottom: 22px;
}
.lv-lead__headline {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(30px, 4.2vw, 54px);
	line-height: 1.12;
	color: var(--navy-deep);
	margin: 0 0 28px;
	letter-spacing: -.005em;
}
.lv-lead p {
	font-size: 17px;
	margin: 0 0 18px;
	color: var(--text);
}

/* Dropcap retired in the modern look */
.lv-lead .lv-dropcap::first-letter { all: unset; }

.lv-lead__signature {
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: var(--gold-deep);
	margin-top: 32px;
	border-top: 1px solid var(--rule-gold);
	padding-top: 20px;
	max-width: 280px;
}

.lv-lead__cta { margin-top: 36px; }

/* ------- Buttons ------------------------------------------------------ */

.lv-cta {
	display: block;
	width: 100%;
	background: var(--gold);
	color: var(--navy-deep);
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 12px;
	padding: 18px 28px;
	border: 1px solid var(--gold);
	border-radius: 2px;
	cursor: pointer;
	box-shadow: var(--shadow-cta);
	transition: transform .25s ease, box-shadow .25s ease, background .25s, color .25s;
	margin-top: 6px;
	text-align: center;
}
.lv-cta:hover {
	background: var(--navy-deep);
	color: var(--gold);
	border-color: var(--navy-deep);
	transform: translateY(-2px);
	box-shadow: 0 24px 50px -22px rgba(10, 31, 61, .55);
}

.lv-cta--inline {
	display: inline-block;
	width: auto;
	min-width: 240px;
	padding: 16px 38px;
	color: var(--navy-deep);
}
.lv-cta--inline:hover { color: var(--gold); }

/* Outline variant for use on dark backgrounds */
.lv-cta--outline {
	background: transparent;
	color: var(--gold);
	border: 1px solid var(--gold);
	box-shadow: none;
}
.lv-cta--outline:hover {
	background: var(--gold);
	color: var(--navy-deep);
	border-color: var(--gold);
}

/* ------- Booking card ------------------------------------------------- */

.lv-booking {
	position: relative;
	background: var(--white);
	border: 1px solid var(--rule-soft);
	border-top: 3px solid var(--gold);
	padding: 44px 36px 32px;
	box-shadow: var(--shadow-card);
}
/* Corner brackets retired — kept invisible to avoid mismatched chrome */
.lv-booking::before,
.lv-booking::after { display: none; }

.lv-booking__head { text-align: center; margin-bottom: 24px; }
.lv-booking__head .lv-sc { color: var(--gold-deep); }
.lv-booking__head h3 {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 34px;
	margin: 12px 0 0;
	color: var(--navy-deep);
	letter-spacing: -.005em;
}

.lv-price {
	text-align: center;
	margin: 8px 0 32px;
}
.lv-price small {
	display: block;
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 10.5px;
	color: var(--gold-deep);
	margin-bottom: 8px;
}
.lv-price__amount {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 64px;
	color: var(--navy-deep);
	line-height: 1;
	letter-spacing: -.01em;
}
.lv-price__amount sup {
	font-size: 22px;
	color: var(--gold-deep);
	font-family: var(--font-body);
	font-weight: 500;
	vertical-align: top;
	margin-right: 4px;
	top: 12px;
	position: relative;
}
.lv-price__note {
	font-family: var(--font-body);
	font-style: normal;
	color: var(--muted);
	font-size: 14px;
	margin-top: 10px;
	letter-spacing: .04em;
}

.lv-field {
	display: block;
	margin-bottom: 18px;
}
.lv-field label {
	display: block;
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .28em;
	font-size: 10.5px;
	color: var(--muted);
	margin-bottom: 8px;
}
.lv-field input,
.lv-field select,
.lv-field textarea {
	width: 100%;
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--rule-soft);
	padding: 10px 0;
	font-family: var(--font-body);
	font-size: 16px;
	color: var(--navy-deep);
	border-radius: 0;
	outline: none;
	transition: border-color .2s;
}
.lv-field input:focus,
.lv-field select:focus,
.lv-field textarea:focus {
	border-bottom-color: var(--gold);
}
.lv-field--row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 22px;
	margin-bottom: 18px;
}

.lv-booking__foot {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 10px;
	color: var(--muted);
}

.lv-booking__notice {
	margin-top: 18px;
	padding: 14px 16px;
	border-left: 3px solid var(--gold);
	background: var(--off-white);
	font-family: var(--font-body);
	font-size: 14px;
	color: var(--text);
	text-align: left;
}
.lv-booking__notice--ok { border-left-color: var(--gold); color: var(--navy-deep); }
.lv-booking__notice--err { border-left-color: #b94a3a; color: #b94a3a; }

/* ------- Bordered grids (Aboard + Particulars) ------------------------ */

.lv-grid-table {
	border: 0;
	background: transparent;
	box-shadow: none;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background-color: var(--rule-soft);
}
.lv-grid-table > .lv-cell {
	padding: 36px 28px;
	border: 0;
	background: var(--white);
	min-height: 200px;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	transition: background .25s, transform .25s;
}
.lv-grid-table > .lv-cell:hover {
	background: var(--off-white);
}

.lv-cell__eyebrow {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .4em;
	color: var(--gold-deep);
	font-size: 11px;
	margin-bottom: 14px;
}
.lv-cell h4 {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 24px;
	color: var(--navy-deep);
	margin: 0 0 12px;
	letter-spacing: -.005em;
}
.lv-cell p {
	font-family: var(--font-body);
	font-size: 15px;
	line-height: 1.65;
	color: var(--muted);
	margin: 0;
	font-style: normal;
}

/* ------- Gallery ------------------------------------------------------ */

.lv-gallery {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	grid-auto-rows: 220px;
	gap: 20px;
}
.lv-gallery__item {
	position: relative;
	overflow: hidden;
	border: 0;
	box-shadow: var(--shadow-card);
	background: var(--navy-deep);
	margin: 0;
}
.lv-gallery__item::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 60%, rgba(5, 15, 31, .3) 100%);
	pointer-events: none;
	transition: opacity .4s;
}
.lv-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(1.05) contrast(1.02);
	transition: transform 1.2s ease-out;
}
.lv-gallery__item:hover img { transform: scale(1.06); }
.lv-gallery__item:hover::after { opacity: 0; }

.lv-gallery__item--1 { grid-column: span 6; grid-row: span 2; }
.lv-gallery__item--2 { grid-column: span 3; }
.lv-gallery__item--3 { grid-column: span 3; }
.lv-gallery__item--4 { grid-column: span 3; }
.lv-gallery__item--5 { grid-column: span 3; }
.lv-gallery__item--6 { grid-column: span 4; }
.lv-gallery__item--7 { grid-column: span 8; }

.lv-gallery--full { grid-auto-rows: 240px; }

/* Placeholder gradient swatches kept for fallback */
.lv-photo  { width: 100%; height: 100%; background: linear-gradient(135deg, #1b3458 0%, #0a1f3d 50%, #050f1f 100%); }
.lv-photo--a { background: linear-gradient(160deg, #d9b878 0%, #a4853f 50%, #1b3458 100%); }
.lv-photo--b { background: radial-gradient(80% 60% at 40% 30%, #c9a861, #233d63 70%, #0a1f3d); }
.lv-photo--c { background: linear-gradient(135deg, #0a1f3d, #1b3458 60%, #a4853f); }
.lv-photo--d { background: linear-gradient(200deg, #c9a861 0%, #233d63 60%, #050f1f); }
.lv-photo--e { background: radial-gradient(60% 80% at 70% 50%, #d9b878, #1b3458 60%, #050f1f); }
.lv-photo--f { background: linear-gradient(180deg, #1b3458, #050f1f 70%); }
.lv-photo--g { background: linear-gradient(220deg, #c9a861 0%, #1b3458 50%, #0a1f3d 100%); }

/* ------- Story (two columns) ------------------------------------------ */

.lv-story {
	max-width: 820px;
	margin: 0 auto;
	column-count: 2;
	column-gap: 56px;
	font-family: var(--font-body);
	font-size: 17px;
	color: var(--text);
	line-height: 1.8;
}
.lv-story p { margin: 0 0 18px; }
.lv-story p:first-child::first-letter { all: unset; } /* no dropcap */

/* ------- Itinerary ---------------------------------------------------- */

.lv-itinerary {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
}
.lv-stop {
	position: relative;
	background: var(--white);
	border: 1px solid var(--rule-soft);
	border-top: 2px solid var(--gold);
	padding: 64px 28px 36px;
	text-align: center;
	box-shadow: var(--shadow-card);
	transition: transform .3s, box-shadow .3s;
}
.lv-stop:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-deep);
}
.lv-stop__roundel {
	position: absolute;
	top: -24px;
	left: 50%;
	transform: translateX(-50%);
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--white);
	border: 1px solid var(--gold);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	color: var(--gold-deep);
	font-size: 18px;
	letter-spacing: .04em;
	box-shadow: 0 8px 16px -6px rgba(10, 31, 61, .25);
}
.lv-stop__time {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: var(--gold-deep);
	margin-bottom: 12px;
}
.lv-stop h4 {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 26px;
	color: var(--navy-deep);
	margin: 0 0 12px;
	letter-spacing: -.005em;
}
.lv-stop p {
	font-family: var(--font-body);
	font-size: 15px;
	color: var(--muted);
	margin: 0;
	line-height: 1.65;
}

/* ------- Pull quote --------------------------------------------------- */

.lv-ship-illustration {
	margin: clamp(60px, 8vw, 110px) auto 0;
	padding: 0;
	text-align: center;
	max-width: 280px;
}
.lv-ship-illustration img {
	display: block;
	width: 100%;
	height: auto;
	opacity: .82;
	mix-blend-mode: multiply;
}
.lv-ship-illustration + .lv-pull {
	margin-top: clamp(24px, 3vw, 48px);
}

.lv-pull {
	max-width: 920px;
	margin: clamp(60px, 8vw, 110px) auto;
	text-align: center;
	border: 0;
	padding: 0 24px;
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(26px, 3.8vw, 42px);
	line-height: 1.3;
	color: var(--navy-deep);
	letter-spacing: -.005em;
	font-style: italic;
	position: relative;
}
.lv-pull::before {
	content: "";
	display: block;
	width: 56px;
	height: 1px;
	background: var(--gold);
	margin: 0 auto 36px;
}
.lv-pull cite {
	display: block;
	margin-top: 32px;
	font-family: var(--font-body);
	font-style: normal;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: var(--gold-deep);
}

/* ------- Feature grid (front page) ------------------------------------ */

.lv-feature-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}
.lv-feature {
	position: relative;
	background: var(--white);
	border: 1px solid var(--rule-soft);
	border-top: 2px solid var(--gold);
	padding: 60px 32px 36px;
	text-align: center;
	box-shadow: var(--shadow-card);
	transition: transform .3s, box-shadow .3s;
}
.lv-feature:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-deep);
}
.lv-feature__roundel {
	position: absolute;
	top: -24px;
	left: 50%;
	transform: translateX(-50%);
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--white);
	border: 1px solid var(--gold);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	color: var(--gold-deep);
	font-size: 18px;
}
.lv-feature h3 {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 26px;
	color: var(--navy-deep);
	margin: 0 0 14px;
	letter-spacing: -.005em;
}
.lv-feature p {
	font-family: var(--font-body);
	font-style: normal;
	color: var(--muted);
	margin: 0;
	line-height: 1.65;
	font-size: 15px;
}

/* ------- CTA band ----------------------------------------------------- */

.lv-cta-band { background: var(--navy-deep); padding: clamp(64px, 8vw, 112px) 0; }
.lv-cta-band__inner {
	border: 0;
	background: transparent;
	padding: 0 24px;
	text-align: center;
	box-shadow: none;
	color: var(--white);
}
.lv-cta-band .lv-eyebrow { color: var(--gold); }
.lv-cta-band .lv-eyebrow::before,
.lv-cta-band .lv-eyebrow::after { background: var(--gold); }
.lv-cta-band__title {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(28px, 4vw, 48px);
	margin: 18px 0 22px;
	color: var(--white);
	letter-spacing: -.005em;
}
.lv-cta-band__note {
	font-family: var(--font-body);
	color: rgba(255, 255, 255, .75);
	margin: 0 0 32px;
	font-size: 16px;
}
.lv-cta-band .lv-cta--inline {
	background: var(--gold);
	color: var(--navy-deep);
	border-color: var(--gold);
}
.lv-cta-band .lv-cta--inline:hover {
	background: transparent;
	color: var(--gold);
	border-color: var(--gold);
}

/* ------- Contact page ------------------------------------------------- */

.lv-contact-grid {
	display: grid;
	grid-template-columns: 1fr 1.15fr;
	gap: clamp(36px, 5vw, 72px);
	align-items: start;
}
.lv-contact-aside h5 {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: var(--gold-deep);
	margin: 28px 0 8px;
}
.lv-contact-aside h5:first-child { margin-top: 0; }
.lv-contact-aside p {
	margin: 0 0 6px;
	font-size: 16px;
	color: var(--text);
	line-height: 1.65;
}

.lv-booking--contact .lv-booking__head h3 { font-size: 30px; }

.lv-note {
	text-align: center;
	font-family: var(--font-body);
	color: var(--muted);
	margin-top: 32px;
	font-size: 14px;
}

/* ------- Footer ------------------------------------------------------- */

.lv-footer {
	background: var(--navy-deep);
	color: rgba(255, 255, 255, .75);
	border-top: 0;
	padding: clamp(64px, 7vw, 96px) 0 32px;
	margin-top: 0;
}
.lv-footer__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 48px;
}
.lv-footer h5 {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 11px;
	color: var(--gold);
	margin: 0 0 20px;
}
.lv-footer p, .lv-footer a {
	font-family: var(--font-body);
	font-size: 15px;
	color: rgba(255, 255, 255, .72);
	margin: 0 0 6px;
	border-bottom: 0;
	line-height: 1.7;
}
.lv-footer a:hover { color: var(--gold); }

.lv-footer__anchor {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 16px;
	color: var(--gold);
	margin: 56px 0 24px;
	font-size: 18px;
	opacity: .7;
}
.lv-footer__anchor::before,
.lv-footer__anchor::after {
	content: "";
	flex: 1;
	max-width: 220px;
	height: 1px;
	background: rgba(201, 168, 97, .35);
}
.lv-footer__copy {
	text-align: center;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .42em;
	font-size: 10.5px;
	color: rgba(255, 255, 255, .55);
}

/* ------- Responsive --------------------------------------------------- */

@media (max-width: 980px) {
	.lv-lead { grid-template-columns: 1fr; }
	.lv-grid-table { grid-template-columns: repeat(2, 1fr); }
	.lv-itinerary { grid-template-columns: repeat(2, 1fr); row-gap: 52px; }
	.lv-story { column-count: 1; }
	.lv-gallery { grid-auto-rows: 180px; }
	.lv-gallery__item--1 { grid-column: span 12; grid-row: span 2; }
	.lv-gallery__item--2 { grid-column: span 6; }
	.lv-gallery__item--3 { grid-column: span 6; }
	.lv-gallery__item--4 { grid-column: span 6; }
	.lv-gallery__item--5 { grid-column: span 6; }
	.lv-gallery__item--6 { grid-column: span 6; }
	.lv-gallery__item--7 { grid-column: span 6; }
	.lv-feature-grid { grid-template-columns: 1fr; row-gap: 52px; }
	.lv-footer__grid { grid-template-columns: 1fr; gap: 32px; }
	.lv-contact-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
	/* Remove the top utility strip entirely on mobile */
	.lv-topstrip { display: none; }

	/* Swap the inline nav for a hamburger + collapsible drawer */
	.lv-nav { border-top: 0; }
	.lv-nav .levantades-container {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		padding-top: 0;
		padding-bottom: 0;
	}
	.lv-nav__toggle { display: block; }
	.lv-nav__list {
		flex-direction: column;
		gap: 0;
		padding: 0;
		max-height: 0;
		overflow: hidden;
		transition: max-height .3s ease;
		border-top: 1px solid rgba(201, 168, 97, .2);
	}
	.lv-nav__list.is-open {
		max-height: 70vh;
		padding: 8px 0 16px;
	}
	.lv-nav__item {
		width: 100%;
		text-align: center;
		border-bottom: 1px solid rgba(201, 168, 97, .12);
	}
	.lv-nav__item:last-child { border-bottom: 0; }
	.lv-nav__item a {
		display: block;
		padding: 16px 12px;
		font-size: 11px;
		letter-spacing: .28em;
	}
	.lv-nav__item.is-current a { border-bottom-color: transparent; }

	/* Shorter, less cramped hero on phones */
	.lv-hero__inner { min-height: clamp(320px, 60vh, 480px); }
	.lv-hero__plate { bottom: 28px; padding: 0 18px; }
	.lv-hero__plate small { letter-spacing: .42em; font-size: 10.5px; margin-bottom: 10px; }
	.lv-hero__plate strong { font-size: clamp(22px, 6vw, 32px); }
}

@media (max-width: 560px) {
	body.levantades-themed { font-size: 16px; }
	.lv-grid-table { grid-template-columns: 1fr; }
	.lv-itinerary { grid-template-columns: 1fr; }
	.lv-booking { padding: 32px 22px 26px; }
	.lv-hero__inner { min-height: clamp(280px, 55vh, 420px); }
}

/* =======================================================================
   WooCommerce overrides — tuned for the modern palette
   ======================================================================= */

.lv-wc-wrap {
	font-family: var(--font-body);
	font-size: 17px;
	color: var(--text);
}

.lv-wc-wrap table.shop_table,
.lv-wc-wrap table.woocommerce-checkout-review-order-table,
.lv-wc-wrap table.woocommerce-table--order-details {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--rule-soft);
	background: var(--white);
	box-shadow: var(--shadow-card);
	font-family: var(--font-body);
	margin: 28px 0;
}
.lv-wc-wrap table.shop_table th,
.lv-wc-wrap table.shop_table td,
.lv-wc-wrap table.woocommerce-checkout-review-order-table th,
.lv-wc-wrap table.woocommerce-checkout-review-order-table td,
.lv-wc-wrap table.woocommerce-table--order-details th,
.lv-wc-wrap table.woocommerce-table--order-details td {
	border-bottom: 1px solid var(--rule-soft);
	border-top: 0;
	border-left: 0;
	border-right: 0;
	padding: 18px 20px;
	text-align: left;
	vertical-align: middle;
	color: var(--navy-deep);
}
.lv-wc-wrap table.shop_table thead th {
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 11px;
	color: var(--gold-deep);
	background: var(--off-white);
}
.lv-wc-wrap table.shop_table tfoot th,
.lv-wc-wrap table.shop_table tfoot td {
	background: var(--off-white);
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .28em;
	font-size: 12px;
	color: var(--navy-deep);
}

.lv-wc-wrap input[type="text"],
.lv-wc-wrap input[type="email"],
.lv-wc-wrap input[type="tel"],
.lv-wc-wrap input[type="password"],
.lv-wc-wrap input[type="number"],
.lv-wc-wrap input[type="date"],
.lv-wc-wrap input[type="url"],
.lv-wc-wrap select,
.lv-wc-wrap textarea,
.lv-wc-wrap .select2-container .select2-selection {
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--rule-soft);
	padding: 12px 0;
	font-family: var(--font-body);
	font-size: 16px;
	color: var(--navy-deep);
	border-radius: 0;
	width: 100%;
	box-sizing: border-box;
	min-height: 46px;
	line-height: 1.4;
}
.lv-wc-wrap input:focus,
.lv-wc-wrap select:focus,
.lv-wc-wrap textarea:focus {
	border-bottom-color: var(--gold);
	outline: none;
}
.lv-wc-wrap label {
	display: block;
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 10.5px;
	color: var(--muted);
	margin: 16px 0 6px;
}

.lv-wc-wrap .button,
.lv-wc-wrap a.button,
.lv-wc-wrap button.button,
.lv-wc-wrap input[type="submit"],
.lv-wc-wrap .wp-element-button {
	display: inline-block;
	background: var(--gold);
	color: var(--navy-deep) !important;
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 12px;
	padding: 16px 32px;
	border: 1px solid var(--gold);
	border-radius: 2px;
	cursor: pointer;
	box-shadow: var(--shadow-cta);
	text-decoration: none;
	transition: transform .25s, background .25s, color .25s, box-shadow .25s;
}
.lv-wc-wrap .button:hover,
.lv-wc-wrap a.button:hover,
.lv-wc-wrap button.button:hover,
.lv-wc-wrap input[type="submit"]:hover {
	background: var(--navy-deep);
	color: var(--gold) !important;
	border-color: var(--navy-deep);
	transform: translateY(-2px);
}
.lv-wc-wrap .button.alt,
.lv-wc-wrap button[name="update_cart"] {
	background: var(--white);
	color: var(--navy-deep) !important;
	border-color: var(--rule-soft);
	box-shadow: none;
}

.lv-wc-wrap .woocommerce-message,
.lv-wc-wrap .woocommerce-info,
.lv-wc-wrap .woocommerce-error,
.lv-wc-wrap .woocommerce-notice {
	background: var(--off-white);
	border-left: 3px solid var(--gold);
	border-top: 0; border-right: 0; border-bottom: 0;
	color: var(--navy-deep);
	padding: 16px 20px;
	margin: 18px 0;
	font-family: var(--font-body);
	font-size: 16px;
	border-radius: 0;
	box-shadow: none;
}
.lv-wc-wrap .woocommerce-error { border-left-color: #b94a3a; color: #b94a3a; }

.lv-wc-wrap #order_review,
.lv-wc-wrap #order_review_heading {
	background: var(--white);
	border: 1px solid var(--rule-soft);
	padding: 28px;
	box-shadow: var(--shadow-card);
	margin-top: 32px;
}
.lv-wc-wrap #order_review_heading {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: 26px;
	margin-bottom: 0;
	border-bottom: 0;
	padding-bottom: 14px;
	color: var(--navy-deep);
}
.lv-wc-wrap #order_review { margin-top: 0; border-top: 0; }

.lv-wc-wrap .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	border: 1px solid var(--rule-soft);
	background: var(--white);
}
.lv-wc-wrap .woocommerce-MyAccount-navigation li {
	border-bottom: 1px solid var(--rule-soft);
}
.lv-wc-wrap .woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.lv-wc-wrap .woocommerce-MyAccount-navigation a {
	display: block;
	padding: 16px 20px;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 11px;
	color: var(--muted);
	border-bottom: 0;
	text-decoration: none;
	transition: color .2s, background .2s;
}
.lv-wc-wrap .woocommerce-MyAccount-navigation li.is-active a,
.lv-wc-wrap .woocommerce-MyAccount-navigation a:hover {
	background: var(--off-white);
	color: var(--gold-deep);
}

.lv-prose h2 { font-family: var(--font-display); font-weight: 400; color: var(--navy-deep); margin: 28px 0 14px; letter-spacing: -.005em; }
.lv-prose h3 { font-family: var(--font-display); font-weight: 400; color: var(--navy-deep); margin: 22px 0 12px; font-size: 22px; }
.lv-prose p  { margin: 0 0 16px; color: var(--text); }

.lv-wc-wrap .wc-block-cart,
.lv-wc-wrap .wc-block-checkout { background: var(--white); }
.lv-wc-wrap .wc-block-components-totals-item,
.lv-wc-wrap .wc-block-components-product-name,
.lv-wc-wrap .wc-block-components-product-metadata,
.lv-wc-wrap .wc-block-components-product-price {
	color: var(--navy-deep) !important;
	font-family: var(--font-body) !important;
}
.lv-wc-wrap .wc-block-components-title,
.lv-wc-wrap .wc-block-components-checkout-step__title,
.lv-wc-wrap .wc-block-components-totals-footer-item {
	font-family: var(--font-display) !important;
	color: var(--navy-deep) !important;
}

.page-template-page-book .wc-bookings-booking-form,
.page-template-page-book form.cart .wc-bookings-booking-form { all: revert; }
.page-template-page-book .single_add_to_cart_button { display: none !important; }

/* =======================================================================
   Gallery lightbox
   ======================================================================= */

.lv-gallery__item a {
	display: block;
	width: 100%;
	height: 100%;
	border-bottom: 0;
	cursor: zoom-in;
}
.lv-gallery__item a img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

html.lv-lightbox-open { overflow: hidden; }

.lv-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
}
.lv-lightbox.is-open { display: flex; }

.lv-lightbox__overlay {
	position: absolute;
	inset: 0;
	background: rgba(5, 15, 31, .94);
	cursor: zoom-out;
	animation: lv-fade-in .25s ease-out;
}

.lv-lightbox__figure {
	position: relative;
	max-width: 92vw;
	max-height: 90vh;
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	z-index: 1;
}

.lv-lightbox__img {
	max-width: 92vw;
	max-height: 78vh;
	display: block;
	opacity: 0;
	transition: opacity .35s ease-out;
	box-shadow: 0 30px 80px -20px rgba(0, 0, 0, .6);
}
.lv-lightbox__img.is-loaded { opacity: 1; }

.lv-lightbox__caption {
	color: rgba(255, 255, 255, .7);
	font-size: 14px;
	letter-spacing: .04em;
	text-align: center;
	max-width: 720px;
	padding: 0 24px;
}

.lv-lightbox__counter {
	position: absolute;
	top: 22px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	color: var(--gold);
	font-family: var(--font-body);
	font-weight: 500;
	letter-spacing: .42em;
	font-size: 11px;
	text-transform: uppercase;
}

.lv-lightbox__close,
.lv-lightbox__nav {
	position: absolute;
	background: transparent;
	border: 1px solid rgba(201, 168, 97, .35);
	color: var(--gold);
	cursor: pointer;
	z-index: 2;
	transition: background .2s, color .2s, border-color .2s, transform .2s;
	padding: 0;
	line-height: 1;
}
.lv-lightbox__close:hover,
.lv-lightbox__nav:hover {
	background: var(--gold);
	color: var(--navy-deep);
	border-color: var(--gold);
}

.lv-lightbox__close {
	top: 18px;
	right: 22px;
	width: 44px;
	height: 44px;
	font-size: 28px;
	border-radius: 50%;
}

.lv-lightbox__nav {
	top: 50%;
	transform: translateY(-50%);
	width: 56px;
	height: 56px;
	font-size: 34px;
	border-radius: 50%;
	font-family: var(--font-display);
}
.lv-lightbox__nav:hover { transform: translateY(-50%) scale(1.05); }
.lv-lightbox__nav--prev { left: 24px; }
.lv-lightbox__nav--next { right: 24px; }

@keyframes lv-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@media (max-width: 760px) {
	.lv-lightbox__nav { width: 44px; height: 44px; font-size: 28px; }
	.lv-lightbox__nav--prev { left: 8px; }
	.lv-lightbox__nav--next { right: 8px; }
	.lv-lightbox__close { top: 10px; right: 10px; width: 38px; height: 38px; font-size: 24px; }
	.lv-lightbox__counter { top: 16px; font-size: 10px; }
}

/* =======================================================================
   Cookie consent banner
   ======================================================================= */

.lv-cookie {
	position: fixed;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%) translateY(20px);
	max-width: 720px;
	width: calc(100% - 32px);
	z-index: 9000;
	background: var(--navy-deep);
	border: 1px solid rgba(201, 168, 97, .35);
	box-shadow: 0 24px 60px -22px rgba(0, 0, 0, .5);
	color: var(--white);
	font-family: var(--font-body);
	font-size: 14px;
	opacity: 0;
	transition: opacity .35s ease-out, transform .35s ease-out;
	pointer-events: none;
}
.lv-cookie.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
	pointer-events: auto;
}
.lv-cookie__inner {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 16px 22px;
}
.lv-cookie__text {
	flex: 1;
	margin: 0;
	color: rgba(255, 255, 255, .82);
	line-height: 1.5;
}
.lv-cookie__text a {
	color: var(--gold);
	border-bottom: 1px solid rgba(201, 168, 97, .5);
}
.lv-cookie__text a:hover { color: var(--gold-bright); }
.lv-cookie__ok {
	flex: 0 0 auto;
	background: var(--gold);
	color: var(--navy-deep);
	border: 1px solid var(--gold);
	font-family: var(--font-body);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 11px;
	padding: 10px 22px;
	border-radius: 2px;
	cursor: pointer;
	transition: background .2s, color .2s;
}
.lv-cookie__ok:hover {
	background: var(--white);
	color: var(--navy-deep);
}
@media (max-width: 600px) {
	.lv-cookie__inner { flex-direction: column; align-items: stretch; gap: 12px; }
	.lv-cookie__ok { width: 100%; }
}

/* ------- Testimonials --------- */

.lv-testimonials {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.lv-testimonial {
	background: var(--white);
	border: 1px solid var(--rule-soft);
	border-top: 2px solid var(--gold);
	padding: 36px 30px 28px;
	margin: 0;
	box-shadow: var(--shadow-card);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	position: relative;
	transition: transform .3s, box-shadow .3s;
}
.lv-testimonial:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-deep);
}
.lv-testimonial::before {
	content: "“";
	position: absolute;
	top: 14px;
	right: 24px;
	font-family: var(--font-display);
	font-size: 56px;
	color: var(--gold);
	opacity: .35;
	line-height: 1;
}
.lv-testimonial blockquote {
	margin: 0 0 22px;
	padding: 0;
	border: 0;
	font-family: var(--font-display);
	font-weight: 400;
	font-style: italic;
	font-size: 18px;
	line-height: 1.5;
	color: var(--navy-deep);
}
.lv-testimonial figcaption {
	border-top: 1px solid var(--rule-soft);
	padding-top: 14px;
}
.lv-testimonial__name {
	display: block;
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 14px;
	color: var(--navy-deep);
	letter-spacing: .02em;
	margin-bottom: 2px;
}
.lv-testimonial__meta {
	display: block;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 10.5px;
	color: var(--gold-deep);
}

@media (max-width: 980px) {
	.lv-testimonials { grid-template-columns: 1fr; }
}

/* ------- 404 page --------- */

.lv-404 {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
	padding: 24px 0;
}
.lv-404__numeral {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(110px, 22vw, 220px);
	line-height: 1;
	color: var(--gold);
	letter-spacing: .005em;
	margin-bottom: 12px;
	opacity: .85;
}
.lv-404__title {
	font-family: var(--font-display);
	font-weight: 400;
	font-size: clamp(28px, 4vw, 42px);
	color: var(--navy-deep);
	margin: 18px 0 14px;
	letter-spacing: -.005em;
}
.lv-404__body {
	font-family: var(--font-body);
	font-size: 17px;
	color: var(--muted);
	margin: 0 0 32px;
}
.lv-404__actions {
	display: flex;
	justify-content: center;
	gap: 18px;
	flex-wrap: wrap;
	margin-bottom: 32px;
}
.lv-404__actions .lv-cta { width: auto; min-width: 220px; }
.lv-404__links {
	display: flex;
	justify-content: center;
	gap: 28px;
	list-style: none;
	margin: 24px 0 0;
	padding: 18px 0 0;
	border-top: 1px solid var(--rule-soft);
	flex-wrap: wrap;
}
.lv-404__links a {
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .32em;
	font-size: 11px;
	color: var(--gold-deep);
	border-bottom: 0;
}
.lv-404__links a:hover { color: var(--gold); }

/* ------- Footer legal links --------- */
.lv-footer__legal {
	margin-top: 18px;
	display: flex;
	justify-content: center;
	gap: 28px;
	flex-wrap: wrap;
	font-family: var(--font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .35em;
	font-size: 10px;
}
.lv-footer__legal a {
	color: rgba(255, 255, 255, .55);
	border-bottom: 0;
	transition: color .2s;
}
.lv-footer__legal a:hover { color: var(--gold); }
