
/*!
 * Bootstrap v3.3.7 (http://getbootstrap.com)
 * Copyright 2011-2016 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */

@font-face {
    font-family: 'TitilliumWeb-Black';
    src: url('TitilliumWeb-Black.eot');
    src: url('TitilliumWeb-Black.eot') format('embedded-opentype'), url('TitilliumWeb-Black.woff2') format('woff2'), url('TitilliumWeb-Black.woff') format('woff'), url('TitilliumWeb-Black.ttf') format('truetype'), url('TitilliumWeb-Black.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-Bold';
    src: url('TitilliumWeb-Bold.eot');
    src: url('TitilliumWeb-Bold.eot') format('embedded-opentype'), url('TitilliumWeb-Bold.woff2') format('woff2'), url('TitilliumWeb-Bold.woff') format('woff'), url('TitilliumWeb-Bold.ttf') format('truetype'), url('TitilliumWeb-Bold.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-BoldItalic';
    src: url('TitilliumWeb-BoldItalic.eot');
    src: url('TitilliumWeb-BoldItalic.eot') format('embedded-opentype'), url('TitilliumWeb-BoldItalic.woff2') format('woff2'), url('TitilliumWeb-BoldItalic.woff') format('woff'), url('TitilliumWeb-BoldItalic.ttf') format('truetype'), url('TitilliumWeb-BoldItalic.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-ExtraLight';
    src: url('TitilliumWeb-ExtraLight.eot');
    src: url('TitilliumWeb-ExtraLight.eot') format('embedded-opentype'), url('TitilliumWeb-ExtraLight.woff2') format('woff2'), url('TitilliumWeb-ExtraLight.woff') format('woff'), url('TitilliumWeb-ExtraLight.ttf') format('truetype'), url('TitilliumWeb-ExtraLight.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-ExtraLightItalic';
    src: url('TitilliumWeb-ExtraLightItalic.eot');
    src: url('TitilliumWeb-ExtraLightItalic.eot') format('embedded-opentype'), url('TitilliumWeb-ExtraLightItalic.woff2') format('woff2'), url('TitilliumWeb-ExtraLightItalic.woff') format('woff'), url('TitilliumWeb-ExtraLightItalic.ttf') format('truetype'), url('TitilliumWeb-ExtraLightItalic.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-Italic';
    src: url('TitilliumWeb-Italic.eot');
    src: url('TitilliumWeb-Italic.eot') format('embedded-opentype'), url('TitilliumWeb-Italic.woff2') format('woff2'), url('TitilliumWeb-Italic.woff') format('woff'), url('TitilliumWeb-Italic.ttf') format('truetype'), url('TitilliumWeb-Italic.svg#OpenSans') format('svg');
}


@font-face {
    font-family: 'TitilliumWeb-Light';
    src: url('TitilliumWeb-Light.eot');
    src: url('TitilliumWeb-Light.eot') format('embedded-opentype'), url('TitilliumWeb-Light.woff2') format('woff2'), url('TitilliumWeb-Light.woff') format('woff'), url('TitilliumWeb-Light.ttf') format('truetype'), url('TitilliumWeb-Light.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-LightItalic';
    src: url('TitilliumWeb-LightItalic.eot');
    src: url('TitilliumWeb-LightItalic.eot') format('embedded-opentype'), url('TitilliumWeb-LightItalic.woff2') format('woff2'), url('TitilliumWeb-LightItalic.woff') format('woff'), url('TitilliumWeb-LightItalic.ttf') format('truetype'), url('TitilliumWeb-LightItalic.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-Regular';
    src: url('TitilliumWeb-Regular.eot');
    src: url('TitilliumWeb-Regular.eot') format('embedded-opentype'), url('TitilliumWeb-Regular.woff2') format('woff2'), url('TitilliumWeb-Regular.woff') format('woff'), url('TitilliumWeb-Regular.ttf') format('truetype'), url('TitilliumWeb-Regular.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-SemiBold';
    src: url('TitilliumWeb-SemiBold.eot');
    src: url('TitilliumWeb-SemiBold.eot') format('embedded-opentype'), url('TitilliumWeb-SemiBold.woff2') format('woff2'), url('TitilliumWeb-SemiBold.woff') format('woff'), url('TitilliumWeb-SemiBold.ttf') format('truetype'), url('TitilliumWeb-SemiBold.svg#OpenSans') format('svg');
}

@font-face {
    font-family: 'TitilliumWeb-SemiBoldItalic';
    src: url('TitilliumWeb-SemiBoldItalic.eot');
    src: url('TitilliumWeb-SemiBoldItalic.eot') format('embedded-opentype'), url('TitilliumWeb-SemiBoldItalic.woff2') format('woff2'), url('TitilliumWeb-SemiBoldItalic.woff') format('woff'), url('TitilliumWeb-SemiBoldItalic.ttf') format('truetype'), url('TitilliumWeb-SemiBoldItalic.svg#OpenSans') format('svg');
}

/* Colores constantes*/
:root {
    --circle-size: 32px;
    --color: #707070;
    --color-green-zona: #15A48D; /* Verde Coorporatico ZonaVirtual */
}

/**/

body,
html {
    min-height: 95%
}

body {
    margin: 0px;
    font-family: "TitilliumWeb-Regular";
    font-size: 14px;
    color: #d4d4d4;
    /*color: #777;
	background-color: #FFF;
    text-align: justify;
	padding-bottom: 200px;
    min-height: 100vh;
    line-height: 20pt;*/
    position: relative;
    background-image: url('./Graficas/fondo_tesoreria.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
}

@media (max-width: 768px) {
    body {
        background-position: right;
    }
}

.pilitic-container input[type=checkbox] {
    accent-color: #15A48D;
}

hr {
    margin-top: -1rem;
}

.pie_pagina {
    width: 100%;
    margin-top: auto;
}

.row {
    margin-right: 0px !important;
    margin-left: 0px !important;
}

.pmz_contenido_ppal {
    width: 1000px;
    margin: auto;
    overflow: hidden;
}

.pmz_bold {
    font-family: "TitilliumWeb-SemiBold";
    color: #000;
    line-height: 20pt;
}

.pmz_normal {
    font-family: "TitilliumWeb-Regular";
    color: #777;
    line-height: 20pt;
    font-weight: bold;
    display: flex;
    justify-content: left;
}


.pmz_negro {
    font-family: "TitilliumWeb-Regular";
    color: #000;
    line-height: 20pt;
}

.pmz_negro_bold_pg {
    font-family: "TitilliumWeb-SemiBold";
    color: #000;
    line-height: 23pt;
    text-align: right;
}

.pmz_gris_normal_pg {
    font-family: "TitilliumWeb-Regular";
    color: #777;
    line-height: 23pt;
    text-align: right;
}

.pmz_bold_gris {
    font-family: "TitilliumWeb-SemiBold";
    color: #777;
}


.pmz_bold_gris2 {
    font-family: "TitilliumWeb-SemiBold";
    color: #777;
}

.pmz_bold_verde {
    font-family: "TitilliumWeb-SemiBold";
    color: #40aea6;
    line-height: 20pt;
}

.pmz_bold_rojo {
    font-family: "TitilliumWeb-SemiBold";
    color: #D90000;
    line-height: 20pt;
}

.error-message {
    color: red;
    display: none;
    font-weight: bold;
    font-size: 12px;
}

.error-input {
    border: 1px solid red !important;
}

.pmz_bold_naranja {
    font-family: "TitilliumWeb-SemiBold";
    color: #FF9326;
    line-height: 20pt;
}

.pmz_bold_pendiente {
    font-family: "TitilliumWeb-SemiBold";
    color: #F2B628;
    line-height: 20pt;
}

.pmz_caja_general {
    margin: auto;
    border: 1px solid #F1F1F1;
}

.pmz_div_gnral {
    width: 100%;
    overflow: hidden;
    margin: auto;
    text-align: center;
    font-size: 12px;
}

.pmz_div_gnral2 {
    width: 100%;
    overflow: hidden;
    margin: 0 auto;
}

.pmz_btn_imprimir {
    background-color: #AAA;
    color: #fff;
    text-align: center;
    padding-top: 5px;
    padding-bottom: 5px;
    border: 1px solid #AAA;
    margin-bottom: 20px;
    margin-top: 20px;
    width: 180px;
}

a:hover {
    text-decoration: none;
    color: #000;
}

a:active {
    text-decoration: none;
    color: #000;
}

a:link {
    text-decoration: none;
    display: flex;
    align-items: center;
    width: fit-content;
}

.pmz_titulo_ventana {
    font-family: "TitilliumWeb-SemiBold";
    font-size: 1.8em;
    color: #000;
    letter-spacing: 3px;
}

.pmz_campo_desple_banco {
    width: 318px;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
}

.pmz_campo_desple {
    height: 32px;
    margin-top: 2px;
    width: 100%;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
}

.pmz_campo_desple_vence {
    margin-top: 2px;
    height: 32px;
    width: 75px;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
    margin-right: 2em;
}

.quota-container {
    width: 100px;
}

.date-end-tc {
    position: relative;
    min-height: 1px;
    padding-right: 5px;
    padding-left: 5px;
    float: left;
    width: 24%;
}

.date-end-tc-year {
    margin-top: 2px;
    height: 32px;
    width: 70px;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
    margin-right: 10px;
}

.date-end-tc-month {
    margin-top: 2px;
    height: 32px;
    width: 70px;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
    margin-right: 0;
}

.pmz_campo_desple_exp {
    width: 98px;
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
}

.pmz_campo_new_valor {
    width: 100%;
    border: 1px solid #999;
    padding: 2px;
    text-align: right;
    margin-top: 3px;
    margin-bottom: 3px;
    height: 30px;
}

.pmz_campo_desple_cod {
    height: 32px;
    margin-top: 2px;
    width: 100%;
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 2px;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
    background-image: url("Graficas/cod_seguridad.gif");
    background-repeat: no-repeat;
    background-position: right;
}

.pmz_boton {
    background-color: #AAA;
    border-bottom: 1px solid #DDD;
    border-top: 1px solid #AAA;
    border-left: 1px solid #AAA;
    border-right: 1px solid #AAA;
    color: #FFF;
    width: 20%;
    text-align: center;
    letter-spacing: 1.5px;
    border-radius: 0px;
    margin-top: 20px;
}

.pmz_boton1 {
    background-color: #AAA;
    border-bottom: 1px solid #DDD;
    border-top: 1px solid #AAA;
    border-left: 1px solid #AAA;
    border-right: 1px solid #AAA;
    color: #FFF;
    width: 300px;
    text-align: center;
    letter-spacing: 3px;
    border-radius: 0px;
    margin: auto;
    margin-bottom: 10px;
}

.pmz_boton2 {
    background-color: #AAA;
    border-bottom: 1px solid #DDD;
    border-top: 1px solid #AAA;
    border-left: 1px solid #AAA;
    border-right: 1px solid #AAA;
    color: #FFF;
    width: 200px;
    text-align: center;
    letter-spacing: 3px;
    border-radius: 0px;
    margin: auto;
    margin-bottom: 10px;
}

.btn-pay-bill {
    width: 150px !important;
    justify-content: center !important;
}

.btn {
    background-color: var(--color-green-zona);
    color: #fff;
    font-weight: bold;
    border: 2px solid var(--color-green-zona);
    border-radius: 20px;
    padding: 0 14px;
    cursor: pointer;
    max-width: 180px;
    justify-content: center;
    margin: 0 auto;
    min-height: 38px;
    align-content: center;
    letter-spacing: 1px;
    font-size: 14px;
}

    .btn:hover {
        background-color: #fff;
        color: var(--color-green-zona);
        font-weight: bold;
        border: 2px solid var(--color-green-zona);
        border-radius: 20px;
        padding: 0 14px;
        cursor: pointer;
        min-width: 130px;
        justify-content: center;
        margin: 0 auto;
        min-height: 38px;
        align-content: center;
    }

        .btn:hover > img {
            filter: invert(40%) sepia(32%) saturate(512%) hue-rotate(112deg) brightness(94%) contrast(90%);
        }

.pmz_div_izq {
    width: 40%;
    float: left;
    overflow: auto;
    line-height: 23pt;
}

.pmz_div_der {
    width: 60%;
    float: right;
    overflow: auto;
}

.pmz_div_izq3 {
    width: 25%;
    float: left;
    overflow: auto;
    line-height: 23pt;
    text-align: left;
    padding-right: 15px;
}

.pmz_div_der2 {
    width: 40%;
    float: right;
    text-align: right;
    overflow: hidden;
}

.pmz_div_der3 {
    width: 70%;
    float: right;
    overflow: auto;
}

.pmz_div_izq2 {
    width: 47%;
    float: left;
    overflow: auto;
    text-align: right;
    padding-right: 20px;
}

.pmz_terminos_final {
    overflow: auto;
    padding-top: 20px;
    margin: auto;
}

.pmz_terminos_ventana {
    height: 600px;
    overflow-y: scroll;
    padding: 30px;
}

.pmz_boton_alertas {
    margin: auto;
    text-align: center;
    padding-top: 50px;
    padding: 20px;
}

@media(max-width: 500px) {
    .pmz_campo_desple_vence {
        width: 100%;
        margin-right: 0;
    }

    .pilitic-container > span {
        display: block;
        margin: 0 4px;
    }
}

@media(max-width:768px) {
    .btn {
        min-width: 90px !important;
    }

        .btn:hover {
            min-width: 90px !important;
        }

    .quota-container {
        width: 50%;
    }

    .pmz_contenido_ppal {
        width: 90%;
        margin: auto;
        padding-top: 40px;
        height: 70px;
    }

    .pmz_bold {
        font-family: "TitilliumWeb-SemiBold";
        color: #000;
        line-height: 20pt;
    }

    .pmz_normal {
        font-family: "TitilliumWeb-Regular";
        color: #777;
        line-height: 20pt;
        display: grid;
    }


    .pmz_negro {
        font-family: "TitilliumWeb-Regular";
        color: #000;
        line-height: 20pt;
    }

    .pmz_negro_bold_pg {
        font-family: "TitilliumWeb-SemiBold";
        color: #000;
        line-height: 23pt;
        text-align: right;
    }

    .pmz_gris_normal_pg {
        font-family: "TitilliumWeb-Regular";
        color: #777;
        line-height: 23pt;
        text-align: left;
    }

    .pmz_bold_gris {
        font-family: "TitilliumWeb-SemiBold";
        color: #777;
        line-height: 20pt;
    }

    .pmz_bold_gris2 {
        font-family: "TitilliumWeb-SemiBold";
        color: #777;
    }

    .pmz_bold_verde {
        font-family: "TitilliumWeb-SemiBold";
        color: #40aea6;
        line-height: 20pt;
    }

    .pmz_bold_rojo {
        font-family: "TitilliumWeb-SemiBold";
        color: #D90000;
        line-height: 20pt;
    }

    .pmz_bold_pendiente {
        font-family: "TitilliumWeb-SemiBold";
        color: #F2B628;
        line-height: 20pt;
    }

    .pmz_bold_naranja {
        font-family: "TitilliumWeb-SemiBold";
        color: #FF9326;
        line-height: 20pt;
    }

    .pmz_caja_general {
        margin: auto;
        border: 1px solid #F1F1F1;
    }

    .pmz_div_gnral {
        width: 100%;
        overflow: hidden;
        margin: auto;
        text-align: center;
    }

    .pmz_div_gnral2 {
        width: 100%;
        overflow: hidden;
        margin: 0 auto;
    }

    .pmz_btn_imprimir {
        background-color: #AAA;
        color: #fff;
        text-align: center;
        padding-top: 5px;
        padding-bottom: 5px;
        border: 1px solid #AAA;
        margin-bottom: 20px;
        margin-top: 20px;
        widows: 180px;
    }

    a:hover {
        text-decoration: none;
        color: #000;
    }

    a:active {
        text-decoration: none;
        color: #000;
    }

    .pmz_titulo_ventana {
        font-family: "TitilliumWeb-SemiBold";
        font-size: 1.8em;
        color: #000;
        letter-spacing: 3px;
    }

    .pmz_campo_desple_banco {
        width: 100%;
        padding: 2px;
        background-color: #fff;
        border: 1px solid #ccc;
        border-radius: 4px;
        font-family: "TitilliumWeb-Regular";
    }

    .pmz_campo_desple {
        font-family: "TitilliumWeb-Regular";
        height: 32px;
        margin-top: 2px;
        width: 100%;
        padding: 2px;
        background-color: #fff;
        border: 1px solid #ccc;
        border-radius: 4px;
    }

    .pmz_campo_new_valor {
        width: 100%;
        border: 1px solid #999;
        padding: 2px;
        text-align: left;
        margin-top: 3px;
        margin-bottom: 3px;
    }

    .pmz_campo_desple_cod {
        margin-top: 2px;
        height: 32px;
        padding: 2px 6px;
        border-radius: 6px;
        border: 1px solid #c7c7c7;
        font-size: 13px;
        width: 95%;
        font-family: "TitilliumWeb-Regular";
        background-image: url("Graficas/cod_seguridad.gif");
        background-repeat: no-repeat;
        background-position: right;
    }

    .pmz_boton {
        background-color: var(--color-green-zona);
        border: 2px solid var(--color-green-zona);
        color: #FFF;
        text-align: center;
        letter-spacing: 1.5px;
        border-radius: 20px;
    }

    .pmz_boton1 {
        background-color: #AAA;
        border-bottom: 1px solid #DDD;
        border-top: 1px solid #AAA;
        border-left: 1px solid #AAA;
        border-right: 1px solid #AAA;
        color: #FFF;
        width: 200px;
        text-align: center;
        letter-spacing: 3px;
        border-radius: 0px;
        margin: auto;
        margin-bottom: 10px;
    }

    .pmz_boton2 {
        background-color: #AAA;
        border-bottom: 1px solid #DDD;
        border-top: 1px solid #AAA;
        border-left: 1px solid #AAA;
        border-right: 1px solid #AAA;
        color: #FFF;
        width: 200px;
        text-align: center;
        letter-spacing: 3px;
        border-radius: 0px;
        margin: auto;
        margin-bottom: 10px;
    }

    .pmz_div_izq {
        width: 100%;
        float: left;
        overflow: auto;
        line-height: 23pt;
    }

    .pmz_div_der {
        width: 100%;
        float: right;
        overflow: auto;
    }

    .pmz_div_izq3 {
        width: 30%;
        float: left;
        overflow: auto;
        line-height: 23pt;
        text-align: right;
        padding-right: 15px;
    }

    .pmz_div_der2 {
        width: 50%;
        float: right;
        text-align: left;
        overflow: hidden;
    }

    .pmz_div_der3 {
        width: 60%;
        float: right;
        overflow: auto;
    }

    .pmz_div_izq2 {
        width: 50%;
        float: left;
        overflow: auto;
        text-align: left;
        padding-right: 20px;
    }

    .pmz_terminos_final {
        overflow: auto;
        padding-top: 20px;
        margin: auto;
        text-align: center;
    }

    .pmz_terminos_ventana {
        height: 80%;
        overflow-y: scroll;
        padding: 30px;
    }


    .pmz_boton_alertas {
        margin: auto;
        text-align: center;
        padding-top: 20px;
    }
}


/*** ENCABEZADO ***/

.pmz_enca_supe {
    width: 100%;
    margin: auto;
    /*background-image: url("Graficas/fondo_superior.png");
	background-repeat: repeat-x;*/
    min-height: 7em;
    background-position: bottom;
    background-color: white;
}

.pmz_enca_conte {
    width: 1000px;
    margin: auto;
    overflow: hidden;
    padding-top: 20px;
}

.pmz_enca_logo_clien {
    float: left;
}

.pmz_enca_datos_bienve {
    float: none;
}

.pmz_bienvenido_cliente {
    width: 100%;
}

.pmz_texto_bienvenido::before {
    font-family: "TitilliumWeb-Regular";
    color: #000;
    line-height: 20pt;
    padding-right: 5px;
}

.pmz_adios_cliente {
    width: 100%;
}

    .pmz_adios_cliente::before {
        content: "Vuelva pronto ";
        font-family: "TitilliumWeb-Regular";
        color: #000;
        line-height: 20pt;
        padding-right: 5px;
    }

.pmz_idiomas {
    border: 1px #F8F8F8 solid;
    width: 120px;
    background-repeat: no-repeat;
    background-position: 77px;
    text-transform: uppercase;
}

.pmz_datos_pago_seguro {
    width: 250px;
    float: right;
    padding-top: 10px;
}

.pmz_espacio_candado {
    width: 140px;
    float: left;
    padding-top: 3px;
    display: flex;
    align-items: center;
}

    .pmz_espacio_candado > span {
        margin-right: 4px;
    }

.pmz_candado {
    font-size: 1px;
    position: relative;
    border-radius: 3px;
    border: 3.5px solid #686868;
    border-right-width: 8.5px;
    border-left-width: 4.5px;
    margin: 0 10px 6px 0;
}

    .pmz_candado:before {
        content: "";
        box-sizing: border-box;
        position: absolute;
        border: 3px solid #686868;
        width: 10px;
        height: 11px;
        left: 50%;
        margin-left: -3px;
        top: -8px;
        border-top-left-radius: 7px;
        border-top-right-radius: 7px;
    }
/*
.pmz_candado:after {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: 1px solid #AAA;
  border-radius: 2.5px;
  left: 50%;
  top: -1px;
  margin-left: -2.5px;
}
*/
.pmz_paga_seg::before {
    width: 50%;
    float: left;
    padding-top: 5px;
}

.pmz_logo_zona_enca {
    background-image: url("Graficas/logo_zona_encabezado.png");
    background-repeat: no-repeat;
    width: 40%;
    height: 45px;
    float: right;
    margin-top: -30px;
}

.pmz_logo_banco {
    display: none;
}

@media(min-height: 632px) {
    .central-body-login {
        min-height: calc(97vh - 160px);
    }

    .central-body-cp {
        min-height: calc(72vh - 160px);
    }

    .body-bills, #Contenido_Pendientes_UpTransaPte {
        min-height: calc(97vh - 158px);
    }
}

@media(max-height: 633px) {
    .step:not(:last-child)::after {
        top: 18%;
        left: 23%;
        width: 86%;
    }

    .central-body-login {
        min-height: calc(100vh - 107px);
    }

    .central-body-cp {
        min-height: calc(84vh - 30px);
    }

    .body-bills, #Contenido_Pendientes_UpTransaPte {
        min-height: calc(94vh - 190px);
    }
}

@media(min-height: 945px) {
    .step:not(:last-child)::after {
        left: 17%;
        width: 89%;
    }

    .central-body-login, .central-body-cp {
        min-height: calc(96vh - 123px);
    }

    .body-bills, #Contenido_Pendientes_UpTransaPte {
        min-height: calc(91vh - 153px);
    }
}

@media (min-width: 1920px) {
    .central-body-login {
        min-height: calc(100vh - 120px);
    }

    .body-bills, #Contenido_Pendientes_UpTransaPte, .central-body-cp {
        min-height: calc(90vh - 150px);
    }
}

@media(max-width:768px) {
    .col-sm-12, .col-md-12 {
        padding-right: 0;
        padding-left: 0;
    }

    .pmz_enca_supe {
        width: 100%;
        margin: auto;
        /*background-image: url("Graficas/fondo_superior.png");
		background-repeat: repeat-x;*/
        min-height: 7em;
        background-position: bottom;
        background-color: white;
    }

    .pmz_enca_conte {
        width: 100%;
        margin: auto;
        overflow: hidden;
        padding-top: 10px;
    }

    .pmz_enca_logo_clien {
        float: none;
        text-align: center;
        margin-bottom: 0px;
        clear: both;
        height: 80px;
        padding-top: 10px;
        width: 100%
    }

    .pmz_enca_datos_bienve {
        float: none;
        width: 100%;
        position: relative;
    }

    .pmz_bienvenido_cliente {
        width: 100%;
        clear: both;
        text-align: center;
        padding-top: 25px;
        padding-bottom: 10px;
    }

    .pmz_texto_bienvenido::before {
        visibility: hidden !important;
        content: "";
        font-family: none;
        color: none;
        line-height: none;
        padding-right: none;
    }

    .pmz_idiomas {
        border: 1px #F8F8F8 solid;
        width: 120px;
        background-repeat: no-repeat;
        background-position: 77px;
        text-transform: uppercase;
    }

    .pmz_datos_pago_seguro {
        width: 0px;
        float: none;
        padding-top: 0px;
        visibility: hidden !important;
    }
}

/*** FIN ENCABEZADO ***/

/*** MENU DEL PROCESO ***/

.pmz_proceso_cuatro {
    width: 810px;
    float: left;
}

.pmz_procesos_pago1 {
    float: left;
    width: 20%;
    text-align: left;
}

.pmz_procesos_pago2 {
    float: left;
    width: 30%;
    text-align: left;
}

.pmz_procesos_pago3 {
    float: left;
    width: 30%;
    text-align: left;
}

.pmz_procesos_pago4 {
    float: left;
    width: 20%;
    text-align: left;
}

.pmz_proceso_activo {
    padding-left: 23px;
    background-image: url("Graficas/proceso_activo.gif");
    background-position: left;
    background-repeat: no-repeat;
    color: #000;
    margin-right: 20px;
}

.pmz_proceso_inactivo {
    padding-left: 23px;
    background-image: url("Graficas/proceso_inactivo.gif");
    background-position: left;
    background-repeat: no-repeat;
    color: #f1f1f1;
    margin-right: 20px;
}

.pmz_menu_inicio {
    float: right;
    width: 150px;
    text-align: right;
    margin: 5px 2rem;
}

.pmz_btn_inicio {
    text-decoration: none;
    color: var(--color-green-zona);
}

.content-goback {
    height: 3em;
    align-content: center;
    padding-left: 6vw;
    font-weight: bold;
}

    .content-goback > a:hover {
        color: #23527c;
        text-decoration: none;
    }

.pmz_tiempo {
    background-image: url(Graficas/reloj.gif);
    height: 30px;
    width: 30px;
    float: left;
    background-position: right;
    background-repeat: no-repeat;
}

.pmz_ayuda {
    background-image: url("Graficas/ayuda.gif");
    background-position: right;
    background-repeat: no-repeat;
    color: #AAA;
}

@media(max-width:768px) {

    .pmz_proceso_tres {
        width: 0%;
        float: none;
        visibility: hidden !important;
    }

    .pmz_menu_inicio {
        float: none;
        width: 100%;
        text-align: left;
    }

    .pmz_btn_inicio {
        text-decoration: none;
        color: var(--color-green-zona);
    }

    .pmz_menu_tm {
        width: 100%;
        padding-left: 25%;
    }

    .pmz_tiempo {
        background-image: url(Graficas/reloj.gif);
        height: 30px;
        width: 30px;
        float: left;
        background-position: right;
        background-repeat: no-repeat;
    }

    .pmz_ayuda {
        background-image: url("Graficas/ayuda.gif");
        background-position: right;
        background-repeat: no-repeat;
        color: #AAA;
    }
}

/*** FIN MENU DEL PROCESO ***/

/*** POP UP PREGUNTAS FRECUENTES ***/
.modal-content-cp {
    width: 70%;
    margin: auto;
    margin-top: 50px;
    padding: 30px;
}

@media(max-width:768px) {
    .modal-content-cp {
        width: 90%;
        margin: auto;
        margin-top: 50px;
        padding: 30px;
    }
}
/* Style the Image Used to Trigger the Modal */
#myImg {
    border-radius: 5px;
    cursor: pointer;
    transition: 0.3s;
}

    #myImg:hover {
        opacity: 0.7;
    }

/* The Modal (background) */
.modal1 {
    display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 1; /* Sit on top */
    padding-top: 100px; /* Location of the box */
    left: 0;
    top: 0;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.9); /* Black w/ opacity */
}

/* Modal Content (Image) */
.modal-content1 {
    margin: auto;
    display: block;
    width: 80%;
    max-width: 700px;
}

/* Caption of Modal Image (Image Text) - Same Width as the Image */
#caption {
    margin: auto;
    display: block;
    width: 80%;
    max-width: 700px;
    text-align: center;
    color: #ccc;
    padding: 10px 0;
    height: 150px;
}

/* Add Animation - Zoom in the Modal */
.modal-content1, #caption {
    animation-name: zoom;
    animation-duration: 0.6s;
}

