/* ==========================================================================
   Volcán Imperial — Landing pages (Matrimonios / Empresas)
   Custom, non-Brizy, mobile-first, animated. 2026-06.
   ========================================================================== */

:root {
	--vi-blue: #0a497b;
	--vi-blue-deep: #063252;
	--vi-blue-ink: #04263f;
	--vi-gold: #b09455;
	--vi-gold-soft: #d2bd84;
	--vi-ink: #1b2733;
	--vi-muted: #5d6b78;
	--vi-cream: #fbf8f3;
	--vi-sand: #f1e9dd;
	--vi-line: #e7ddcd;
	--vi-white: #ffffff;
	--vi-shadow: 0 18px 50px -24px rgba(4, 38, 63, 0.45);
	--vi-shadow-sm: 0 8px 24px -16px rgba(4, 38, 63, 0.5);
	--vi-radius: 16px;
	--vi-container: 1180px;
	--vi-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--vi-font-head: "Instrument Serif", Georgia, "Times New Roman", serif;
	--vi-font-body: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--vi-font-brand: "Special Gothic Expanded One", "Montserrat", sans-serif;
}

/* Branded "Volcán Imperial" wordmark when set in text */
.vi-brand { font-family: var(--vi-font-brand); font-weight: 400; letter-spacing: 0.04em; }

