/* =========================
   Página de Contacto (Spacio)
   ========================= */

:root {
    --spacio-yellow: #f4b400;
    --spacio-ink: #111;
    --spacio-muted: #666;
    --radius: 12px;
    font-family: 'Montserrat', sans-serif;
}

/* Contenedor principal */
.contacto-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 90px 20px 40px;
    /* deja espacio al header fijo */
}

/* Grilla de 2 columnas */
.contacto-grid {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    /* izq más ancha */
    gap: 36px;
    align-items: start;
}

/* ===== Layout de columnas con CSS Grid ===== */
.contacto-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 40px;
    align-items: start;
    /* Desktop: datos/izquierda, mapa/derecha */
    grid-template-areas: "datos mapa";
}

/* Columna izquierda */
.col-izq .contacto-brand {
    max-width: 340px;
    height: auto;
    display: block;
}

.contacto-direccion {
    margin: 14px 0 8px;
}

.contacto-datos-list {
    list-style: none;
    padding: 0;
    margin: 6px 0 18px;
    text-decoration: none !important;
}

.contacto-datos-list a {
    text-decoration: none !important;
    color: #3a3a3a;
}



.contacto-datos-list li {
    margin: 6px 0;
}

.dato-label {
    display: inline-block;
    min-width: 96px;
    color: #666;
}

/* Mapa responsive */
.mapa-embebido iframe {
    width: 100% !important;
    height: clamp(320px, 40vh, 480px);
    border: 0;
    border-radius: 10px;
    box-shadow: 0 8px 22px rgba(0, 0, 0, .08);
}

/* Columna derecha (form). Si quieres que “siga” al hacer scroll: */
.col-der {
    position: sticky;
    top: 100px;
}

/* ===== Formulario CF7 ===== */
.contacto-formulario {
    font-family: 'Montserrat', sans-serif;
    color: #3a3a3a;
    padding-top: 75px;
    margin-top: 28px;
}

.contacto-formulario h2 {
    font-size: clamp(20px, 2.6vw, 26px);
    margin: 0 0 12px 0;
}

.col-der,
.col-der * {
    box-sizing: border-box;
}

.col-der {
    min-width: 0;
}

/* evita que el contenido contraiga la columna */

.col-der .wpcf7,
.col-der .wpcf7 form,
.col-der .wpcf7-form {
    width: 100%;
    max-width: none;
}

.col-der .wpcf7-form p,
.col-der .wpcf7-form label,
.col-der .wpcf7-form .wpcf7-form-control-wrap {
    display: block;
    width: 100%;
    margin: 0 0 4px;
}

/* Inputs y selects a 100% del ancho */
.col-der .wpcf7-form input[type="text"],
.col-der .wpcf7-form input[type="email"],
.col-der .wpcf7-form input[type="tel"],
.col-der .wpcf7-form select,
.col-der .wpcf7-form textarea {
    display: block;
    width: 100% !important;
    max-width: none !important;
    padding: 10px 7px;
    border: 1px solid #cfcfcf;
    border-radius: 6px;
    font: inherit;
}

/* Altura mínima del textarea */
.col-der .wpcf7-form textarea {
    min-height: 160px;
}

/* Alineación del checkbox/acceptance y enlaces dentro */
.col-der .wpcf7-acceptance {
    margin: 6px 0 10px;
}

.col-der .wpcf7-acceptance .wpcf7-list-item {
    margin: 0;
}

/* ===== Botón morado como el resto del sitio ===== */
.col-der .wpcf7 input[type="submit"],
.col-der .wpcf7-submit {
    background: #5f2c8c;
    /* morado */
    color: #fff;
    border: 0;
    border-radius: 6px;
    padding: .85rem 2.2rem;
    font-weight: 600;
    cursor: pointer;
    transition: transform .15s ease, background .15s ease, box-shadow .15s ease;

}

.col-der .wpcf7 input[type="submit"]:hover,
.col-der .wpcf7-submit:hover {
    background: #4a1f6d;
    /* morado más oscuro */
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .12);
}

/* Por si el tema fija anchos en inputs globales, gana especificidad aquí */

.contacto-grid .col-der textarea,
.contacto-grid .col-der select {
    width: 100% !important;
}


/* ===== Responsive ===== */
@media (max-width: 768px) {
    .contacto-grid {
        grid-template-columns: 1fr;
        gap: 26px;
    }

    .col-der {
        position: static;
    }

    .mapa-embebido iframe {
        height: clamp(280px, 36vh, 420px);
    }
}

/* Accesibilidad preferencia de reduce motion */
@media (prefers-reduced-motion: reduce) {

    .icon-btn,
    .contacto-formulario .wpcf7-submit {
        transition: none;
    }
}