/* ──────────────────────────────────────────────────────────────────
 * FloresYa — Contacto Stitch v2 styles (2026-04-26)
 * Hero + Layout 2-col (form + aside cards) + Location section
 * ────────────────────────────────────────────────────────────────── */

.fy-contacto-page {
	font-family: 'Plus Jakarta Sans', sans-serif;
	color: var(--fy-on-surface, #1b1c1c);
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px 80px;
}

/* ── HERO ─────────────────────────────────────────────────────── */
.fy-contacto-hero {
	max-width: 720px;
	padding: 64px 0 48px;
}

.fy-contacto-hero__title {
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.1;
	margin: 0 0 16px;
}

.fy-contacto-hero__lead {
	font-size: 18px;
	line-height: 1.6;
	color: var(--fy-on-surface-variant, #594048);
	margin: 0;
}

/* ── LAYOUT 2-COL ─────────────────────────────────────────────── */
.fy-contacto-grid {
	display: grid;
	grid-template-columns: 7fr 5fr;
	gap: 32px;
	align-items: start;
	margin-bottom: 80px;
}

@media (max-width: 900px) {
	.fy-contacto-grid { grid-template-columns: 1fr; }
}

.fy-contacto-form-wrap {
	background: #fff;
	padding: 32px;
	border-radius: 20px;
	box-shadow: 0 4px 20px rgba(135, 114, 116, 0.08);
	border: 1px solid var(--fy-outline-variant, #e1bdc7);
}
.fy-contacto-form__heading {
	font-family: 'Plus Jakarta Sans', sans-serif !important;
	font-size: 22px !important;
	font-weight: 700 !important;
	margin: 0 0 20px !important;
	color: var(--fy-on-surface, #1b1c1c) !important;
}

/* ── ASIDE CARDS ──────────────────────────────────────────────── */
.fy-contacto-aside {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.fy-contacto-card {
	background: #fff;
	padding: 24px;
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(135, 114, 116, 0.08);
	display: flex;
	gap: 16px;
	transition: box-shadow 200ms ease, transform 200ms ease;
}
.fy-contacto-card:hover {
	box-shadow: 0 8px 30px rgba(135, 114, 116, 0.12);
	transform: translateY(-2px);
}

.fy-contacto-card__icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--fy-surface-container-low, #f6f3f2);
	display: flex;
	align-items: center;
	justify-content: center;
}
.fy-contacto-card__icon .material-symbols-outlined { color: var(--fy-primary, #b70068); font-size: 24px; }

.fy-contacto-card--wa .fy-contacto-card__icon { background: rgba(0, 134, 103, 0.10); }
.fy-contacto-card--wa .fy-contacto-card__icon .material-symbols-outlined { color: #006b51; }

.fy-contacto-card--email .fy-contacto-card__icon { background: rgba(183, 0, 104, 0.10); }

.fy-contacto-card__body { flex: 1; min-width: 0; }
.fy-contacto-card__body h3 {
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 6px;
}
.fy-contacto-card__body p {
	font-size: 13px;
	color: var(--fy-on-surface-variant, #594048);
	margin: 0 0 8px;
}
.fy-contacto-card__link {
	color: var(--fy-primary, #b70068) !important;
	font-weight: 700;
	font-size: 16px;
	text-decoration: none !important;
}
.fy-contacto-card__link:hover { text-decoration: underline !important; }

/* Social card */
.fy-contacto-card--social {
	flex-direction: column;
	gap: 16px;
}
.fy-contacto-card__social-head {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--fy-on-surface-variant, #594048);
	margin: 0;
}
.fy-contacto-social-grid {
	display: flex;
	gap: 12px;
}
.fy-contacto-social-grid a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	border: 1px solid var(--fy-outline-variant, #e1bdc7);
	color: var(--fy-on-surface-variant, #594048) !important;
	transition: background 200ms ease, color 200ms ease, border-color 200ms ease;
	text-decoration: none !important;
}
.fy-contacto-social-grid a:hover {
	background: var(--fy-primary, #b70068);
	border-color: var(--fy-primary, #b70068);
	color: #fff !important;
}

/* ── MAP CARD en aside (reemplaza location section duplicada 2026-04-27) ── */
.fy-contacto-card--map {
	flex-direction: column !important;
	gap: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
}
.fy-contacto-card__map-iframe iframe {
	display: block !important;
	width: 100% !important;
	border: 0 !important;
}
.fy-contacto-card__map-body {
	padding: 16px 20px 20px !important;
}
.fy-contacto-card__map-body h3 {
	font-size: 16px !important;
	font-weight: 700 !important;
	margin: 0 0 4px !important;
}
.fy-contacto-card__map-body p {
	font-size: 13px !important;
	color: var(--fy-on-surface-variant, #594048) !important;
	margin: 0 0 10px !important;
}
.fy-contacto-card__map-link {
	display: inline-flex !important;
	align-items: center;
	gap: 6px !important;
	color: var(--fy-primary, #b70068) !important;
	font-weight: 700 !important;
	font-size: 13px !important;
	text-decoration: none !important;
}
.fy-contacto-card__map-link:hover { text-decoration: underline !important; }
/* 2026-05-01: Hide ALL WPForms anti-spam fields (legacy honeypot + antispam_v3) */
form[id^="wpforms-form-"] [class*="wpforms-field-hp"],
form[id^="wpforms-form-"] [id$="-field-hp-container"],
form[id^="wpforms-form-"] [id$="-field-hp"],
form[id^="wpforms-form-"] label[for$="-field-hp"],
form[id^="wpforms-form-"] [id="wpforms-1057-field_3-container"],
form[id^="wpforms-form-"] [id="wpforms-1057-field_3"],
form[id^="wpforms-form-"] label[for="wpforms-1057-field_3"] {
    position: absolute !important;
    left: -99999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    clip: rect(0,0,0,0) !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* 2026-05-01: Bulletproof grid — ensure 2 columns at desktop */
@media (min-width: 901px) {
    .fy-contacto-grid {
        display: grid !important;
        grid-template-columns: 7fr 5fr !important;
        gap: 32px !important;
        align-items: start !important;
    }
    .fy-contacto-form-wrap,
    .fy-contacto-aside {
        min-width: 0 !important;
    }
}

/* 2026-05-01: Escape WP is-layout-constrained — fy-contacto-page debe ser full-width */
.entry-content.is-layout-constrained > .fy-contacto-page,
.entry-content > .fy-contacto-page,
.is-layout-constrained > .fy-contacto-page {
    max-width: 1200px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.fy-contacto-page {
    max-width: 1200px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 24px;
}

/* 2026-05-01 v2: Bulletproof escape WP block layout constraint */
body.fy-page-contacto .entry-content,
body.fy-page-contacto .is-layout-constrained,
body.fy-page-contacto .wp-block-post-content {
    max-width: none !important;
}
body.fy-page-contacto .entry-content > *,
body.fy-page-contacto .is-layout-constrained > *,
body.fy-page-contacto .wp-block-post-content > * {
    max-width: none !important;
}
body.fy-page-contacto .ct-container-full,
body.fy-page-contacto .ct-container {
    max-width: 1200px !important;
}
body.fy-page-contacto .fy-contacto-page {
    max-width: 1200px !important;
    width: 100% !important;
}
@media (min-width: 901px) {
    body.fy-page-contacto .fy-contacto-grid {
        display: grid !important;
        grid-template-columns: minmax(0, 7fr) minmax(0, 5fr) !important;
        gap: 32px !important;
    }
}

/* Also make sure WPForms confirmation message NEVER hidden by our honeypot CSS */
.wpforms-confirmation-container,
.wpforms-confirmation-container-full,
[id^="wpforms-confirmation-"] {
    position: static !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    clip: auto !important;
}

/* 2026-05-01 v4: Force explicit grid placement — bypasses any auto-flow or width issue */
@media (min-width: 901px) {
    body.fy-page-contacto .fy-contacto-form-wrap {
        grid-column: 1 / 2 !important;
        grid-row: 1 !important;
    }
    body.fy-page-contacto .fy-contacto-aside {
        grid-column: 2 / 3 !important;
        grid-row: 1 !important;
    }
    body.fy-page-contacto .fy-contacto-grid > * {
        min-width: 0 !important;
        max-width: none !important;
    }
}

/* WPForms AJAX confirmation — styled and always visible */
.fy-contacto-form-wrap .wpforms-confirmation-container-full,
.fy-contacto-form-wrap .wpforms-confirmation-container,
#wpforms-confirmation-1057,
.wpforms-container .wpforms-confirmation-container-full {
    display: block !important;
    position: static !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    clip: auto !important;
    padding: 24px 20px !important;
    border-radius: 12px !important;
    background: #fdf2f6 !important;
    border: 1px solid #e1bdc7 !important;
    color: #1b1c1c !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    text-align: center !important;
    margin-top: 0 !important;
}