/* Corporate variant (Empresas): cool steel/slate palette, no gold warmth */
body.vi-corp {
	--vi-gold: #3f6f93;
	--vi-gold-soft: #9fc0d6;
	--vi-cream: #f5f8fb;
	--vi-sand: #e8f0f6;
	--vi-line: #d3e2ee;
}
/* Corporate buttons: brushed steel (same machined structure as brass) */
body.vi-corp .vi-btn--gold {
	border-color: rgba(206, 216, 228, 0.5);
	background-color: #6c7886;
	background-image:
		radial-gradient(ellipse 85% 110% at 50% -6%, rgba(246, 250, 255, 0.18), transparent 66%),
		repeating-radial-gradient(circle at 50% 145%, rgba(244, 249, 255, 0.05) 0px, rgba(244, 249, 255, 0.05) 1px, rgba(28, 36, 46, 0.05) 1px, rgba(28, 36, 46, 0.05) 2px),
		repeating-linear-gradient(116deg, rgba(244, 249, 255, 0.025) 0px, rgba(244, 249, 255, 0.025) 0.5px, rgba(24, 32, 42, 0.024) 0.5px, rgba(24, 32, 42, 0.024) 1.6px),
		linear-gradient(177deg, #97a3b1 0%, #76828f 32%, #626d7b 58%, #444e5b 100%);
	text-shadow: 0 1px 2px rgba(22, 30, 40, 0.55);
	box-shadow:
		0 9px 20px -12px rgba(30, 42, 56, 0.55),
		inset 0 2px 1.5px -1px rgba(248, 252, 255, 0.8),
		inset 0 -3px 4px -2px rgba(20, 28, 38, 0.6),
		inset 0 0 0 1px rgba(40, 52, 66, 0.35);
}
body.vi-corp .vi-btn--gold::before {
	background: conic-gradient(from var(--vi-rim),
		rgba(248, 252, 255, 0) 0deg,
		rgba(248, 252, 255, 0.95) 30deg,
		rgba(70, 90, 110, 0.1) 76deg,
		rgba(248, 252, 255, 0) 140deg,
		rgba(248, 252, 255, 0) 198deg,
		rgba(248, 252, 255, 0.8) 246deg,
		rgba(70, 90, 110, 0.1) 292deg,
		rgba(248, 252, 255, 0) 360deg);
}

/* Home variant: deep-navy palette + machined navy buttons */
body.vi-navy {
	--vi-gold: #355d86;
	--vi-gold-soft: #a7c6e0;
}
body.vi-navy .vi-btn--gold {
	border-color: rgba(150, 182, 216, 0.45);
	background-color: #1d3a5a;
	background-image:
		radial-gradient(ellipse 85% 110% at 50% -6%, rgba(212, 230, 250, 0.16), transparent 66%),
		repeating-radial-gradient(circle at 50% 145%, rgba(204, 224, 248, 0.05) 0px, rgba(204, 224, 248, 0.05) 1px, rgba(8, 18, 32, 0.06) 1px, rgba(8, 18, 32, 0.06) 2px),
		repeating-linear-gradient(116deg, rgba(204, 224, 248, 0.025) 0px, rgba(204, 224, 248, 0.025) 0.5px, rgba(6, 16, 30, 0.03) 0.5px, rgba(6, 16, 30, 0.03) 1.6px),
		linear-gradient(177deg, #2f5078 0%, #1f3c5d 32%, #173050 58%, #0c2037 100%);
	text-shadow: 0 1px 2px rgba(4, 14, 28, 0.6);
	box-shadow:
		0 9px 20px -12px rgba(8, 24, 44, 0.7),
		inset 0 2px 1.5px -1px rgba(214, 232, 252, 0.7),
		inset 0 -3px 4px -2px rgba(4, 14, 28, 0.7),
		inset 0 0 0 1px rgba(42, 68, 100, 0.4);
}
body.vi-navy .vi-btn--gold::before {
	background: conic-gradient(from var(--vi-rim),
		rgba(222, 238, 255, 0) 0deg,
		rgba(222, 238, 255, 0.92) 30deg,
		rgba(60, 90, 130, 0.12) 76deg,
		rgba(222, 238, 255, 0) 140deg,
		rgba(222, 238, 255, 0) 198deg,
		rgba(222, 238, 255, 0.78) 246deg,
		rgba(60, 90, 130, 0.12) 292deg,
		rgba(222, 238, 255, 0) 360deg);
}

/* ----- Base ----- */
body.vi-landing {
	margin: 0;
	font-family: var(--vi-font-body);
	color: var(--vi-ink);
	background: var(--vi-white);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
body.vi-landing * { box-sizing: border-box; }
body.vi-landing img { max-width: 100%; display: block; }
body.vi-landing a { text-decoration: none; }
body.vi-landing .vi-hero a:not(.vi-btn), body.vi-landing .vi-footer a, body.vi-landing .vi-cta a:not(.vi-btn) { color: inherit; }

.vi-wrap { width: 100%; max-width: var(--vi-container); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2.5rem); }

.vi-eyebrow {
	font-family: var(--vi-font-body);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--vi-gold);
	margin: 0 0 0.9rem;
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
}
.vi-eyebrow::before { content: ""; width: 30px; height: 1px; background: currentColor; opacity: 0.7; }

h1, h2, h3, .vi-h { font-family: var(--vi-font-head); font-weight: 400; line-height: 1.08; color: var(--vi-blue-deep); margin: 0 0 0.5em; }
.vi-h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
.vi-h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); }
.vi-lead { font-size: clamp(1.05rem, 1.6vw, 1.22rem); color: var(--vi-muted); max-width: 60ch; }

.vi-section { padding-block: clamp(3.5rem, 8vw, 7rem); }
.vi-section--cream { background: var(--vi-cream); }
.vi-section--sand { background: var(--vi-sand); }
.vi-center { text-align: center; }
.vi-center .vi-lead, .vi-center .vi-eyebrow { margin-inline: auto; }
.vi-center .vi-eyebrow { display: inline-flex; }

/* ----- Buttons ----- */
.vi-btn {
	display: inline-flex; align-items: center; gap: 0.55rem;
	font-weight: 600; font-size: 0.98rem; letter-spacing: 0.01em;
	padding: 0.92rem 1.7rem; border-radius: 999px; cursor: pointer;
	border: 1px solid transparent; transition: transform 0.3s var(--vi-ease), box-shadow 0.3s var(--vi-ease), background 0.3s, color 0.3s;
	will-change: transform;
}
.vi-btn svg { width: 1.1em; height: 1.1em; }
/* Machined brass: top-lit satin face + spun/cross grain, an inset bevel
   (chamfer) and a conic-gradient reflection that sweeps around the rim. */
