/**
 * Estilos para el formulario personalizado de login/registro
 */

/* Ocultar formulario predeterminado de WooCommerce */
#customer_login.col2-set {
    display: none !important;
}

/* Contenedor principal del formulario */
.custom-login-register-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin: 0 auto 30px;
    padding: 30px;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 5px;
}

.login-right .custom-login-register-wrapper {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin: 0 auto 30px;
    padding: 30px;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 5px;
}

.login-right .form-row {
    display: flex;
    flex-direction: column;
}

.login-right .register-info p {
    margin-bottom: 20px;
    line-height: 1.6;
    white-space: break-spaces;
}

/* Estilos de la columna de login */
.custom-login-column .woocommerce-form-login__rememberme {
    margin: 15px 0;
}

.custom-login-column .woocommerce-LostPassword {
    margin-top: 15px;
}

/* Botones */
.custom-login-column .woocommerce-Button,
.custom-register-column .woocommerce-Button,
.btn-show-register {
    transition: all 0.3s ease;
}

.custom-login-column .woocommerce-Button:hover,
.custom-register-column .woocommerce-Button:hover,
.btn-show-register:hover {
    background: #555 !important;
    opacity: 0.9;
}

.btn-show-login:hover {
    background: #f5f5f5 !important;
}

/* Títulos de las columnas */
.custom-login-column h3,
.custom-register-column h3 {
    margin-bottom: 20px;
    font-size: 18px;
    font-weight: 600;
    text-transform: uppercase;
}

/* Sección de información de registro */
.register-info {
    margin-bottom: 20px;
}

.register-info p {
    margin-bottom: 20px;
    line-height: 1.6;
}

/* Botón "Registrarse" */
.btn-show-register {
    width: 100%;
    padding: 12px 24px;
    background: #333;
    color: #fff;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    font-weight: 600;
}

/* Botón "Volver al login" */
.btn-show-login {
    width: 100%;
    background: transparent;
    color: #333;
    border: 1px solid #ddd;
}

/* Botón submit del formulario de registro */
.woocommerce-form-register__submit {
    width: 100%;
}

/* Control de visibilidad dinámica de columnas */
.custom-login-column.hidden {
    display: none;
}

.custom-lost-password-column.hidden {
    display: none;
}

.custom-reset-password-column.hidden {
    display: none;
}

.custom-register-column.hidden {
    display: none;
}

/* Estilos de validación de campos */
.validation-error input,
.validation-error select,
.validation-error textarea {
    border-color: #a00 !important;
    background-color: #fef5f5 !important;
}

.validation-error label {
    color: #a00;
    font-weight: 600;
}

.error-message {
    color: #a00;
    font-size: 12px;
    margin-top: 5px;
    display: block;
    font-weight: 500;
}

/* Clase para ocultar campos dinámicamente */
.campo-oculto {
    display: none !important;
}

/* Asegurarse de que estén visibles cuando necesario */
.campo-visible {
    display: block !important;
}

/* Asegurar que el asterisco sea visible */
#billing_nif_field .required,
#billing_razon_social_field .required {
    color: #c00;
    font-weight: 600;
}

/* Asegurar que el opcional desaparezca cuando son requeridos */
#billing_nif_field.validate-required .optional,
#billing_razon_social_field.validate-required .optional {
    display: none;
}

/* Asegurarse de que el input tiene estilo adecuado cuando son obligatorios */
#billing_nif_field.validate-required input,
#billing_razon_social_field.validate-required input {
    border: 1px solid #ccc;
}

p#billing_address_1_field {
    width: 100%;
    float: none;
    display: flex;
    flex-direction: column;
}

.w-html:not(.login-right) p#billing_postcode_field,
.w-html:not(.login-right) p#billing_city_field,
.w-html:not(.login-right) p#shipping_postcode_field,
.w-html:not(.login-right) p#shipping_city_field,
.w-account p#billing_postcode_field,
.w-account p#billing_city_field,
.w-account p#shipping_postcode_field,
.w-account p#shipping_city_field {
    width: 50%;
    float: left;
    box-sizing: border-box;
    clear: none;
    padding-right: .5rem;
}

.w-html:not(.login-right) p#billing_city_field,
.w-html:not(.login-right) p#shipping_city_field,
.w-account p#billing_city_field,
.w-account p#shipping_city_field {
    padding-right: 0;
}

.w-html:not(.login-right) p#billing_city_field {
    padding-left: .5rem;
}

.woocommerce-form .form-row label {
    font-weight: 500;
    font-size: 16px !important;
}

/* Error messages en formulario de reset password */
.custom-reset-password-column .woocommerce-error {
    display: block !important;
    background-color: #fee !important;
    border: 2px solid #c33 !important;
    border-left: 4px solid #c33 !important;
    color: #800 !important;
    padding: 15px !important;
    margin-bottom: 20px !important;
    border-radius: 3px !important;
    font-weight: 600 !important;
    clear: both;
}

/* Responsive */
@media (max-width: 768px) {
    .custom-login-register-wrapper {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    .w-html:not(.login-right) p#billing_postcode_field, .w-html:not(.login-right) p#billing_city_field {
        width: 100%;
        float:none;
    }

    .w-html:not(.login-right) p#billing_city_field {
        padding-left: 0;
    }
}