@keyframes zoom {
    from {
        transform: scale(0)
    }

    to {
        transform: scale(1)
    }
}

/* The Close Button */
.close1 {
    position: absolute;
    top: 15px;
    right: 35px;
    color: #f1f1f1;
    font-size: 40px;
    font-weight: bold;
    transition: 0.3s;
}

    .close1:hover,
    .close1:focus {
        color: #bbb;
        text-decoration: none;
        cursor: pointer;
    }

@media(max-width:768px) {

    .modal-content {
        width: 80%;
        margin: auto;
        margin-top: 50px;
        padding: 10px;
    }

    .modal-header {
        padding-bottom: 20px;
        border-bottom: 2px solid #e5e5e5;
        text-align: center;
    }

    .close {
        font-size: 30px;
        border: 1 solid #F8F8F8;
        border-radius: 100px;
        background-color: #AAA;
    }

    .preguntas {
        color: #000;
        font-family: "TitilliumWeb-SemiBold";
        line-height: 10px;
    }

    h3 {
        font-size: 20px;
        text-align: left;
        line-height: 30px;
        text-transform: lowercase;
    }
}

/*** FIN POP UP PREGUNTAS FRECUENTES ***/

/*** CONTENIDO CENTRAL ***/

/* Estilos cuando .pmz_general NO es hijo directo  Formularios*/
.pmz_general {
    position: relative;
    width: 65%;
    min-width: 22em;
    background-color: white;
    box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
    margin: 4px auto;
    padding: 2em 3em;
    border: 1px solid #ccc;
    border-radius: 1.5em;
    border-top: 3em solid #15A48D;
}

    /* Agrega el texto "TUS DATOS" cuando .pmz_general NO es hijo directo */
    .pmz_general::before {
        content: "TUS DATOS";
        position: absolute;
        top: -30px;
        left: 50%;
        transform: translateX(-50%);
        color: white;
        font-weight: bold;
        font-size: 16px;
        border-radius: 4px;
    }