@property --vi-rim { syntax: "<angle>"; inherits: false; initial-value: 0deg; }

.vi-btn--gold {
	color: #fff !important;
	position: relative;
	isolation: isolate;
	--vi-rim: 0deg;
	border: 1px solid rgba(66, 52, 24, 0.55);
	background-color: #9c8348;
	background-image:
		radial-gradient(ellipse 85% 110% at 50% -6%, rgba(255, 247, 222, 0.16), transparent 66%),
		repeating-radial-gradient(circle at 50% 145%, rgba(255, 247, 222, 0.045) 0px, rgba(255, 247, 222, 0.045) 1px, rgba(52, 42, 18, 0.045) 1px, rgba(52, 42, 18, 0.045) 2px),
		repeating-linear-gradient(116deg, rgba(255, 249, 226, 0.022) 0px, rgba(255, 249, 226, 0.022) 0.5px, rgba(44, 35, 14, 0.022) 0.5px, rgba(44, 35, 14, 0.022) 1.6px),
		linear-gradient(177deg, #bca468 0%, #a08951 32%, #8d7742 58%, #6d5829 100%);
	background-repeat: no-repeat;
	text-shadow: 0 1px 2px rgba(46, 36, 12, 0.55);
	box-shadow:
		0 9px 20px -12px rgba(78, 60, 20, 0.6),
		inset 0 2px 1.5px -1px rgba(255, 247, 216, 0.8),
		inset 0 -3px 4px -2px rgba(46, 35, 12, 0.7),
		inset 0 0 0 1px rgba(92, 73, 35, 0.35);
	transition: transform 0.3s var(--vi-ease), box-shadow 0.3s var(--vi-ease), filter 0.3s var(--vi-ease);
}
.vi-btn--gold::before {
	content: "";
	position: absolute; inset: 0;
	border-radius: inherit;
	padding: 1.6px;
	background: conic-gradient(from var(--vi-rim),
		rgba(255, 251, 230, 0) 0deg,
		rgba(255, 251, 230, 0.95) 30deg,
		rgba(150, 120, 60, 0.1) 76deg,
		rgba(255, 251, 230, 0) 140deg,
		rgba(255, 251, 230, 0) 198deg,
		rgba(255, 251, 230, 0.8) 246deg,
		rgba(150, 120, 60, 0.1) 292deg,
		rgba(255, 251, 230, 0) 360deg);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	mask-composite: exclude;
	animation: vi-rim-spin 5.5s linear infinite;
	pointer-events: none;
}
@keyframes vi-rim-spin { to { --vi-rim: 360deg; } }
.vi-btn--gold svg { position: relative; filter: drop-shadow(0 1px 2px rgba(46, 36, 12, 0.5)); }
.vi-btn--gold:hover {
	color: #fff !important;
	transform: translateY(-2px);
	filter: brightness(1.05);
	box-shadow:
		0 15px 28px -14px rgba(78, 60, 20, 0.75),
		inset 0 2px 1.5px -1px rgba(255, 249, 222, 0.9),
		inset 0 -3px 4px -2px rgba(46, 35, 12, 0.7),
		inset 0 0 0 1px rgba(92, 73, 35, 0.35);
}
.vi-btn--gold:hover::before { animation-duration: 2.6s; }
.vi-btn--ghost { background: transparent; color: #fff !important; border-color: rgba(255, 255, 255, 0.6); }
.vi-btn--ghost:hover { background: rgba(255, 255, 255, 0.14); border-color: rgba(255, 255, 255, 0.9); transform: translateY(-3px); }
.vi-btn--outline { background: #fff; color: var(--vi-blue) !important; border-color: var(--vi-line); }
.vi-btn--outline:hover { transform: translateY(-3px); box-shadow: var(--vi-shadow-sm); border-color: var(--vi-gold); }

/* ==========================================================================
   Header
   ========================================================================== */
/* Over the hero: NO bar — logo + nav float directly on the photo. */
.vi-header {
	position: fixed; inset: 0 0 auto 0; z-index: 100;
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; padding: 1.15rem clamp(1.1rem, 4vw, 3rem);
	background: transparent;
	transition: background 0.4s var(--vi-ease), padding 0.4s var(--vi-ease), box-shadow 0.4s, border-color 0.4s;
}
/* After the hero: a full-width rectangular glass bar slides in. */
.vi-header.scrolled {
	background: rgba(7, 40, 64, 0.72);
	-webkit-backdrop-filter: blur(20px) saturate(1.5);
	backdrop-filter: blur(20px) saturate(1.5);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 14px 40px -24px rgba(0, 0, 0, 0.6);
	padding-block: 0.55rem;
}
/* While the mobile overlay menu is open, drop the header's backdrop-filter:
   otherwise it forms a containing block that traps the fixed overlay inside it. */
body.vi-menu-open .vi-header {
	background: transparent !important;
	-webkit-backdrop-filter: none !important;
	backdrop-filter: none !important;
	border-color: transparent !important;
	box-shadow: none !important;
}
.vi-logo-img { height: 72px; width: auto; display: block; transition: height 0.4s var(--vi-ease); }
.vi-header.scrolled .vi-logo-img { height: 46px; }

.vi-nav { display: flex; align-items: center; gap: 0.12rem; }
/* links float in white; hover shows a soft glass "chip" (no underline) */
.vi-nav a:not(.vi-btn) {
	color: #fff !important; font-size: 0.88rem; font-weight: 600; white-space: nowrap;
	padding: 0.42rem 0.72rem; border-radius: 999px;
	text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
	transition: background 0.25s var(--vi-ease), text-shadow 0.25s;
}
.vi-nav a:not(.vi-btn):hover { background: rgba(255, 255, 255, 0.18); text-shadow: none; }
.vi-header.scrolled .vi-nav a:not(.vi-btn) { text-shadow: none; }
.vi-nav .vi-btn { padding: 0.5rem 1.1rem; font-size: 0.88rem; margin-left: 0.4rem; }

/* "Eventos ▾" dropdown */
.vi-navsub { position: relative; display: flex; align-items: center; }
.vi-navsub > a { display: inline-flex; align-items: center; gap: 0.3rem; }
.vi-caret { width: 0.72em; height: 0.72em; transition: transform 0.25s var(--vi-ease); opacity: 0.9; }
.vi-navsub:hover .vi-caret, .vi-navsub:focus-within .vi-caret { transform: rotate(180deg); }
.vi-navsub::after { content: ""; position: absolute; top: 100%; left: -12px; right: -12px; height: 0.6rem; } /* hover bridge */
.vi-navsub__menu {
	position: absolute; top: calc(100% + 0.45rem); left: 50%;
	display: flex; flex-direction: column; min-width: 215px;
	padding: 0.4rem; border-radius: 14px;
	background: rgba(8, 30, 52, 0.9);
	-webkit-backdrop-filter: blur(20px) saturate(1.5); backdrop-filter: blur(20px) saturate(1.5);
	border: 1px solid rgba(255, 255, 255, 0.14);
	box-shadow: 0 22px 50px -24px rgba(0, 0, 0, 0.65), inset 0 1px 0 rgba(255, 255, 255, 0.14);
	opacity: 0; visibility: hidden; transform: translateX(-50%) translateY(-6px);
	transition: opacity 0.25s var(--vi-ease), transform 0.25s var(--vi-ease), visibility 0.25s;
	z-index: 10;
}
.vi-navsub:hover .vi-navsub__menu, .vi-navsub:focus-within .vi-navsub__menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.vi-navsub__menu a { color: #fff !important; padding: 0.55rem 0.95rem !important; border-radius: 10px; font-size: 0.88rem; white-space: nowrap; text-shadow: none !important; }
.vi-navsub__menu a:hover { background: rgba(255, 255, 255, 0.16); }

@media (max-width: 1180px) and (min-width: 861px) { .vi-nav a:not(.vi-btn) { font-size: 0.84rem; padding: 0.42rem 0.62rem; } .vi-logo-img { height: 58px; } }

.vi-burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; z-index: 110; }
.vi-burger span { width: 26px; height: 2px; background: #fff; transition: transform 0.3s, opacity 0.3s, background 0.3s; }
body.vi-menu-open .vi-burger span { background: #fff; }
body.vi-menu-open .vi-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.vi-menu-open .vi-burger span:nth-child(2) { opacity: 0; }
body.vi-menu-open .vi-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ==========================================================================
   Hero
   ========================================================================== */
.vi-hero {
	position: relative; min-height: 100svh; display: flex; align-items: center;
	color: #fff; overflow: hidden;
}
.vi-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.08); animation: vi-kenburns 18s ease-out forwards; }
.vi-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4, 38, 63, 0.55) 0%, rgba(4, 38, 63, 0.35) 40%, rgba(4, 38, 63, 0.82) 100%); }
.vi-hero .vi-wrap { position: relative; z-index: 2; padding-block: 7rem 4rem; }
.vi-hero .vi-h1 { color: #fff; max-width: 16ch; }
.vi-hero .vi-eyebrow { color: var(--vi-gold-soft); }
.vi-hero__sub { font-size: clamp(1.05rem, 1.8vw, 1.3rem); max-width: 52ch; color: rgba(255, 255, 255, 0.92); margin: 0 0 2rem; }
.vi-hero__cta { display: flex; flex-wrap: wrap; gap: 0.9rem; }
.vi-scrollcue { position: absolute; left: 50%; bottom: 26px; z-index: 2; transform: translateX(-50%); width: 26px; height: 42px; border: 2px solid rgba(255, 255, 255, 0.55); border-radius: 14px; }
.vi-scrollcue::after { content: ""; position: absolute; left: 50%; top: 8px; width: 4px; height: 8px; background: #fff; border-radius: 2px; transform: translateX(-50%); animation: vi-scroll 1.8s infinite; }

@keyframes vi-kenburns { to { transform: scale(1); } }
@keyframes vi-scroll { 0% { opacity: 0; transform: translate(-50%, 0); } 40% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, 14px); } }

