.formulario-container {
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px;
    background: #fdfdfd;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-family: Arial, sans-serif;
    font-size: 14px;
}

.cf7_contenedor_seccion {
    margin-bottom: 20px;
}

.cf7_contenedor_seccion h4 {
    margin-bottom: 10px;
    color: #333;
    border-bottom: 1px solid #ccc;
    padding-bottom: 5px;
}

.fila {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10px;
    gap: 15px; /* ← Espaciado entre columnas */
}

.fila.dos-columnas .columna {
    flex: 1 1 calc(50% - 7.5px); /* 2 columnas con gap */
}

.fila.tres-columnas .columna {
    flex: 1 1 calc(33.333% - 10px); /* 3 columnas con gap */
}

.fila.cuatro-columnas .columna {
    flex: 1 1 calc(25% - 11.25px); /* 4 columnas con gap */
}

/* Columnas proporcionales adicionales */
.columna-1-1 {  flex: 1 1 100%;}

.columna-1-3 { flex: 1 1 calc(33.333% - 10px); }
.columna-2-3 { flex: 1 1 calc(66.666% - 10px); }

.columna-1-4 { flex: 1 1 calc(25% - 11.25px); }
.columna-3-4 { flex: 1 1 calc(75% - 11.25px); }

.columna-1-2 { flex: 1 1 calc(50% - 7.5px); }

/* Columnas full width en móvil */
@media (max-width: 768px) {
    .fila .columna,
    .columna-1-3,
    .columna-2-3,
    .columna-1-4,
    .columna-3-4,
    .columna-1-2 {
        flex: 1 1 100%;
    }
}

input[type="text"],
input[type="email"],
input[type="number"],
select,
textarea {
    width: 100%;
    padding: 8px;
    box-sizing: border-box;
    margin-top: 4px;
    margin-bottom: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
}

textarea {
    min-height: 80px;
}

input[type="submit"] {
    background-color: #0073aa;
    color: white;
    padding: 10px 20px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

input[type="submit"]:hover {
    background-color: #005177;
}

.acceptance-wrap {
    margin-top: 10px;
}

.acceptance-wrap label {
    font-size: 13px;
}

/* Estilo para mensajes visuales */
.mensaje-confirmacion,
.mensaje-error {
    padding: 12px 16px;
    margin-bottom: 20px;
    border-left: 5px solid;
    border-radius: 4px;
    font-size: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.mensaje-confirmacion {
    background-color: #dff0d8;
    border-color: #3c763d;
    color: #3c763d;
}

.mensaje-error {
    background-color: #f2dede;
    border-color: #a94442;
    color: #a94442;
}

.mensaje-confirmacion::before,
.mensaje-error::before {
    font-family: 'Arial';
    font-weight: bold;
    font-size: 20px;
    display: inline-block;
}

.mensaje-confirmacion::before {
    content: "✔️";
}

.mensaje-error::before {
    content: "⚠️";
}

/* Aviso antes de enviar */
.aviso-informativo {
    background-color: #fcfcfc;
    border: 1px solid #ccc;
    padding: 15px 18px;
    border-radius: 4px;
    font-size: 13px;
    line-height: 1.6;
    color: #333;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.aviso-informativo p {
    margin: 0 0 10px;
}

.aviso-informativo p:last-child {
    margin-bottom: 0;
}


/**/
.fila ul {
    padding-left: 20px;
    margin-bottom: 15px;
}

.fila ul li {
    margin-bottom: 8px;
    line-height: 1.5;
}