/* Cuando .pmz_general ES hijo directo de .central-body-login, elimina los estilos anteriores */
.central-body-login > .pmz_general, .body-login > .pmz_general, .card-general > .pmz_general {
    overflow: hidden;
    margin: auto;
    box-shadow: none;
    border: none;
    padding: initial;
    background-color: initial;
    width: auto;
    border-radius: initial;
}

    /* Remueve la línea superior y el texto "TUS DATOS" */
    .central-body-login > .pmz_general::before, .body-login > .pmz_general::before, .card-general > .pmz_general::before {
        content: none;
    }


.pmz_conten_izqui {
    width: 732px;
    overflow: auto;
    padding-right: 30px;
    float: left;
}

.pmz_conten_derech {
    width: 268px;
    overflow: auto;
    float: right;
}

.pmz_detalle_pago {
    overflow: hidden;
    border-bottom: 2px solid #F1F1F1;
    padding-bottom: 15px;
}

.pmz_medios_pagos_psetc {
    overflow: auto;
    padding-top: 20px;
}

.pmz_recuadro_info {
    overflow: auto;
    border: 1px solid #F1F1F1;
    margin-top: 20px;
    padding-top: 20px;
    padding-bottom: 30px;
    padding-left: 15px;
    padding-right: 15px;
}

.pmz_izqu_pse {
    width: 30%;
    float: left;
    border-right: 1px solid #F1F1F1;
    line-height: 45px;
    overflow: auto;
}

.pmz_dere_pse {
    width: 70%;
    float: right;
    overflow: auto;
    padding-left: 20px;
    line-height: 40px;
}

.pmz_img_tc {
    background-image: url("Graficas/tarjetas_credito.gif");
    background-repeat: no-repeat;
    width: 230px;
    height: 30px;
    margin-bottom: 1.5em;
}

.pmz_izquier_tc {
    width: 50%;
    float: left;
    overflow: auto;
    padding-right: 30px;
}

.pmz_dere_tc {
    width: 50%;
    float: right;
    overflow: auto;
}

.pmz_deta_pag_total {
    text-align: right;
    color: #000;
    font-family: "TitilliumWeb-SemiBold";
    line-height: 23pt;
}

.control-label {
    padding-bottom: 30px;
}

.pmz_deta_nuevo_valor {
    width: 20%;
    float: left;
}