/* Hero load animation */
.vi-hero [data-hero] { opacity: 0; transform: translateY(26px); animation: vi-fadeup 0.9s var(--vi-ease) forwards; }
.vi-hero [data-hero="1"] { animation-delay: 0.15s; }
.vi-hero [data-hero="2"] { animation-delay: 0.32s; }
.vi-hero [data-hero="3"] { animation-delay: 0.5s; }
.vi-hero [data-hero="4"] { animation-delay: 0.68s; }
@keyframes vi-fadeup { to { opacity: 1; transform: none; } }

/* ==========================================================================
   Reveal on scroll
   ========================================================================== */
[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity 0.8s var(--vi-ease), transform 0.8s var(--vi-ease); }
[data-reveal].vi-in { opacity: 1; transform: none; }
[data-reveal][data-delay="1"] { transition-delay: 0.1s; }
[data-reveal][data-delay="2"] { transition-delay: 0.2s; }
[data-reveal][data-delay="3"] { transition-delay: 0.3s; }
[data-reveal][data-delay="4"] { transition-delay: 0.4s; }

/* ==========================================================================
   Intro
   ========================================================================== */
.vi-intro .vi-h2 { max-width: 22ch; margin-inline: auto; }
.vi-rule { width: 64px; height: 2px; background: var(--vi-gold); margin: 1.5rem auto 1.8rem; border: 0; }

