/* =============================================================
   CONTACT — diseño Pencil. Prefijo .ctx
   ============================================================= */
.ctx {
	--ctx-blue:    var(--son-primary-blue, #232B1E);
	--ctx-green:   var(--son-secondary-green, #AA7E42);
	--ctx-burg:    var(--son-deep-burgundy, #8A6632);
	--ctx-rose:    var(--son-rose-red, #AA7E42);
	--ctx-bg:      var(--son-background, #F4F1E4);
	--ctx-surface: var(--son-surface, #FFFFFF);
	--ctx-text:    var(--son-text, #2A3726);
	--ctx-text-2:  var(--son-text-secondary, #6B6B52);
	--ctx-border:  var(--son-border-subtle, #D8D2BC);
	--ctx-accent:  var(--son-accent-green, #D1B178);
	--ctx-head:    var(--son-font-heading, 'Cormorant Garamond', serif);
	--ctx-body:    'Inter', sans-serif;
	--ctx-shadow:  0 1.6rem 4rem rgba(27,33,23,.12);
	background: var(--ctx-bg); color: var(--ctx-text); font-family: var(--ctx-body);
}
.ctx-eyebrow { font-size: 1.3rem; font-weight: 600; letter-spacing: .24em; text-transform: uppercase; color: var(--cv-gold-dark, #8A6632); margin-bottom: 1.4rem; }
.ctx-eyebrow--light { color: var(--cv-gold-light, #D1B178); }
.ctx-h2 { font-family: var(--ctx-head); font-size: clamp(3.2rem, 4vw, 5rem); font-weight: 500; line-height: 1.05; color: var(--ctx-text); }
.ctx-head { text-align: center; max-width: 64rem; margin: 0 auto 4.8rem; }

/* Botones */
.ctx-btn { display: inline-flex; align-items: center; justify-content: center; gap: 1rem; font-size: 1.5rem; font-weight: 600; letter-spacing: .04em; padding: 1.6rem 3.2rem; border-radius: 100px; text-decoration: none; border: none; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.ctx-btn:hover { transform: translateY(-2px); }
.ctx-btn--gold { background: var(--cv-gold, #AA7E42); color: #fff; box-shadow: 0 1rem 2.4rem rgba(170,126,66,.32); }
.ctx-btn--gold:hover { background: var(--cv-gold-dark, #8A6632); }
.ctx-btn--glass { background: transparent; color: var(--cv-cream, #F7F4C1); border: 1.5px solid rgba(247,244,193,.5); }
.ctx-btn--glass:hover { background: rgba(247,244,193,.12); }
.ctx-btn--full { width: 100%; }
.ctx-btn .cusvib-ic { width: 1.7rem; height: 1.7rem; }

/* ═══ HERO (oscuro, centrado) ═══ */
.ctx-hero { background: var(--cv-forest, #232B1E); color: var(--cv-cream, #F7F4C1); text-align: center; padding: 8rem 4rem 9rem; }
.ctx-hero__inner { max-width: 72rem; margin-inline: auto; }
.ctx-hero__title { font-family: var(--ctx-head); font-size: clamp(4.4rem, 6.5vw, 7rem); font-weight: 500; line-height: 1; margin-bottom: 1.8rem; color: var(--cv-cream, #F7F4C1); }
.ctx-hero__sub { font-size: 1.7rem; line-height: 1.6; color: var(--cv-muted-dark, #B8B89C); max-width: 52ch; margin-inline: auto; }

/* ═══ 3 CANALES (call / email / whatsapp) ═══ */
.ctx-channels { background: var(--ctx-bg); padding: 5.6rem 4rem 0; }
.ctx-channels__grid { max-width: 120rem; margin-inline: auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.4rem; }
.ctx-channel { display: flex; flex-direction: column; align-items: flex-start; gap: .6rem; background: var(--cv-card, #FBF9EF); border: 1px solid var(--cv-hairline-light, #D8D2BC); border-radius: 1.6rem; padding: 3rem; }
.ctx-channel__icon { width: 5.2rem; height: 5.2rem; border-radius: 999px; background: var(--cv-forest, #232B1E); color: var(--cv-gold-light, #D1B178); display: grid; place-items: center; margin-bottom: 1.6rem; }
.ctx-channel__icon .cusvib-ic { width: 2.2rem; height: 2.2rem; }
.ctx-channel__label { font-size: 1.2rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--cv-gold-dark, #8A6632); }
.ctx-channel__value { font-family: var(--ctx-head); font-size: 2.4rem; font-weight: 600; color: var(--ctx-text); text-decoration: none; transition: color .2s ease; }
.ctx-channel__value:hover { color: var(--cv-gold, #AA7E42); }
.ctx-channel__note { font-size: 1.35rem; color: var(--ctx-text-2); margin-top: .3rem; }

/* ═══ MAIN (form + oficina + mapa) ═══ */
.ctx-main { background: var(--ctx-bg); padding: 5.6rem 4rem 7rem; }
.ctx-main__grid { max-width: 120rem; margin-inline: auto; display: grid; grid-template-columns: 1.6fr 1fr; gap: 3.2rem; align-items: start; }

/* Formulario */
.ctx-formcard { background: var(--cv-card, #FBF9EF); border: 1px solid var(--cv-hairline-light, #D8D2BC); border-radius: 2.4rem; padding: 4rem; box-shadow: 0 1.6rem 4rem rgba(27,33,23,.06); }
.ctx-formcard__title { font-family: var(--ctx-head); font-size: 3.2rem; font-weight: 600; color: var(--ctx-text); margin-bottom: .8rem; }
.ctx-formcard__sub { font-size: 1.5rem; line-height: 1.5; color: var(--ctx-text-2); margin-bottom: 2.8rem; }
.ctx-form { display: flex; flex-direction: column; gap: 2rem; }
.ctx-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.ctx-form label { display: flex; flex-direction: column; gap: .8rem; }
.ctx-form label span { font-size: 1.35rem; font-weight: 600; color: var(--ctx-text); }
.ctx-form input, .ctx-form textarea { font-family: inherit; font-size: 1.5rem; padding: 1.4rem 1.6rem; border: 1px solid var(--cv-hairline-light, #D8D2BC); border-radius: 1.2rem; background: var(--cv-light, #F4F1E4); color: var(--ctx-text); transition: border-color .2s ease; }
.ctx-form input::placeholder, .ctx-form textarea::placeholder { color: var(--ctx-text-2); opacity: .7; }
.ctx-form input:focus, .ctx-form textarea:focus { outline: none; border-color: var(--cv-gold, #AA7E42); }
.ctx-form textarea { resize: vertical; min-height: 13rem; }
.ctx-form__notice { display: flex; align-items: center; gap: 1rem; padding: 1.4rem 1.8rem; border-radius: 1.2rem; font-size: 1.5rem; font-weight: 500; }
.ctx-form__notice--ok { background: rgba(157,186,60,.14); color: #5b7016; }
.ctx-form__notice--err { background: rgba(192,57,43,.12); color: #C0392B; }
.ctx-form__notice .cusvib-ic { width: 2rem; height: 2rem; }

/* Columna derecha: oficina + mapa */
.ctx-aside { display: flex; flex-direction: column; gap: 2.4rem; }
.ctx-office { background: var(--cv-forest, #232B1E); color: var(--cv-light-text, #EFEAD6); border-radius: 1.6rem; padding: 3.2rem; }
.ctx-office__title { font-family: var(--ctx-head); font-size: 2.6rem; font-weight: 600; color: var(--cv-cream, #F7F4C1); margin-bottom: 2.2rem; }
.ctx-office__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2rem; }
.ctx-office__list li { display: flex; align-items: flex-start; gap: 1.4rem; }
.ctx-office__ic { width: 3.6rem; height: 3.6rem; border-radius: 999px; background: rgba(170,126,66,.18); color: var(--cv-gold-light, #D1B178); display: grid; place-items: center; flex-shrink: 0; }
.ctx-office__ic .cusvib-ic { width: 1.8rem; height: 1.8rem; }
.ctx-office__list li span { display: flex; flex-direction: column; gap: .3rem; }
.ctx-office__list strong { font-size: 1.5rem; font-weight: 600; color: var(--cv-cream, #F7F4C1); }
.ctx-office__list em { font-size: 1.35rem; font-style: normal; color: var(--cv-muted-dark, #B8B89C); }
.ctx-map { position: relative; display: block; min-height: 22rem; border-radius: 1.6rem; overflow: hidden;
	background-color: var(--cv-forest, #232B1E);
	background-image: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
	background-size: 4rem 4rem; }
.ctx-map__pin { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 5rem; height: 5rem; border-radius: 999px; background: var(--cv-gold, #AA7E42); color: #fff; display: grid; place-items: center; box-shadow: 0 .8rem 2rem rgba(0,0,0,.3); }
.ctx-map__pin .cusvib-ic { width: 2.2rem; height: 2.2rem; }

/* ═══ FAQ ═══ */
.ctx-faqsec { background: var(--cv-cream-soft, #EDE8CF); padding: 9rem 4rem; }
.ctx-faq { max-width: 80rem; margin-inline: auto; display: flex; flex-direction: column; gap: 1.4rem; }
.ctx-faq__item { background: var(--cv-card, #FBF9EF); border: 1px solid var(--cv-hairline-light, #D8D2BC); border-radius: 1.4rem; overflow: hidden; }
.ctx-faq__q { width: 100%; background: none; border: none; cursor: pointer; padding: 2.2rem 2.6rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; text-align: left; font-family: var(--ctx-head); font-size: 2rem; font-weight: 600; color: var(--ctx-text); }
.ctx-faq__ic { width: 1.9rem; height: 1.9rem; color: var(--cv-gold-dark, #8A6632); transition: transform .3s ease; flex-shrink: 0; }
.ctx-faq__item.is-open .ctx-faq__ic { transform: rotate(45deg); }
.ctx-faq__a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.ctx-faq__item.is-open .ctx-faq__a { max-height: 80rem; }
.ctx-faq__a p { padding: 0 2.6rem 2.4rem; font-size: 1.55rem; line-height: 1.65; color: var(--ctx-text-2); }

/* ═══ CTA (oscuro) ═══ */
.ctx-cta { background: var(--cv-forest, #232B1E); color: var(--cv-cream, #F7F4C1); padding: 9rem 4rem; text-align: center; }
.ctx-cta__inner { max-width: 64rem; margin-inline: auto; }
.ctx-cta__title { font-family: var(--ctx-head); font-size: clamp(3.4rem, 4.5vw, 5rem); font-weight: 500; line-height: 1.05; margin: 1rem 0 1.6rem; color: var(--cv-cream, #F7F4C1); }
.ctx-cta__sub { font-size: 1.6rem; line-height: 1.6; color: var(--cv-muted-dark, #B8B89C); margin-bottom: 3rem; }
.ctx-cta__buttons { display: flex; gap: 1.6rem; justify-content: center; flex-wrap: wrap; }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1024px) {
	.ctx-channels__grid { grid-template-columns: 1fr; }
	.ctx-main__grid { grid-template-columns: 1fr; }
	.ctx-formcard { padding: 3.2rem; }
}
@media (max-width: 680px) {
	.ctx-form__row { grid-template-columns: 1fr; }
	.ctx-hero, .ctx-channels, .ctx-main, .ctx-faqsec, .ctx-cta { padding-inline: 2.4rem; }
}

/* =============================================================
   CUSTOM SELECT (.cusvib-cs) — dropdown estilizado para el form
   de testimonios. Enhancement JS; oculta el <select> nativo.
   ============================================================= */
.ctx-form .cusvib-cs { position: relative; width: 100%; }
/* select nativo oculto pero presente para el submit (JS lo mueve dentro de .cusvib-cs) */
.ctx-form .cusvib-cs select { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); border: 0; }
/* si JS no corre, el select sigue visible y usable */
.ctx-form select { display: block; }

.ctx-form .cusvib-cs__trigger {
	display: flex; align-items: center; justify-content: space-between; gap: 1rem;
	width: 100%; font-family: inherit; font-size: 1.5rem; text-align: left;
	padding: 1.4rem 1.6rem; border: 1px solid var(--ctx-border); border-radius: 1.2rem;
	background: var(--ctx-bg); color: var(--ctx-text); cursor: pointer;
	transition: border-color .2s ease;
}
.ctx-form .cusvib-cs.is-open .cusvib-cs__trigger,
.ctx-form .cusvib-cs__trigger:focus-visible { outline: none; border-color: var(--ctx-green); }
.ctx-form .cusvib-cs__label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ctx-form .cusvib-cs__label--placeholder { color: var(--ctx-text-2); }
.ctx-form .cusvib-cs__chevron { width: 1.6rem; height: 1.6rem; flex-shrink: 0; color: var(--ctx-text-2); transition: transform .2s ease; }
.ctx-form .cusvib-cs.is-open .cusvib-cs__chevron { transform: rotate(180deg); }

.ctx-form .cusvib-cs__list {
	position: absolute; top: calc(100% + .6rem); left: 0; right: 0; z-index: 50;
	max-height: 28rem; overflow-y: auto; margin: 0; padding: .6rem; list-style: none;
	background: var(--ctx-surface); border: 1px solid var(--ctx-border); border-radius: 1.2rem;
	box-shadow: 0 1.6rem 4rem rgba(27,33,23,.18);
	opacity: 0; visibility: hidden; transform: translateY(-.4rem);
	transition: opacity .15s ease, transform .15s ease, visibility .15s;
}
.ctx-form .cusvib-cs.is-open .cusvib-cs__list { opacity: 1; visibility: visible; transform: translateY(0); }
.ctx-form .cusvib-cs__option {
	list-style: none; padding: 1.1rem 1.4rem; border-radius: .8rem; font-size: 1.5rem; color: var(--ctx-text);
	cursor: pointer; transition: background .12s ease, color .12s ease;
}
.ctx-form .cusvib-cs__option::marker { content: none; }
/* anula el bullet verde de .page-prose ul > li cuando el form vive dentro de una página */
.page-prose .cusvib-cs__list { padding-left: .6rem; }
.page-prose .cusvib-cs__option { position: static; padding-left: 1.4rem; }
.page-prose .cusvib-cs__option::before { display: none; content: none; }
.ctx-form .cusvib-cs__option--placeholder { color: var(--ctx-text-2); }
.ctx-form .cusvib-cs__option.is-active { background: var(--ctx-bg); }
.ctx-form .cusvib-cs__option:hover { background: var(--ctx-green); color: #fff; }
.ctx-form .cusvib-cs__option.is-selected { font-weight: 600; color: var(--ctx-green); }
.ctx-form .cusvib-cs__option.is-selected.is-active,
.ctx-form .cusvib-cs__option.is-selected:hover { color: #fff; }

/* scrollbar fina */
.ctx-form .cusvib-cs__list::-webkit-scrollbar { width: .8rem; }
.ctx-form .cusvib-cs__list::-webkit-scrollbar-thumb { background: var(--ctx-border); border-radius: .8rem; }

/* ── multi-select (checkboxes) ── */
.ctx-form .cusvib-cs--multi .cusvib-cs__option {
	display: flex; align-items: center; gap: 1rem;
}
/* en multi NO pintamos toda la fila de verde; solo hover/active sutil */
.ctx-form .cusvib-cs--multi .cusvib-cs__option:hover,
.ctx-form .cusvib-cs--multi .cusvib-cs__option.is-active { background: var(--ctx-bg); color: var(--ctx-text); }
.ctx-form .cusvib-cs--multi .cusvib-cs__option.is-selected { font-weight: 500; color: var(--ctx-text); }
.ctx-form .cusvib-cs--multi .cusvib-cs__option.is-selected.is-active,
.ctx-form .cusvib-cs--multi .cusvib-cs__option.is-selected:hover { color: var(--ctx-text); }
.ctx-form .cusvib-cs__optlabel { flex: 1; min-width: 0; }
.ctx-form .cusvib-cs__check {
	flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center;
	width: 2rem; height: 2rem; border: 2px solid var(--ctx-border); border-radius: .5rem;
	background: #fff; transition: background .12s ease, border-color .12s ease;
}
.ctx-form .cusvib-cs__checkmark { width: 1.4rem; height: 1.4rem; color: #fff; opacity: 0; transition: opacity .12s ease; }
.ctx-form .cusvib-cs__option.is-selected .cusvib-cs__check { background: var(--ctx-green); border-color: var(--ctx-green); }
.ctx-form .cusvib-cs__option.is-selected .cusvib-cs__checkmark { opacity: 1; }
/* anula el bullet verde de .page-prose también en los <li> con check */
.page-prose .cusvib-cs--multi .cusvib-cs__option { padding-left: 1.4rem; }