@media(max-width:768px) {

    .pmz_conten_izqui {
        width: 100%;
        overflow: auto;
        padding-right: 30px;
        float: left;
    }

    .pmz_conten_derech {
        width: 90%;
        overflow: auto;
        float: none;
        margin: auto;
        clear: both;
        padding-top: 30px;
    }

    .pmz_detalle_pago {
        overflow: hidden;
        border-bottom: 2px solid #F1F1F1;
        padding-bottom: 0px;
        margin: auto;
        width: 90%;
    }

    .pmz_medios_pagos_psetc {
        overflow: auto;
        padding-top: 20px;
        margin: auto;
        width: 90%;
    }

    .pmz_recuadro_info {
        overflow: auto;
        border: 1px solid #F1F1F1;
        margin-top: 20px;
        padding-top: 20px;
        padding-bottom: 30px;
        padding-left: 15px;
        padding-right: 15px;
    }

    .pmz_izqu_pse {
        width: 100%;
        float: none;
        border-right: none;
        line-height: 30px;
        overflow: auto;
        margin-bottom: 20px;
    }

    .pmz_dere_pse {
        width: 100%;
        float: none;
        overflow: auto;
        padding-left: 0px;
        line-height: 30px;
    }

    .pmz_img_tc {
        background-image: url("Graficas/tarjetas_credito.gif");
        background-repeat: no-repeat;
        width: 230px;
        height: 30px;
    }

    .pmz_izquier_tc {
        width: 100%;
        float: none;
        overflow: auto;
        padding-right: 0px;
        margin-bottom: 25px;
    }

    .pmz_dere_tc {
        width: 100%;
        float: right;
        overflow: auto;
    }

    .pmz_deta_pag_total {
        text-align: right;
        color: #000;
        font-family: "TitilliumWeb-SemiBold";
        line-height: 23pt;
    }

    .control-label {
        padding-bottom: 30px;
    }

    .pmz_deta_nuevo_valor {
        width: 20%;
        float: left;
    }
}


/*** FIN CONTENIDO CENTRAL ***/


/*** RECURRENCIAS ***/

.pmz_ggral_recurrencias {
    width: 700px;
    margin: auto;
    overflow: hidden;
    border: 1px solid #F1F1F1;
    padding: 15px;
    margin-top: 50px;
    margin-bottom: 30px;
}

.pmz_panel_login {
    width: 70%;
    margin: auto;
    padding-top: 10px;
}

.col-md-8 {
    width: 66.66666667%;
}

@media(max-width:768px) {

    .pmz_ggral_recurrencias {
        width: 100%;
        margin: auto;
        overflow: hidden;
        border: 1px solid #F1F1F1;
        padding: 15px;
        margin-top: 10px;
        margin-bottom: 30px;
    }

    .pmz_panel_login {
        width: 100%;
        margin: auto;
        padding-top: 10px;
    }

    .col-md-8 {
        width: 100%;
    }
}

/*** FIN RECURRENCIAS ***/


/*** FORMATO 413 ***/

.pmz_413_gral {
    width: 100%;
    overflow: hidden;
    background-color: #F8F8F8;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 20px;
    font-family: "TitilliumWeb-Regular";
    color: #777;
    text-align: justify;
    line-height: 20pt;
}

.pmz_413_titulo {
    border: 1px solid #AAA;
    height: 35px;
    padding-left: 20px;
    padding-top: 5px;
    color: #FFF;
    border-radius: 10px 10px 0px 10px;
    -webkit-border-radius: 10px 10px 0px 10px;
    background-color: #AAA;
    overflow: hidden;
}

.pmz_413_texto {
    overflow: hidden;
    padding-top: 30px;
}

.pmz_413_log_certificados {
    width: 100%;
    height: 70px;
    background-image: url("Graficas/certificados_pc.gif");
    background-repeat: no-repeat;
    background-position: 0% 10px;
}

.pmz_413_log_afiliados {
    width: 100%;
    height: 70px;
    display: flex;
    /*background-image: url("Graficas/afiliaciones.gif");
    background-repeat: no-repeat;
    background-position: 0% 10px;*/
}

/* Nuevo 
Se agrega img para la plantilla 13
*/

.img_CP {
    width: 30%;
    height: 70px;
    background-image: url("../../../../Graficas/CicloPAGO.png");
    background-repeat: no-repeat;
    background-position: 83% 10px, 103px;
    cursor: pointer;
    display: none;
}

.img_ZG {
    width: 30%;
    height: 70px;
    background-image: url("../../../../Graficas/ZonaSEGURA.png");
    background-repeat: no-repeat;
    background-position: 98% 10px, 103px;
    cursor: pointer;
}

.img_afiliaciones {
    width: 40%;
    height: 70px;
    background-image: url("Graficas/afiliaciones.gif");
    background-repeat: no-repeat;
    background-position: 0% 10px, 103px;
}


/* Hasta aquí */

@media(max-width:768px) {

    .pmz_413_gral {
        width: 100%;
        overflow: hidden;
        background-color: #F8F8F8;
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 20px;
        font-family: "TitilliumWeb-Regular";
        color: #777;
        text-align: justify;
        line-height: 20pt;
    }

    .pmz_413_titulo {
        border: 1px solid #AAA;
        height: 35px;
        padding-left: 20px;
        padding-top: 5px;
        color: #FFF;
        border-radius: 10px 10px 0px 10px;
        -webkit-border-radius: 10px 10px 0px 10px;
        background-color: #AAA;
        overflow: hidden;
    }

    .pmz_413_texto {
        overflow: hidden;
        padding-top: 30px;
    }

    .pmz_413_log_certificados {
        width: 100%;
        height: 70px;
        background-image: url("Graficas/certificados_pc.gif");
        background-repeat: no-repeat;
        background-position: 0% 10px;
    }

    .pmz_413_log_afiliados {
        width: 100%;
        height: 70px;
        /*background-image: url("Graficas/afiliaciones.gif");
    background-repeat: no-repeat;
    background-position: 0% 10px;*/
    }

    /* Nuevo 
Se agrega img para la plantilla 13
*/

    .img_CP {
        width: 30%;
        height: 70px;
        background-image: url("../../../../Graficas/CicloPAGO.png");
        background-repeat: no-repeat;
        background-position: 83% 10px, 103px;
        cursor: pointer;
        display: none;
    }

    .img_ZG {
        width: 30%;
        height: 70px;
        background-image: url("../../../../Graficas/ZonaSEGURA.png");
        background-repeat: no-repeat;
        background-position: 98% 10px, 103px;
        cursor: pointer;
    }

    .img_afiliaciones {
        width: 40%;
        height: 70px;
        background-image: url("Graficas/afiliaciones.gif");
        background-repeat: no-repeat;
        background-position: 0% 10px, 103px;
    }
}

/*** FIN FORMATO 413 ***/

/*** PIE DE PAGINA ***/

.pmz_piepag_gnral {
    width: 100%;
    background-color: #F9FBFB;
    overflow: auto;
    font-family: Arial;
    font-size: 12px;
    /*padding-top: 20px;
	padding-bottom: 20px;*/
}

.pmz_logo_zona {
    width: 70%;
    float: left;
    overflow: auto;
    background-image: url("Graficas/logo_pie_zona.png");
    background-position: right;
    padding-right: 20px;
    border-right: 1px solid #CCCCCC;
    background-repeat: no-repeat;
    height: 60px;
}

.pmz_texto_pie {
    width: 28%;
    float: right;
    overflow: hidden;
    line-height: 18px;
    padding-top: 15px;
}

.pmz_vincu_zona {
    text-decoration: none;
    color: #777;
}


@media(max-width:768px) {

    .pmz_piepag_gnral {
        width: 100%;
        background-color: #F9FBFB;
        overflow: auto;
        font-family: Arial;
        font-size: 12px;
        /*padding-top: 10px;
	padding-bottom: 10px;*/
    }

    .pmz_logo_zona {
        width: 100%;
        float: none;
        overflow: auto;
        background-image: url("Graficas/logo_pie_zona_mov.png");
        background-position: center;
        padding-right: 0px;
        border-right: none;
        background-repeat: no-repeat;
        height: 35px;
        background-size: 65%;
    }

    .pmz_texto_pie {
        width: 100%;
        float: none;
        overflow: hidden;
        line-height: 15px;
        padding-top: 0px;
        text-align: center;
        font-size: 12px;
    }

    .pmz_vincu_zona {
        text-decoration: none;
        color: #777;
    }
}

/*** FIN PIE DE PAGINA ***/


/*** FORMATOS DE FINALIZACIÓN ***/

.pmz_titulos_formato {
    font-family: "TitilliumWeb-Bold";
    color: #FFF;
    line-height: 20pt;
    background-color: #AAA;
    padding-top: 10px;
    padding-bottom: 10px;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-align: center;
}

.pmz_titulos_formato_rechazado {
    font-family: "TitilliumWeb-Bold";
    color: #FFF;
    line-height: 20pt;
    background-color: #D90000;
    padding-top: 10px;
    padding-bottom: 10px;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-align: center;
}

.pmz_titulos_formato_pendiente {
    font-family: "TitilliumWeb-Bold";
    color: #FFF;
    line-height: 20pt;
    background-color: #F2B628;
    padding-top: 10px;
    padding-bottom: 10px;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-align: center;
}

.pmz_form_titulo_caja {
    background-color: #F8F8F8;
    padding-left: 30px;
    padding-bottom: 20px;
    padding-right: 20px;
    padding-top: 5px;
    text-transform: uppercase;
    border: 1px solid #F8F8F8;
    border-bottom-left-radius: 100%;
    border-bottom-right-radius: 100%;
    height: 40px;
    text-align: center;
}

.pmz_form_contenido_caja {
    font-family: "TitilliumWeb-Regular";
    font-size: 16px;
    padding-left: 30px;
    padding-right: 30px;
    padding-bottom: 20px;
    margin: auto;
    overflow: auto;
}

.pmz_texto_seguro {
    font-family: "TitilliumWeb-Regular";
    font-size: 16px;
}

.pmz_formatos_finalizacion {
    width: 800px;
    margin: auto;
    overflow: hidden;
}

.pmz_formatos_finalizacion2 {
    width: 800px;
    margin: auto;
}

.pmz_td_table {
    text-align: center;
    background-color: #F8F8F8;
    border: 1px solid #FFFFFF;
    font-size: 13px;
}

.pmz_td_table2 {
    text-align: center;
    border: 1px solid #F8F8F8;
    font-size: 13px;
}

@media(max-width:768px) {

    .pmz_titulos_formato {
        font-family: "TitilliumWeb-Bold";
        color: #FFF;
        line-height: 20pt;
        background-color: #AAA;
        padding-top: 10px;
        padding-bottom: 10px;
        letter-spacing: 1px;
        text-transform: uppercase;
        text-align: center;
    }

    .pmz_titulos_formato_rechazado {
        font-family: "TitilliumWeb-Bold";
        color: #FFF;
        line-height: 20pt;
        background-color: #D90000;
        padding-top: 10px;
        padding-bottom: 10px;
        letter-spacing: 1px;
        text-transform: uppercase;
        text-align: center;
    }

    .pmz_titulos_formato_pendiente {
        font-family: "TitilliumWeb-Bold";
        color: #FFF;
        line-height: 20pt;
        background-color: #F2B628;
        padding-top: 10px;
        padding-bottom: 10px;
        letter-spacing: 1px;
        text-transform: uppercase;
        text-align: center;
    }

    .pmz_form_titulo_caja {
        background-color: #F8F8F8;
        padding-left: 30px;
        padding-bottom: 20px;
        padding-right: 20px;
        padding-top: 5px;
        text-transform: uppercase;
        border: 1px solid #F8F8F8;
        border-bottom-left-radius: 100%;
        border-bottom-right-radius: 100%;
        height: 40px;
        text-align: center;
    }

    .pmz_form_contenido_caja {
        font-family: "TitilliumWeb-Regular";
        font-size: 16px;
        padding-left: 15px;
        padding-right: 15px;
        padding-bottom: 20px;
        margin: auto;
        overflow: auto;
        padding-top: 20px;
    }

    .pmz_form_LD {
        width: 100%;
        float: right;
        line-height: 40px;
        text-align: right;
    }

    .pmz_form_LI {
        width: 100%;
        float: left;
        line-height: 35px;
        text-align: left;
    }

    .pmz_formatos_finalizacion {
        width: 100%;
        margin: auto;
        overflow: hidden;
    }

    .pmz_formatos_finalizacion2 {
        width: 100%;
        margin: auto;
        overflow-y: scroll;
    }

    .pmz_td_table {
        text-align: center;
        background-color: #F8F8F8;
        border: 1px solid #FFFFFF;
        font-size: 13px;
    }

    .pmz_td_table2 {
        text-align: center;
        border: 1px solid #F8F8F8;
        font-size: 13px;
    }

    .pmz_text_negro {
        color: #000;
    }
}