/* ==========================================================================
   Espacios (cards)
   ========================================================================== */
.vi-grid { display: grid; gap: clamp(1.2rem, 2.5vw, 1.8rem); }
.vi-grid--3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.vi-card {
	background: #fff; border: 1px solid var(--vi-line); border-radius: var(--vi-radius);
	overflow: hidden; box-shadow: var(--vi-shadow-sm);
	transition: transform 0.4s var(--vi-ease), box-shadow 0.4s var(--vi-ease);
}
.vi-card:hover { transform: translateY(-8px); box-shadow: var(--vi-shadow); }
.vi-card__media { aspect-ratio: 4 / 3; overflow: hidden; }
.vi-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--vi-ease); }
.vi-card:hover .vi-card__media img { transform: scale(1.07); }
.vi-card__body { padding: 1.5rem 1.5rem 1.8rem; }
.vi-card__meta { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--vi-gold); }
.vi-card h3 { font-size: 1.4rem; margin: 0.4rem 0 0.5rem; }
.vi-card p { margin: 0; color: var(--vi-muted); font-size: 0.97rem; }

/* ==========================================================================
   Servicios (icon grid on blue)
   ========================================================================== */
.vi-section--blue { background: linear-gradient(160deg, var(--vi-blue) 0%, var(--vi-blue-deep) 100%); color: #fff; }
.vi-section--blue .vi-h2, .vi-section--blue .vi-eyebrow { color: #fff; }
.vi-section--blue .vi-eyebrow { color: var(--vi-gold-soft); }
.vi-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.4rem; margin-top: 2.5rem; }
.vi-feature { display: flex; gap: 1rem; align-items: flex-start; padding: 1.3rem; border: 1px solid rgba(255, 255, 255, 0.16); border-radius: var(--vi-radius); background: rgba(255, 255, 255, 0.04); transition: background 0.35s, border-color 0.35s; }
.vi-feature:hover { background: rgba(255, 255, 255, 0.09); border-color: rgba(216, 194, 138, 0.5); }
.vi-feature__icon { flex: 0 0 auto; width: 44px; height: 44px; display: grid; place-items: center; border-radius: 12px; background: rgba(216, 194, 138, 0.16); color: var(--vi-gold-soft); }
.vi-feature__icon svg { width: 24px; height: 24px; }
.vi-feature h3 { color: #fff; font-family: var(--vi-font-body); font-size: 1.02rem; font-weight: 600; margin: 0.15rem 0 0.25rem; }
.vi-feature p { margin: 0; font-size: 0.9rem; color: rgba(255, 255, 255, 0.75); }

/* ==========================================================================
   Galería
   ========================================================================== */
.vi-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.8rem; margin-top: 2.5rem; }
.vi-gallery a { position: relative; overflow: hidden; border-radius: 12px; aspect-ratio: 1 / 1; }
.vi-gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--vi-ease); }
.vi-gallery a:hover img { transform: scale(1.08); }
.vi-gallery a.vi-tall { grid-row: span 2; aspect-ratio: auto; }

