/* =====================================================
   BLOQUE: Contacto
   Metodología: Desktop First
   Breakpoint móvil: max-width 1023px
   ===================================================== */

/* Variables CSS del proyecto */
:root {
    --ct-azul: var(--wp--preset--color--custom-azul, #005E9E);
    --ct-celeste: var(--wp--preset--color--custom-celeste, #00BFFF);
    --ct-verde: var(--wp--preset--color--custom-verde, #40bc84);
    --ct-negro: var(--wp--preset--color--custom-negro, #242424);
    --ct-corridos: var(--wp--preset--color--custom-corridos, #272727);
    --ct-font-barlow: var(--wp--preset--font-family--barlow, 'Barlow', sans-serif);
    --ct-wide-size: var(--wp--style--global--wide-size, 1285px);
}

/* Reset base del bloque */
.contacto,
.contacto-editor {
    box-sizing: border-box;
    width: 100%;
}

.contacto *,
.contacto-editor * {
    box-sizing: border-box;
}

/* =====================================================
   SECCIÓN: Contenedor principal
   ===================================================== */
.contacto,
.contacto-editor {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding-top: var(--ct-padding-top, 115px);
    padding-bottom: var(--ct-padding-bottom, 100px);
    padding-left: 20px;
    padding-right: 20px;
    background-color: rgba(0, 191, 255, 0.05);
}

.contacto__contenedor {
    display: flex;
    gap: var(--ct-gap, 110px);
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    max-width: var(--ct-wide-size);
}

/* =====================================================
   SECCIÓN: Bloque izquierdo - Textos
   ===================================================== */
.contacto__textos {
    display: flex;
    flex-direction: column;
    gap: 7px;
    flex: 1;
}

.contacto__volanta {
    font-size: var(--ct-volanta-size, 40px);
    line-height: 0.9;
    text-transform: uppercase;
    color: var(--ct-negro);
    margin: 0;
}

.contacto__titulo {
    font-size: var(--ct-titulo-size, 90px);
    line-height: 0.9;
    text-transform: uppercase;
    color: var(--ct-azul);
    margin: 0;
}

.contacto__bajada {
    font-family: var(--ct-font-barlow);
    font-weight: 400;
    font-size: var(--ct-bajada-size, 18px);
    line-height: 1.35;
    color: var(--ct-negro);
    margin: 0;
}

/* =====================================================
   SECCIÓN: Bloque derecho - Formulario
   ===================================================== */
.contacto__formulario-wrapper {
    display: flex;
    flex-direction: column;
    gap: 19px;
    align-items: center;
    justify-content: center;
    width: 650px;
    flex-shrink: 0;
    background-color: white;
    border-radius: 5px;
    padding-top: var(--ct-form-padding-top, 35px);
    padding-bottom: var(--ct-form-padding-bottom, 100px);
    padding-left: var(--ct-form-padding-lr, 45px);
    padding-right: var(--ct-form-padding-lr, 45px);
}

/* =====================================================
   SECCIÓN: Botonera
   ===================================================== */
.contacto__botonera {
    display: flex;
    gap: 10px;
    align-items: center;
    width: 100%;
}

.contacto__boton {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    height: 50px;
    padding: 12px 24px;
    border-radius: 5px;
    font-size: 26px;
    line-height: 0.9;
    text-transform: uppercase;
    letter-spacing: 0.26px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 2px solid var(--ct-azul);
    background-color: transparent;
    color: var(--ct-azul);
}

.contacto__boton:hover {
    transform: scale(1.03);
}

.contacto__boton--activo {
    background-color: var(--ct-azul);
    color: #fff;
    border-color: var(--ct-azul);
}

/* =====================================================
   SECCIÓN: Preview del formulario (Editor)
   ===================================================== */
.contacto__form-preview {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.contacto__campo {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.contacto__label {
    font-family: var(--ct-font-barlow);
    font-weight: 500;
    font-size: 14px;
    line-height: 1.4;
    color: var(--ct-corridos);
}

.contacto__input {
    display: flex;
    align-items: center;
    height: 70px;
    padding: 0 25px;
    background-color: #fff;
    border-radius: 5px;
    font-family: var(--ct-font-barlow);
    font-weight: 500;
    font-size: 18px;
    color: #000;
}

.contacto__textarea {
    display: flex;
    align-items: flex-start;
    height: 190px;
    padding: 20px 25px;
    background-color: #fff;
    border-radius: 5px;
    font-family: var(--ct-font-barlow);
    font-weight: 500;
    font-size: 18px;
    color: #000;
}

.contacto__submit-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    width: 100%;
}

.contacto__submit {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: center;
    height: 69px;
    padding: 18px 27px;
    background-color: var(--ct-azul);
    border: none;
    border-radius: 5px;
    font-size: 36px;
    line-height: 0.9;
    text-transform: uppercase;
    color: #fff;
    cursor: pointer;
    transition: transform 0.2s ease;
}

.contacto__submit:hover {
    transform: scale(1.03);
}

.contacto__submit svg {
    width: 26px;
    height: 26px;
    transform: rotate(45deg);
}

/* =====================================================
   SECCIÓN: Formulario real (Frontend - Gravity Forms)
   ===================================================== */
.contacto__formulario-container {
    width: 100%;
}

/* Estilos Gravity Forms con !important */
.contacto__formulario-container {
    margin: 0 !important;
    padding: 0 !important;
}

.contacto__formulario-container .gform_body {
    margin: 0 !important;
}

.contacto__formulario-container .gform_fields {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    grid-row-gap: 10px !important;
}

.contacto__formulario-container .gfield {
    margin: 0 !important;
    padding: 0 !important;
}

.contacto__formulario-container .gfield_label {
    font-family: var(--ct-font-barlow) !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    color: var(--ct-corridos) !important;
    margin-bottom: 10px !important;
}

.contacto__formulario-container input[type="text"],
.contacto__formulario-container input[type="email"],
.contacto__formulario-container input[type="tel"],
.contacto__formulario-container input[type="number"],
.contacto__formulario-container input[type="url"],
.contacto__formulario-container select {
    height: 70px !important;
    padding: 0 25px !important;
    background-color: #fff !important;
    border: none !important;
    border-radius: 5px !important;
    font-family: var(--ct-font-barlow) !important;
    font-weight: 500 !important;
    font-size: 18px !important;
    color: #000 !important;
    width: 100% !important;
}

.contacto__formulario-container textarea {
    height: 190px !important;
    padding: 20px 25px !important;
    background-color: #fff !important;
    border: none !important;
    border-radius: 5px !important;
    font-family: var(--ct-font-barlow) !important;
    font-weight: 500 !important;
    font-size: 18px !important;
    color: #000 !important;
    width: 100% !important;
    resize: none !important;
}

.contacto__formulario-container input::placeholder,
.contacto__formulario-container textarea::placeholder {
    color: #999 !important;
}

.contacto__formulario-container .gform_footer {
    display: flex !important;
    justify-content: flex-end !important;
    margin: 0 !important;
    padding: 10px 0 0 0 !important;
}

.contacto__formulario-container .gform_footer input[type="submit"],
.contacto__formulario-container .gform_button {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 69px !important;
    padding: 18px 27px !important;
    background-color: var(--ct-azul) !important;
    border: none !important;
    border-radius: 5px !important;
    font-family: "gazzetta-variable", sans-serif !important;
    font-size: 36px !important;
    line-height: 0.9 !important;
    text-transform: uppercase !important;
    color: #fff !important;
    cursor: pointer !important;
    transition: transform 0.2s ease !important;
}

.contacto__formulario-container .gform_footer input[type="submit"]:hover,
.contacto__formulario-container .gform_button:hover {
    transform: scale(1.03) !important;
}

/* Ocultar elementos innecesarios de GF */
.contacto__formulario-container .gform_required_legend,
.contacto__formulario-container .gfield_required {
    display: none !important;
}

/* Validación de campos */
.contacto__formulario-container .gfield_error input,
.contacto__formulario-container .gfield_error textarea {
    border: 2px solid #d63638 !important;
}

.contacto__formulario-container .gfield_error .gfield_label {
    color: #d63638 !important;
}

.contacto__formulario-container .validation_message {
    font-family: var(--ct-font-barlow) !important;
    font-size: 12px !important;
    color: #d63638 !important;
    margin-top: 5px !important;
}

/* Loading state */
.contacto__formulario-container.is-loading {
    opacity: 0.6;
    pointer-events: none;
}

/* =====================================================
   RESPONSIVE: Mobile (max-width: 1023px)
   ===================================================== */
@media (max-width: 1023px) {
    .contacto,
    .contacto-editor {
        padding-top: var(--ct-padding-top-mobile, 60px);
        padding-bottom: var(--ct-padding-bottom-mobile, 60px);
    }

    .contacto__contenedor {
        flex-direction: column;
        gap: var(--ct-gap-mobile, 40px);
    }

    .contacto__textos {
        width: 100%;
    }

    .contacto__volanta {
        font-size: var(--ct-volanta-size-mobile, 24px);
    }

    .contacto__titulo {
        font-size: var(--ct-titulo-size-mobile, 48px);
    }

    .contacto__bajada {
        font-size: var(--ct-bajada-size-mobile, 16px);
    }

    .contacto__formulario-wrapper {
        width: 100%;
        padding-top: var(--ct-form-padding-top-mobile, 25px);
        padding-bottom: var(--ct-form-padding-bottom-mobile, 60px);
        padding-left: var(--ct-form-padding-lr-mobile, 20px);
        padding-right: var(--ct-form-padding-lr-mobile, 20px);
    }

    .contacto__boton {
        font-size: 20px;
        height: 44px;
        padding: 10px 18px;
    }

    .contacto__input {
        height: 56px;
        font-size: 16px;
    }

    .contacto__textarea {
        height: 150px;
        font-size: 16px;
    }

    .contacto__submit {
        font-size: 28px;
        height: 56px;
        padding: 14px 22px;
    }

    .contacto__submit svg {
        width: 20px;
        height: 20px;
    }

    /* Gravity Forms Mobile */
    .contacto__formulario-container input[type="text"],
    .contacto__formulario-container input[type="email"],
    .contacto__formulario-container input[type="tel"],
    .contacto__formulario-container input[type="number"],
    .contacto__formulario-container input[type="url"],
    .contacto__formulario-container select {
        height: 56px !important;
        font-size: 16px !important;
    }

    .contacto__formulario-container textarea {
        height: 150px !important;
        font-size: 16px !important;
    }

    .contacto__formulario-container .gform_footer input[type="submit"],
    .contacto__formulario-container .gform_button {
        font-size: 28px !important;
        min-height: 56px !important;
        padding: 14px 22px !important;
    }
}

/* =====================================================
   EDITOR: Estilos específicos del editor
   ===================================================== */
.contacto-editor .contacto__volanta:empty::before,
.contacto-editor .contacto__titulo:empty::before,
.contacto-editor .contacto__bajada:empty::before {
    color: #999;
}

.contacto-editor .contacto__boton {
    pointer-events: none;
}

.contacto-editor .contacto__submit {
    pointer-events: none;
}