/*** FIN FORMATOS DE FINALIZACIÓN ***/


/*** FORMATOS DE CORREO ***/

.pmz_fc_ggral {
    width: 630px;
    margin: auto;
    padding-top: 15px;
    background-color: #fff;
    overflow: hidden;
    font-family: "TitilliumWeb-Regular";
    font-size: 16px;
    color: #777;
}

.pmz_fc_encabezado {
    width: 100%;
    height: 140px;
    border-bottom: 2px solid #03706B;
    border-top: 2px dotted #03706B;
    background-image: url("Graficas/triangulo_fc.gif");
    background-repeat: no-repeat;
    background-position: right;
}

.pmz_fc_logozona {
    width: 50%;
    background-image: url("Graficas/logo_zona_formato_correo.png");
    background-repeat: no-repeat;
    background-position: left center;
    height: 140px;
    float: left;
}

.pmz_fc_logoscerti {
    width: 50%;
    background-image: url("Graficas/logo_certificados_formato_correo.png");
    background-repeat: no-repeat;
    background-position: right bottom;
    height: 130px;
    float: right;
}

.pmz_fc_slogan {
    width: 100%;
    background-color: #9AC6C4;
    color: #fff;
    text-align: center;
    padding-top: 5px;
    padding-bottom: 5px;
    overflow: hidden;
}

.pmz_fc_contenido {
    margin: auto;
    padding: 20px;
    border: 1px solid #ECECEC;
    margin-top: 15px;
    overflow: hidden;
}

.pmz_fc_titulos {
    text-align: center;
}

.pmz_fc_negro {
    color: #000;
}

.pmz_fc_labelppal {
    border: 1px solid #F5F5F5;
    padding: 3px;
    text-align: left;
    margin-bottom: 5px;
    overflow: hidden;
    color: #000;
    font-weight: bold;
}

.pmc_fc_label_left {
    border: 1px solid #F5F5F5;
    padding: 2px;
    text-align: left;
    float: left;
    width: 150px;
    margin-bottom: 5px;
}

.pmz_fc_respue_rigth {
    border: 1px solid #F5F5F5;
    padding: 2px;
    text-align: left;
    float: right;
    width: 420px;
    color: #000;
    background-color: #F5F5F5;
    margin-bottom: 5px;
}

.pmz_fc_tabla {
    border: 1px solid #F5F5F5;
    text-align: center;
    padding: 3px;
    font-size: 12px;
}

.pmz_fc_td {
    border: 1px solid #F5F5F5;
    text-align: left;
    padding: 3px;
    color: #000;
    font-size: 12px;
}

.pmz_fc_texto_pequ {
    margin-top: 15px;
    font-size: 11px;
    text-align: center;
}

.pmz_fc_banner {
    overflow: hidden;
    height: 220px;
    margin-top: 10px;
    width: 100%;
    background-image: url("Graficas/banner_correo.png");
    background-repeat: no-repeat;
}

.pmz_fc_pie_pagina {
    border-bottom: 7px solid #03706B;
    border-top: 7px solid #03706B;
    margin-bottom: 15px;
    margin-top: 15px;
}

.pmz_fc_pieinterno {
    background-color: #03706B;
    border-bottom: 2px solid #FFF;
    border-top: 2px solid #FFF;
    height: 53px;
    color: #FFF;
}

.pmz_fc_text_respaldo {
    float: left;
    width: 270px;
    height: 53;
    text-align: right;
    padding-top: 12px;
}

.pmz_fc_logocommerce {
    width: 136px;
    height: 53;
    background-image: url("Graficas/logo_zona_commerce.png");
    background-repeat: no-repeat;
    float: left;
}

.pmz_fc_logozona1 {
    width: 200px;
    float: left;
    height: 53px;
    background-image: url("Graficas/logo_zona_pagos.png");
    background-repeat: no-repeat;
    background-position: left;
}



@media(max-width:768px) {

    .pmz_fc_ggral {
        width: 100%;
        margin: auto;
        padding-top: 15px;
        background-color: #fff;
        overflow: hidden;
        font-family: "TitilliumWeb-Regular";
        font-size: 16px;
        color: #777;
    }

    .pmz_fc_encabezado {
        width: 100%;
        height: 140px;
        border-bottom: 2px solid #03706B;
        border-top: 2px dotted #03706B;
        background-image: url("Graficas/triangulo_fc.gif");
        background-repeat: no-repeat;
        background-position: right;
    }

    .pmz_fc_logozona {
        width: 100%;
        background-image: url("Graficas/logo_zona_formato_correo.png");
        background-repeat: no-repeat;
        background-position: center center;
        height: 140px;
        float: none;
    }

    .pmz_fc_logoscerti {
        width: 100%;
        background-image: url("Graficas/logo_certificados_formato_correo.png");
        background-repeat: no-repeat;
        background-position: right center;
        height: 50px;
        float: right;
    }

    .pmz_fc_slogan {
        width: 100%;
        background-color: #9AC6C4;
        color: #fff;
        text-align: center;
        padding-top: 5px;
        padding-bottom: 5px;
        overflow: hidden;
    }

    .pmz_fc_contenido {
        margin: auto;
        padding: 20px;
        border: 1px solid #ECECEC;
        margin-top: 15px;
        overflow: hidden;
    }

    .pmz_fc_titulos {
        text-align: center;
    }

    .pmz_fc_negro {
        color: #000;
    }

    .pmz_fc_labelppal {
        border: 1px solid #F5F5F5;
        padding: 1px;
        text-align: left;
        margin-bottom: 5px;
        overflow: hidden;
        color: #000;
        font-weight: bold;
        padding-top: 5px;
        padding-bottom: 5px;
        text-transform: uppercase;
    }

    .pmc_fc_label_left {
        border: 1px solid #F5F5F5;
        padding: 1px;
        text-align: left;
        float: none;
        width: 100%;
        margin-bottom: 5px;
    }

    .pmz_fc_respue_rigth {
        border: 1px solid #F5F5F5;
        padding: 1px;
        text-align: left;
        float: none;
        width: 100%;
        color: #000;
        background-color: #F5F5F5;
        margin-bottom: 5px;
    }

    .pmz_fc_tabla {
        border: 1px solid #F5F5F5;
        text-align: center;
        padding: 3px;
        font-size: 12px;
    }

    .pmz_fc_td {
        border: 1px solid #F5F5F5;
        text-align: left;
        padding: 3px;
        color: #000;
        font-size: 12px;
    }

    .pmz_fc_texto_pequ {
        margin-top: 15px;
        font-size: 11px;
        text-align: center;
    }

    .pmz_fc_banner {
        overflow: hidden;
        height: 220px;
        margin-top: 10px;
        width: 100%;
        background-image: url("Graficas/banner_correo.png");
        background-repeat: no-repeat;
        background-position: center;
    }

    .pmz_fc_pie_pagina {
        border-bottom: 7px solid #03706B;
        border-top: 7px solid #03706B;
        margin-bottom: 15px;
        margin-top: 15px;
    }

    .pmz_fc_pieinterno {
        background-color: #03706B;
        border-bottom: 2px solid #FFF;
        border-top: 2px solid #FFF;
        height: 53px;
        color: #FFF;
    }

    .pmz_fc_text_respaldo {
        float: left;
        width: 270px;
        height: 53;
        text-align: right;
        padding-top: 12px;
    }

    .pmz_fc_logocommerce {
        width: 136px;
        height: 53;
        background-image: url("Graficas/logo_zona_commerce.png");
        background-repeat: no-repeat;
        float: left;
    }

    .pmz_fc_logozona1 {
        width: 200px;
        float: left;
        height: 53px;
        background-image: url("Graficas/logo_zona_pagos.png");
        background-repeat: no-repeat;
        background-position: left;
    }
}

/*** FIN FORMATOS DE CORREO ***/

/** Formato Header Nuevo Tesorerias **/

header {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 0 10px gray;
    position: relative;
    min-width: 98vw;
    background-color: #fff;
    margin-bottom: 1rem;
    min-height: 7em;
}

/** Muestra el logo del comercio solo en portales modalidad formulario **/
.portal-formulario-login {
    display: flex;
    justify-content: center;
    height: 10em;
    width: auto;
}

.login-container {
    margin-top: 6em;
}

.content-login {
    display: flex;
    justify-content: center;
    margin: 20px;
}

nav {
    display: flex;
    flex-grow: 1;
    justify-content: flex-end;
}

.contetn-logo {
    width: 15%;
    text-align: center;
}

.logo-img {
    margin: 0 1em;
    width: auto;
    height: 60px;
}

.lenguage {
    width: 15%;
}

.selected-step {
    position: relative;
    width: 26px; /* Ajusta según el tamaño deseado */
    height: 26px; /* Mantén el contenedor cuadrado */
    display: flex;
    justify-content: center;
    align-items: center;
}

.contorno {
    width: auto; /* Tamaño del contorno */
    height: 22px;
    position: absolute;
}

.punto_seleccion {
    width: 12px; /* Tamaño del punto */
    height: 12px;
    position: absolute;
    filter: invert(44%) sepia(84%) saturate(389%) hue-rotate(120deg) brightness(90%) contrast(89%);
}

.steps {
    display: flex;
    justify-content: center;
    width: 80%;
    color: #9fa3a5;
}

.form-steps {
    display: flex;
    position: relative;
    align-items: center;
    width: 75%;
}

.step {
    position: relative;
    text-align: center;
    flex: 1;
    padding: 0 2px;
    display: flex;
    flex-direction: column;
    align-items: center;
}


    .step > .description {
        margin-top: 10px;
        font-size: 14px;
        color: #555;
    }

    /* Línea de conexión */
    .step:not(:last-child)::after {
        content: '';
        position: absolute;
        top: 18%;
        left: 55%;
        width: 90%;
        height: 2px;
        background-color: #9fa3a5;
        z-index: 1;
    }

    /* Ajustar la posición de la línea */
    .step:not(:first-child)::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 0;
        width: 100%;
        height: 2px;
        background-color: #ccc;
        z-index: -1;
    }