/* Lightbox */
.vi-lightbox { position: fixed; inset: 0; z-index: 200; display: none; place-items: center; background: rgba(4, 23, 38, 0.92); padding: 5vw; opacity: 0; transition: opacity 0.3s; }
.vi-lightbox.open { display: grid; opacity: 1; }
.vi-lightbox img { max-width: 92vw; max-height: 88vh; border-radius: 8px; box-shadow: 0 30px 80px -30px rgba(0, 0, 0, 0.8); }
.vi-lightbox__close { position: absolute; top: 22px; right: 28px; width: 44px; height: 44px; border: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.12); color: #fff; font-size: 1.6rem; cursor: pointer; }

/* ==========================================================================
   Floating WhatsApp — brass circle that expands into a "Contáctanos" pill
   ========================================================================== */
body.vi-landing .joinchat { display: none !important; } /* hide the plugin's green bubble */

.vi-wa {
	position: fixed !important;
	right: clamp(14px, 3vw, 26px);
	bottom: clamp(14px, 3vw, 26px);
	z-index: 95;
	width: 60px; height: 60px;
	padding: 0 !important;
	gap: 0;
	justify-content: center;
	overflow: hidden;
	white-space: nowrap;
	transition: width 0.45s var(--vi-ease), gap 0.45s var(--vi-ease), box-shadow 0.3s var(--vi-ease), transform 0.3s var(--vi-ease);
}
.vi-wa svg { width: 30px; height: 30px; flex: 0 0 auto; }
.vi-wa__label { max-width: 0; opacity: 0; overflow: hidden; font-weight: 600; font-size: 1rem; transition: max-width 0.45s var(--vi-ease), opacity 0.3s; }
.vi-wa:hover { width: 215px; gap: 11px; transform: translateY(-2px); }
.vi-wa:hover .vi-wa__label { max-width: 175px; opacity: 1; }
@media (max-width: 860px) { .vi-wa { width: 54px; height: 54px; } .vi-wa:hover { width: 200px; } }