.step-selected-mobile {
    background-image: url(Graficas/Cicrulo_seleccionado.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    display: block;
    margin: 0 auto;
    width: 22px;
    height: 22px;
}

.step-unselected-mobile {
    background-image: url(Graficas/circulo_gris.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    display: block;
    margin: 0 auto;
    width: 22px;
    height: 22px;
}

/* Línea de conexión entre el primer y último step */
.form-steps::before,
.form-steps::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 2px;
    background-color: #ccc;
    z-index: -1;
}

.step.-current img {
    filter: none;
}

.show-on-mobile {
    display: none;
}

.footer-bill {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: unset !important;
    text-align-last: center;
    color: #546264;
}

.show-footer-mobile {
    display: none;
}

.section-pays-with-zp {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: unset !important;
    text-align-last: center;
    color: #546264;
}
/* Card Login */

.cardContainer {
    min-height: 20em;
    width: 37em;
    text-align: center;
    border-radius: 18px;
    background: rgb(255, 255, 255);
    box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;
    transition: all 0.5s ease;
    margin: auto 10px;
}

.cardTitle {
    position: relative;
    padding: 5px;
    font-size: 1.4em;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    border-top-right-radius: 18px;
    border-top-left-radius: 18px;
    margin-bottom: 2em;
}

.cardContent {
    color: #111111;
    position: relative;
    justify-content: center;
    align-items: center;
    min-height: 200px;
    padding: 0 5em;
}

.cardForm {
    margin: 10px;
    width: 90%;
}

.inputForm {
    margin: 0 0 9px 0;
    width: 100%;
    min-height: 23px;
    padding-left: 10px;
}

.cardFooter a {
    color: #fd2424;
    text-decoration: none;
}

.btn-continuar {
    background-color: var(--color-green-zona);
    color: #fff;
    font-weight: bold;
    border: 2px solid var(--color-green-zona);
    border-radius: 20px;
    padding: 0 14px;
    cursor: pointer;
    margin-bottom: 2em;
}

    .btn-continuar:hover {
        background-color: #fff;
        color: var(--color-green-zona);
        font-weight: bold;
        border: 2px solid var(--color-green-zona);
        border-radius: 20px;
        padding: 0 14px;
        cursor: pointer;
        margin-bottom: 2em;
        display: inline-block;
    }

.color-arrow-btn {
    display: block;
    filter: none;
}

.btn-continuar:hover > .data-button > .color-arrow-btn {
    filter: invert(56%) sepia(80%) saturate(4207%) hue-rotate(140deg) brightness(94%) contrast(84%);
}

.data-button {
    display: flex;
    align-items: center;
    margin: 6px 2px;
}

    .data-button > label {
        margin: 0 6px 0 0;
    }

@media (max-width: 992px) {
    .form-steps {
        align-items: flex-start;
        width: 75%;
        padding-top: 1em;
    }
}

@media (max-width: 768px) {
    .hide-on-mobile {
        display: none !important;
    }

    .show-footer-mobile {
        display: flex;
        margin-top: 0.5em;
        margin-bottom: 2em;
    }

    .show-on-mobile {
        display: flex;
        width: 100%;
    }

    .form-steps > .step > .circle::before {
        position: absolute;
        margin-top: 0.3em;
        margin-left: 0.35em;
        font-size: 42px;
    }

    #FormularioPrincipal {
        min-height: 95vh;
    }

    .cardContainer {
        border-radius: 8px;
    }

    .content-login {
        margin-top: 5vh;
    }

    .cardForm {
        margin: 10px 0;
        width: 100%;
    }

    .cardContainer {
        border-radius: 8px;
    }

    .cardContent {
        padding: 0 2em;
    }

    .contetn-logo {
        width: 100%;
        text-align: center;
    }

    #header > .steps {
        width: 0%;
    }

    .lenguage {
        margin: 0;
        width: 0%;
    }
}


/* Solucion temporal para quitar textos

	.panel-heading, .px_v2_pie_pag {
		display: none;
	} 
	*/
footer {
    color: #546264;
    min-height: 2em;
    align-items: center;
    justify-items: center;
    margin-bottom: 1em;
    text-align: center;
}

.footer {
    color: #546264;
    min-height: 2em;
    align-items: center;
    justify-items: center;
    margin: 10px 1em 2em;
    text-align: center;
}

.descriptive-text {
    display: none;
}

.px_v2_pie_pag {
    display: none;
}

/*Fin solucion temporal */



/*Facturacion*/

.container-bill {
    justify-content: center;
    color: #546264;
    min-height: 52vh;
    display: grid;
    gap: 40px;
    grid-auto-flow: column;
}

.container-form {
    height: auto;
    min-width: 20em;
}

    .price-total > b,
    .content-select-all > b,
    .container-list-bill > div > b,
    .container-form > b {
        font-size: 16px;
    }

.container-list-bill > div {
    margin-bottom: 10px;
}

.container-list-bill {
    height: 5rem;
}

.card {
    /*box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;*/
    border-radius: 8px;
    margin: 10px 0 1em 0;
    background: white;
    border: 1px solid #ccc;
    padding: 10px 0;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.card-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.active-card {
    background-color: #edeff4;
    border: 1.5px solid #b5b5b5;
}

.edit-form {
    display: none;
    flex-direction: column;
}

    .edit-form > label {
        font-weight: bold;
        font-size: 12px;
    }

.section-name {
    display: flex;
    flex-wrap: wrap;
    gap: 10px; /* Espacio entre columnas */
    width: 100%;
}

    /* Ambos divs comparten esta regla */
    .section-name .form-group {
        flex: 1 1 48%;
    }

        /* Si solo hay uno visible (el único hijo dentro de .section-name), ocupa todo el ancho */
        .section-name .form-group:only-child {
            flex: 1 1 100%;
        }

.section-doc {
    display: flex;
    align-items: center;
    gap: 5px;
    width: 100%;
    flex-wrap: wrap;
}

/* Ambos contenedores por defecto ocupan 50% si están presentes */
.tipo-container,
.identificacion-container {
    flex: 1 1 48%;
}

/* Si solo hay un hijo, que ocupe todo el ancho */
.section-doc > :only-child {
    flex: 1 1 100%;
}

/* Aseguramos que los inputs siempre se expandan correctamente */
.identificacion-input {
    width: 100%;
}


/* Responsive: en móviles, ambos al 100% */
@media (max-width: 768px) {
    .section-name .form-group {
        flex: 1 1 100% !important;
    }

    .tipo-container,
    .identificacion-container {
        flex: 1 1 100% !important;
    }
}

.type > label, .doc > label {
    font-size: 12px;
    font-weight: bold;
}

td > .form-control {
    width: 12rem;
    margin: auto;
}

.edit-form input {
    margin-top: 2px;
    height: 32px;
    padding: 2px 6px;
    border-radius: 6px;
    border: 1px solid #c7c7c7;
    font-size: 14px;
}

.edit-form select {
    margin-top: 2px;
    margin-bottom: 0px;
    height: 32px;
    padding: 2px 6px;
    border-radius: 6px;
    border: 1px solid #c7c7c7;
    font-size: 14px;
}

.form {
    min-height: 3em;
    padding: 1em;
    width: 22em;
}

.list-bill {
    min-height: 3em;
    padding: 0em;
    min-width: 56vw;
}

.content-edit {
    margin: 5px 0;
    text-align: right;
}

    .content-edit > span {
        cursor: pointer;
        color: var(--color-green-zona);
    }

.section-buttons {
    align-self: center;
    margin: 8px 4px;
    width: 90%;
    display: flex;
}

.btn-cancel {
    background-color: #EDEFF4 !important;
    color: #546264 !important;
    font-weight: bold !important;
    min-width: 100px !important;
    padding: 7px 12px;
    border: 1px solid #EDEFF4 !important;
    border-radius: 20px !important;
    font-weight: bold;
    cursor: pointer;
    margin: 0 auto !important;
    min-height: 34px;
    letter-spacing: 1px;
}

.btn-save {
    padding: 7px 12px;
    border: 1px solid var(--color-green-zona) !important;
    border-radius: 20px !important;
    font-weight: bold;
    cursor: pointer;
    background-color: var(--color-green-zona) !important;
    color: #f9f9f9 !important;
    min-width: 100px !important;
    font-weight: bold;
    margin: 0 auto !important;
    min-height: 34px;
    letter-spacing: 1px;
}

    .btn-save:hover {
        padding: 7px 12px !important;
        border: 1px solid var(--color-green-zona) !important;
        border-radius: 20px !important;
        background-color: #fff !important;
        color: var(--color-green-zona) !important;
        font-weight: bold;
        min-width: 100px !important;
        cursor: pointer;
    }

input:focus, select:focus {
    border: 2px solid var(--color-green-zona);
    outline: none;
}

.content-bills hr:first-of-type {
    opacity: 0;
}

.content-bills div:first-of-type {
    width: 15px;
    margin-left: 4px;
}

.content-bills hr {
    height: 28px;
    outline: none;
    border: 1px solid #c1c1c1;
    margin: auto;
}

.content-bills {
    display: flex;
    font-size: 13px;
    font-weight: bold;
    justify-content: space-between;
    margin: 12px 2px;
    align-items: center;
}

.bill {
    border-radius: 5px;
    background: white;
    border: 1px solid #ccc;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 1em 1px;
    font-size: 12px;
}

.title {
    width: 7em;
    text-align: center;
}

    .title > input {
        width: 5em;
        margin-right: 4px;
    }

.type {
    margin-right: 5px;
    display: grid;
    width: 50%;
}

#edit-document-number {
    width: 100%;
}

.content-card-list {
    border-bottom: 1px solid #C9CCD5;
    padding: 0 10px;
}

.footer-table {
    padding: 20px 2em 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.total-pay {
    font-size: 18px;
    letter-spacing: 1px;
}

.price-total > p {
    margin: 0;
}

input#otro-valor {
    width: 90%;
}

.total-pagar-info {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.list-bill input[type=checkbox] {
    accent-color: var(--color-green-zona);
}

.form-group {
    margin-bottom: 5px;
}

.type > .form-group {
    margin-bottom: 5px;
}

.form-group > span {
    font-size: 13px;
    font-weight: bold;
}

.table {
    margin-bottom: 2px;
}

    .table > tbody > tr > th,
    .table > tbody > tr > td {
        align-content: center;
        padding: 12px 8px !important;
        text-align: center;
    }

.content-select-all {
    margin: 10px 5px;
}

@media (max-width: 960px) {
    .form {
        width: 19em;
    }

    .container-bill {
        gap: 0;
        min-height: 77vh;
    }
}

@media (max-width: 768px) {
    .card {
        margin: 0;
    }

    .footer-table {
        padding: 20px 1em 12px;
    }

    .container-bill {
        gap: 10px;
        grid-auto-flow: row;
        min-height: auto;
        margin-bottom: 2em;
        padding: 0 12px;
    }

    .container-list-bill {
        height: auto;
        min-width: 100%;
        margin-top: 1em;
    }

    .form {
        min-height: 3em;
        width: 100%;
        margin-top: 10px;
    }

    .price-total > b, .content-select-all > b, .container-list-bill > div > b, .container-form > b {
        letter-spacing: 0.5px;
    }

    .container-form {
        min-width: 100%;
    }

    .content-card-list {
        overflow-x: auto;
        white-space: nowrap;
        height: auto;
        border-bottom: 1px solid grey;
    }

    .list-bill {
        display: inline-block;
    }

    .title {
        width: 34vw;
    }

    .content-bills .title:not(:last-child) input[type="radio"] {
        width: 2em;
        margin: 0;
    }

    .content-bills .title:last-child input#otro-valor {
        width: 88%;
        padding: 3px;
    }

    .total-pay {
        font-size: 14px;
    }

    .section-buttons {
        display: flex;
        justify-content: space-between;
        margin-top: 10px;
        width: 75%;
    }

    .doc {
        width: 100%;
    }
}


/* Nuevos estilos CIclo pago  */

.container-form-summary {
    width: 25em;
    margin: 17px 2em;
    color: #546264;
}

.edit-icon {
    cursor: pointer;
    border-bottom: 1px solid #546264;
}

.form {
    min-height: 3em;
    padding: 1em;
}

.pmz_paga_segu {
    padding: 0px 3px !important;
    text-align: center !important;
}

.contact-info {
    display: grid;
    padding: 15px 1em;
    width: 25em;
    background-color: white;
}

.card-contact {
    border-radius: 8px;
    margin: 10px 0;
    border: 1px solid #d7d7d7;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 2px 5px;
}

.payment-summary {
    padding: 1em;
    align-items: center;
    background-color: white;
}

.title-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 10px;
}

.total-value {
    font-size: 20px;
    color: white;
    background-color: var(--color-green-zona);
    border-radius: 8px;
    padding: 7px 20px;
    display: flex;
    justify-content: space-between;
    margin-top: 16px;
}

.show-summary {
    display: none;
}

.close-summary {
    display: grid;
}

.summary > div {
    display: flex;
    justify-content: space-between;
    margin: 1em 0;
}

.description-summary {
    color: #707070;
    width: 50%;
}

.value-description {
    width: 50%;
    text-align: end;
}

.value-description-sect-1 {
    width: 100%;
    text-align: end;
    margin: 0;
}

.end-summary {
    color: #B7B7B7;
}

.btn-summary {
    border: none;
    background-color: transparent;
    cursor: pointer;
}

#Formulario_FormatoEncabezado {
    position: absolute;
    left: 6%;
    margin-top: 16px;
}

/*Card medios de pago*/
.content-payment-method {
    flex: 1;
    margin-left: 37%;
    color: #546264;
}

    .content-payment-method > b {
        font-size: 16px;
    }

.card-general {
    background-color: #fff;
    padding: 30px 10px 0;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    max-width: 750px;
    width: 100%;
}

.card-payment-method {
    border-radius: 5px;
    height: 6em;
    text-align: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    position: relative;
    width: 22%;
    align-content: center;
}

    .card-payment-method > p {
        margin: 5px auto;
        font-weight: bold;
    }

    .card-payment-method img {
        height: 42px;
        object-fit: cover;
        object-position: center;
    }

    .card-payment-method:hover {
        background-color: #DFDFDF7D;
        cursor: pointer;
    }

#MediosPago_MediosPago_ctl00_UpZonaPagos {
    display: flex;
    flex-direction: column;
    height: calc(100% - 100vh);
}

.payment-methods-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.panel-default {
    border: none;
}

.panel {
    border: none;
    box-shadow: none;
}

.panel-group {
    margin-bottom: 0px !important;
}

.panel-group-payment-methods {
    display: flex;
    flex-direction: column;
}

.header-pse {
    text-align-last: center;
}

.pse-select-container {
    margin: 1em 0;
}

.header-pse > img {
    height: 60px;
    margin-bottom: 1em;
}

.header-pay-tc {
    text-align-last: center;
    text-align: -webkit-center;
}

.tc-form-container {
    display: flex;
    flex-wrap: wrap;
}

.payment-methods-list.centered {
    justify-content: center;
}

.header-payment-method {
    text-align-last: center;
    margin-bottom: 2em;
}

    .header-payment-method img {
        height: 40px;
        margin-bottom: 1.5em;
    }

.form-group > .btn {
    margin: 2em auto;
}

.alert-danger {
    inset-area: center;
    margin: 0 auto 2em;
    min-width: 19em;
    width: 35%;
    display: grid;
    color: #EF2122;
    background-color: #fff;
    border: 1px solid #EF2122;
}

.header-alert {
    display: flex;
    justify-content: space-between;
}

.message-alert {
    color: #545454;
}

.alert-danger strong {
    display: flex;
    align-items: center;
    margin-bottom: 4px;
}

.alert-danger .close {
    margin-left: 1em;
    text-align: right;
}

.pilitic-container {
    margin: 1em 15px 3em;
    text-align: center;
    font-size: 14px;
    font-family: "TitilliumWeb-SemiBold";
    color: #777;
    display: flex;
    justify-content: center;
}

    .pilitic-container > span {
        display: flex;
        margin: 0 4px;
    }

        .pilitic-container > span > a {
            margin: 0 4px;
        }

.content-divDetalle {
    display: flex;
}
/*Se asigna a la columba el simbolo $ */
.lblValorAPagar::before {
    content: "$ ";
}

.message-pse {
    background-color: #F4F4F7;
    padding: 10px;
    border-radius: 6px;
    border: 1px solid #e7e7e7;
    margin: 10px;
    justify-content: center;
}

    .message-pse > .control-label {
        padding-bottom: 0px !important;
        margin: auto;
    }

.skeleton-login {
    width: 50% !important;
}

.card-format {
    min-height: 50vh;
    background-color: #fff;
    max-width: 40em;
    min-width: 20em;
    margin: auto;
    border-radius: 8px;
    padding: 1em 2em;
    color: #535D60;
    font-size: 14px;
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}

.header-section {
    height: auto;
}

.franja-estado {
    height: 40px;
    border-radius: 8px;
    color: #fff;
    margin: 10px 0 1em;
    padding: 0 10px;
    font-size: 16px;
    display: flex;
    align-items: center;
}

.estado-aprobado {
    background-color: var(--color-green-zona);
}

.estado-pendiente {
    background-color: #FFBD06;
}

.estado-rechazado {
    background-color: #E11A1A;
}

.franja-estado > img {
    margin-right: 10px;
    height: 20px;
}

.info-header {
    text-align: left;
    display: grid;
    padding: 5px;
}

    .info-header > span {
        margin: 4px 0;
    }

.body-section {
    padding: 5px;
}

.title-section {
    padding: 5px 0;
    border-bottom: 1px solid #DDE3F0;
    margin-bottom: 1em;
    font-size: 16px;
}

.summary-section > div {
    display: flex;
    justify-content: space-between;
    margin: 1em 0;
}

.footer-section {
    margin: 1em 0;
}

.buttons-section {
    display: flex;
    justify-content: space-evenly;
}

.btn-download {
    background-color: var(--color-green-zona);
    color: #fff;
    width: 120px;
    border: 1px solid var(--color-green-zona);
    border-radius: 2em;
    padding: 7px 14px;
    font-weight: bold;
}

    .btn-download:hover {
        background-color: #fff;
        color: var(--color-green-zona);
        border: 1px solid var(--color-green-zona);
    }

.btn-finish {
    background-color: #fff;
    color: var(--color-green-zona);
    border: 1px solid var(--color-green-zona);
    width: 120px;
    border-radius: 2em;
    padding: 7px 14px;
    font-weight: bold;
}

    .btn-finish:hover {
        background-color: #fff;
        color: #535D60;
        border: 1px solid #707070;
    }

.contact-us-section {
    margin: 2em 10px 0;
    font-size: 13px;
    text-align: center !important;
}

    .contact-us-section > span {
        color: #166BFC;
    }

@media (max-width : 600px) {
    .card-format {
        padding: 1em 0.5em;
    }

    .seleccion-banco {
        margin-top: 10px;
    }
}

@media (min-width : 601px) {
    .seleccion-banco {
        display: grid;
        justify-content: flex-end;
    }
}

.btn-step-disabled {
    background-color: #d9d9d9 !important;
    border: 1px solid #d9d9d9 !important;
    color: #545454 !important;
}

@media (min-width: 1920px) {
    .content-payment-method {
        margin-left: 40%;
    }

    #Formulario_FormatoEncabezado {
        left: 16%;
    }

    .card-general {
        max-width: 826px;
    }
}

@media (max-width: 960px) {
    #Formulario_FormatoEncabezado {
        position: relative;
        margin-top: 16px;
        left: 0%;
        text-align: -webkit-center;
    }

    .content-payment-method {
        flex: 1;
        margin: 1em 2em 12px;
        color: #546264;
    }

    .container-form-summary {
        width: 85%;
        margin: auto 2em;
    }

    .contact-info {
        width: 100%;
    }

    .step:not(:first-child)::before {
        background-color: transparent !important;
    }

    .form-steps::before, .form-steps::after {
        background-color: transparent !important;
    }
}

.scroll-message {
    display: none;
}

@media (max-width: 1288px) {
    .container-form-summary {
        margin: 17px 0em;
    }
}

@media (max-width: 782px) {
    .message-pse {
        margin: 10px 0;
    }

    .alert-danger {
        width: 60%;
    }

    .card-payment-method {
        width: 170px;
    }

        .card-payment-method img {
            height: 40px;
            object-fit: cover;
            object-position: center;
        }

    .step:not(:last-child)::after {
        top: 14%;
        left: 62%;
        width: 77%;
    }

    .form-steps {
        position: relative;
        align-items: normal;
        width: 75%;
    }

    .skeleton-login {
        width: 100% !important;
    }

    .scroll-message {
        display: block;
        color: var(--color-green-zona);
        position: sticky;
        bottom: 0;
        left: 0;
        padding: 8px;
        font-size: 11px;
        letter-spacing: 0.4px;
        z-index: 1;
        width: 100%;
        text-align: center;
    }
}

@media (max-width: 600px) {
    .section-name {
        display: initial;
    }

    .section-doc {
        display: initial;
    }

    .type {
        width: 100%;
    }

    .card-payment-method {
        width: 140px;
    }

    .form-steps {
        position: relative;
        width: 95%;
        align-items: normal;
    }

    .col-xs-6, .col-md-6, .col-md-3, .col-xs-12 {
        padding-right: 1px;
        padding-left: 1px;
    }

    .pmz_campo_desple_vence {
        width: 49%;
        margin-right: 0;
    }

    .pilitic-container > span {
        display: block;
    }

    .date-end-tc {
        min-height: 1px;
        padding-right: 1px;
        padding-left: 1px;
        float: left;
        width: 100%;
    }

    .date-end-tc-year {
        width: 48%;
        margin-right: 0;
    }

    .date-end-tc-month {
        width: 48%;
        margin-right: 0;
        float: right;
    }

    .pmz_campo_desple_exp {
        width: 32%;
    }
}

@media (max-width: 400px) {
    .card-payment-method {
        margin: 0 auto 1em;
        width: 45%;
        min-width: 135px;
    }

    .payment-methods-list {
        gap: 4px;
    }

    .card-general {
        min-width: 220px;
    }

    .pilitic-container > span {
        display: flow;
        margin: 0 10px;
    }
}

@media (max-width: 360px) {
    .card-payment-method {
        min-width: 116px;
    }

        .card-payment-method img {
            height: 34px;
        }
}
/* Skeleton loading*/
.skeleton-loader:empty {
    width: 100%;
    height: 15px;
    display: block;
    background: linear-gradient( to right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 80% ), lightgray;
    background-repeat: repeat-y;
    background-size: 50px 500px;
    background-position: 0 0;
    animation: shine 1s infinite;
}