/* ==========================================================================
   Testimonio
   ========================================================================== */
.vi-quote { max-width: 760px; margin-inline: auto; text-align: center; }
.vi-quote__mark { font-family: var(--vi-font-head); font-size: 4rem; line-height: 0.6; color: var(--vi-gold); }
.vi-quote blockquote { font-family: var(--vi-font-head); font-size: clamp(1.3rem, 2.6vw, 1.9rem); font-style: italic; color: var(--vi-blue-deep); margin: 1rem 0 1.4rem; line-height: 1.4; }
.vi-quote cite { font-style: normal; font-weight: 600; color: var(--vi-ink); }
.vi-quote cite span { display: block; font-weight: 400; color: var(--vi-muted); font-size: 0.92rem; margin-top: 0.2rem; }

/* ==========================================================================
   CTA band
   ========================================================================== */
.vi-cta { background: linear-gradient(135deg, var(--vi-blue-deep), var(--vi-blue-ink)); color: #fff; text-align: center; border-radius: clamp(18px, 3vw, 28px); padding: clamp(2.6rem, 6vw, 4.5rem); position: relative; overflow: hidden; }
.vi-cta::before { content: ""; position: absolute; width: 360px; height: 360px; background: radial-gradient(circle, rgba(194, 161, 77, 0.35), transparent 70%); top: -120px; right: -80px; }
.vi-cta .vi-h2 { color: #fff; position: relative; }
.vi-cta p { color: rgba(255, 255, 255, 0.82); max-width: 48ch; margin: 0.6rem auto 1.8rem; position: relative; }
.vi-cta__row { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; position: relative; }

/* ==========================================================================
   Ubicación
   ========================================================================== */
.vi-loc { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.vi-loc--reverse > :first-child { order: 2; }
.vi-figure { border-radius: var(--vi-radius); overflow: hidden; box-shadow: var(--vi-shadow); aspect-ratio: 4 / 3; }
.vi-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vi-checklist { list-style: none; padding: 0; margin: 1.3rem 0 0; display: grid; gap: 0.55rem; }
.vi-checklist li { display: flex; gap: 0.7rem; align-items: flex-start; color: var(--vi-muted); font-size: 0.98rem; }
.vi-checklist li::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--vi-gold); margin-top: 0.5em; flex: 0 0 auto; }
.vi-loc__info ul { list-style: none; padding: 0; margin: 1.5rem 0 0; display: grid; gap: 1.1rem; }
.vi-loc__info li { display: flex; gap: 0.9rem; align-items: flex-start; }
.vi-loc__info svg { width: 22px; height: 22px; color: var(--vi-gold); flex: 0 0 auto; margin-top: 2px; }
.vi-loc__info b { display: block; color: var(--vi-blue-deep); }
.vi-loc__info span { color: var(--vi-muted); }
.vi-map { border-radius: var(--vi-radius); overflow: hidden; box-shadow: var(--vi-shadow-sm); border: 1px solid var(--vi-line); }
.vi-map iframe { width: 100%; height: 340px; border: 0; display: block; }

/* ==========================================================================
   Footer
   ========================================================================== */
.vi-footer { background: var(--vi-blue-ink); color: rgba(255, 255, 255, 0.72); padding-block: clamp(2.8rem, 6vw, 4rem) 1.6rem; }
.vi-footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.vi-footer h4 { color: #fff; font-family: var(--vi-font-body); font-size: 0.82rem; letter-spacing: 0.16em; text-transform: uppercase; margin: 0 0 1rem; }
.vi-footer a { color: rgba(255, 255, 255, 0.72); transition: color 0.25s; }
.vi-footer a:hover { color: var(--vi-gold-soft); }
.vi-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.55rem; font-size: 0.95rem; }
.vi-footer__brand .vi-logo-img { height: 46px; width: auto; margin-bottom: 1rem; }
.vi-footer__brand p { font-size: 0.92rem; max-width: 34ch; }
.vi-social { display: flex; gap: 0.7rem; margin-top: 1rem; }
.vi-social a { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 50%; }
.vi-social a:hover { background: var(--vi-gold); border-color: var(--vi-gold); color: #fff; }
.vi-social svg { width: 18px; height: 18px; }
.vi-footer__bottom { margin-top: 2.5rem; padding-top: 1.4rem; border-top: 1px solid rgba(255, 255, 255, 0.12); font-size: 0.85rem; display: flex; flex-wrap: wrap; gap: 1rem 1.5rem; align-items: center; justify-content: space-between; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 860px) {
	.vi-burger { display: flex; z-index: 120; }
	.vi-logo { position: relative; z-index: 120; }

	/* Full-screen overlay menu */
	.vi-nav {
		position: fixed; inset: 0; z-index: 110;
		flex-direction: column; align-items: center; justify-content: center;
		gap: 1.7rem; padding: 2rem;
		background: rgba(5, 30, 50, 0.98);
		-webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
		opacity: 0; visibility: hidden; transform: translateY(-12px);
		transition: opacity 0.35s var(--vi-ease), transform 0.35s var(--vi-ease), visibility 0s linear 0.35s;
	}
	body.vi-menu-open .vi-nav {
		opacity: 1; visibility: visible; transform: none;
		transition: opacity 0.35s var(--vi-ease), transform 0.35s var(--vi-ease);
	}
	.vi-nav a { color: #fff !important; font-size: 1.5rem; font-weight: 500; }
	.vi-nav a::after { display: none; }
	.vi-nav .vi-btn { margin-top: 1rem; font-size: 1.05rem; padding: 0.95rem 2.4rem; }
	body.vi-menu-open { overflow: hidden; }
	/* dropdown flattens inside the mobile overlay */
	.vi-navsub { flex-direction: column; align-items: center; gap: 0.7rem; }
	.vi-caret { display: none; }
	.vi-navsub::after { display: none; }
	.vi-navsub__menu {
		position: static; transform: none !important; opacity: 1; visibility: visible;
		background: none; border: none; box-shadow: none; backdrop-filter: none; -webkit-backdrop-filter: none;
		padding: 0; min-width: 0; align-items: center; gap: 0.5rem; margin-top: 0.4rem;
	}
	.vi-navsub__menu a { font-size: 1.15rem !important; color: rgba(255,255,255,0.82) !important; padding: 0.3rem !important; }

	.vi-loc { grid-template-columns: 1fr; }
	.vi-footer__top { grid-template-columns: 1fr; gap: 1.6rem; }
	.vi-footer__bottom { justify-content: flex-start; }
	.vi-gallery a.vi-tall { grid-row: span 1; aspect-ratio: 1 / 1; }
}

/* ==========================================================================
   Reduced motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
	*, [data-reveal], .vi-hero [data-hero], .vi-hero__bg { animation: none !important; transition: none !important; transform: none !important; opacity: 1 !important; }
	.vi-scrollcue { display: none; }
}