.modal-alert {
    text-align: -webkit-center;
}

.modal-content-alert {
    margin: 4em 2em;
    padding: 1em;
    width: 60%;
    min-width: 60rem;
    color: #EF2122;
    background-color: #fff;
    border: 1px solid #EF2122;
}

.title-alert-danger {
    display: flex;
    align-items: center;
}

@keyframes shine {
    to {
        background-position: 100% 0;
    }
}

.prod--wrapper {
    display: flex;
    width: 95%;
    min-height: 70vh;
    border-radius: 4px;
    padding: 22px 10px;
    font-family: "Calibri", "Arial";
    background-color: #00000000;
    justify-content: center;
    margin: auto;
}

    .prod--wrapper .prod--row {
        display: flex;
        flex-direction: row;
    }

    .prod--wrapper .prod--col {
        display: flex;
        flex-direction: column;
    }

    .prod--wrapper .prod--img {
        width: 20%;
        margin: 0 15px;
        justify-content: center;
    }

        .prod--wrapper .prod--img .prod--img-graphic {
            max-height: 27rem;
            height: 100%;
            vertical-align: top;
            max-width: 100%;
        }

    .prod--wrapper .prod--details {
        width: 90%;
        margin-left: 17px;
        align-self: center;
    }

        .prod--wrapper .prod--details .prod--name {
            margin-bottom: 3px;
            width: 85%;
            display: block;
            max-width: 100%;
        }

            .prod--wrapper .prod--details .prod--name .prod--name-para {
                margin: 0 auto;
            }

            .prod--wrapper .prod--details .prod--name .prod--name-text {
                font-weight: bold;
                font-size: 16px;
                line-height: 23px;
                color: #002877;
                height: 40px;
            }

        .prod--wrapper .prod--details .prod--description {
            margin-bottom: 13px;
        }

            .prod--wrapper .prod--details .prod--description .prod--description-text {
                font-size: 13px;
                line-height: 18px;
                color: #666666;
            }

.content-form {
    margin: 2em 0;
}

.form-dp input {
    margin-top: 2px;
}

.form-dp select {
    margin-top: 2px;
}

.content-form > div {
    margin-bottom: 10px;
}

.row div {
    text-align: left;
}

    .row div > span {
        font-weight: bold;
    }

#Encabezado_Encabezado_ImgEncabezado {
    max-height: 100px !important;
}

/*Tabla estado pago pendiente*/
.card-format_pago_pendiente {
    background-color: #fff;
    max-width: 60em;
    min-width: 20em;
    margin: 0 auto 1em auto;
    border-radius: 8px;
    padding: 0;
    color: #535D60;
    font-size: 14px;
}

    .card-format_pago_pendiente .franja-estado {
        height: 40px;
        border-radius: 4px 4px 0 0;
        color: #fff;
        margin: 10px 0 1em;
        padding: 0 10px;
        font-size: 16px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .card-format_pago_pendiente .texto_informativo {
        text-align: center;
    }


.tabla_pago_pendiente {
    border-collapse: separate; /* Necesario para usar border-spacing */
    border-spacing: 0; /* Inicializa sin espacio */
    width: 100%;
    margin-top: 10px;
    text-align-last: center;
    border-spacing: 0 1em;
}

    .tabla_pago_pendiente th, .tabla_pago_pendiente td {
        text-align: left;
        padding: 10px;
    }

    /* Bordes internos en los headers */
    .tabla_pago_pendiente th {
        border-right: 1px solid #ddd;
    }

        /* Ocultar bordes del primer y último th */
        .tabla_pago_pendiente th:first-child {
            border-left: none;
        }

        .tabla_pago_pendiente th:last-child {
            border-right: none;
        }

    /* Bordes internos en los datos */
    .tabla_pago_pendiente td {
        border-right: 1px solid #ddd;
    }

        /* Ocultar bordes del primer y último td */
        .tabla_pago_pendiente td:first-child {
            border-left: none;
        }

        .tabla_pago_pendiente td:last-child {
            border-right: none;
        }

    /* Contorno estilo card en tbody */
    .tabla_pago_pendiente tbody {
        border: 1px solid #ccc;
        border-radius: 8px;
        box-shadow: rgba(14, 30, 37, 0.12) 0px 2px 4px 0px, rgba(14, 30, 37, 0.32) 0px 2px 16px 0px;
    }

#Contenido_Pendientes_BtnRegresar {
    width: 150px;
}








/* HTML: <div class="loader"></div> */
.loader {
    font-weight: bold;
    font-family: sans-serif;
    font-size: 20px;
    animation: l1 1s linear infinite alternate;
}

    .loader:before {
        color: var(--color-green-zona);
        content: "Cargando..."
    }

@keyframes l1 {
    to {
        opacity: 0
    }
}

/* Loading bar */

.loading-bar {
    position: relative;
    display: grid;
    margin: 2em auto;
    height: 40px;
    width: 80%;
    text-align: center !important;
    color: #777;
}

.margin-loading-bill {
    margin: 0 !important;
}

.span-loader {
    display: block;
    position: relative;
    height: 28px;
    width: 120px;
    border-radius: 37px;
    background-color: #999;
    overflow: hidden;
    border: 1px solid #999;
    margin: auto;
}

    .span-loader:after {
        content: "";
        position: absolute;
        top: 0px;
        left: 0;
        bottom: 0px;
        right: 0;
        background-image: linear-gradient(-45deg, rgb(84 98 105) 25%, #ffffff 25%, #ffffff 50%, #546269 50%, rgb(84 98 105) 75%, #ffffff 75%, #ffffff);
        z-index: 1;
        background-size: 9px 9px;
        overflow: hidden;
        border: 2px solid #f5f5f5;
        border-radius: 26px;
    }

.loading-bar > .span-loader:after, .animate > .span-loader > .span-loader {
    animation: load 3s infinite;
}

@keyframes load {
    0% {
        background-position: 0 0;
    }

    100% {
        background-position: 50px 50px;
    }
}

.btn-loader-form {
    width: 10px;
    height: 10px;
    aspect-ratio: 1;
    border-radius: 50%;
    animation: l5 1s infinite linear alternate;
    align-self: center;
    margin: 2em 1em 1em;
    display: none;
}

@keyframes l5 {
    0% {
        box-shadow: 20px 0 #000, -20px 0 #0002;
        background: #000
    }

    33% {
        box-shadow: 20px 0 #000, -20px 0 #0002;
        background: #0002
    }

    66% {
        box-shadow: 20px 0 #0002,-20px 0 #000;
        background: #0002
    }

    100% {
        box-shadow: 20px 0 #0002,-20px 0 #000;
        background: #000
    }
}


@media (max-width: 768px) {
    /* Contenedor específico para el desplazamiento horizontal en móviles */
    .gridview-container {
        overflow-x: scroll; /* Permitir desplazamiento horizontal */
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch; /* Desplazamiento suave en dispositivos móviles */
        scrollbar-width: thin; /* Mostrar barra de desplazamiento en navegadores compatibles */
    }
}






/* Estilos de la modalidad formulario  */

.form-datos {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 65vh;
    padding: 20px; /* Evita que el contenido pegue a los bordes */
}

    .form-datos .container {
        background: #ffffff;
        border-radius: 24px;
        box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
        width: 100%;
        max-width: 800px;
        overflow: hidden;
        padding: 0;
    }

    .form-datos .form-header {
        background: #2ea18e;
        color: #fff;
        text-align: center;
        padding: 10px 20px;
        border-radius: 24px 24px 0 0;
    }

    .form-datos .descriptive-title {
        text-align: center;
        color: #444;
        margin: 1em 10px;
        font-size: 16px;
    }

    .form-datos .form-header h1 {
        margin: auto;
        font-size: 1.5rem;
    }

    .form-datos .form-content {
        padding: 20px 2.5em;
        display: grid;
        grid-template-columns: repeat(2, 1fr); /* Dos columnas por defecto */
        gap: 15px;
    }

    .form-datos .form-group {
        display: flex;
        flex-direction: column;
    }

        .form-datos .form-group label {
            margin-bottom: 2px;
            font-size: 0.9rem;
            color: #444;
            font-weight: bold;
        }

        .form-datos .form-group input,
        .form-datos .form-group select {
            padding: 4px 10px;
            border: 1px solid #ddd;
            border-radius: 5px;
            font-size: 0.9rem;
            background-color: #f9f9f9;
            outline: none;
        }

            .form-datos .form-group input:focus,
            .form-datos .form-group select:focus {
                border-color: #2ea18e;
            }

    .form-datos .btn-continuar {
        grid-column: span 2;
        background-color: #2ea18e;
        color: #fff;
        padding: 10px;
        font-size: 1rem;
        font-weight: bold;
        border: none;
        border-radius: 5px;
        cursor: pointer;
        text-align: center;
        transition: background-color 0.3s;
    }

        .form-datos .btn-continuar:hover {
            background-color: #248b79;
        }

/* Responsive Design */
@media (max-width: 768px) {
    .form-datos .form-content {
        grid-template-columns: 1fr; /* Una columna en pantallas pequeñas */
    }

    .form-datos .btn-continuar {
        grid-column: span 1; /* Ocupa todo el ancho disponible */
    }

    .form-datos .form-header h1 {
        font-size: 1.2rem;
    }

    .form-datos .form-header p {
        font-size: 0.8rem;
    }

    .form-datos .form-group label {
        font-size: 0.8rem;
    }

    .form-datos .form-group input,
    .form-datos .form-group select {
        font-size: 0.85rem;
    }
}

footer {
    bottom: auto !important;
}

.content-btn {
    min-height: 4em;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 60px;
}

.pmz_principal_bancos, .pmz_enca_logo_comercio {
    display: none;
}

/* Fin modalidad Formulario */


/* PSE Avanza */
.pse-avanza-form {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

/* Cada grupo ocupa 100% en móviles */
.pse-avanza-group {
    width: 100%;
    box-sizing: border-box;
}

/* 3 columnas en pantallas grandes */
@media screen and (min-width: 992px) {
    .pse-avanza-group {
        width: calc(33.333% - 10.67px);
    }
}

/* 2 columnas en pantallas medianas */
@media screen and (min-width: 768px) and (max-width: 991px) {
    .pse-avanza-group {
        width: calc(50% - 8px);
    }
}

/* 1 columna en pantallas pequeñas */
@media screen and (max-width: 767px) {
    .pse-avanza-group {
        width: 100%;
    }
}

/* Personalización adicional si deseas ajustar tipo de persona o banco */
.pse-avanza-razon-social,
.pse-avanza-banco {
    display: flex;
    flex-direction: column;
}

.pse_avanza_pmz_campo_desple_banco {
    padding: 2px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-family: "TitilliumWeb-Regular";
}
/* Fin PSE Avanza*/

/* Botones steps Daviplata*/
.step-active {
    color: #fff;
    font-weight: bold;
    background-color: rgb(237 28 39);
}

.step-inactive {
    color: #fff;
    font-weight: bold;
    background-color: #d9d9d9;
}
