/*
--------------------------------------------------------------------------------------------- 
GENERALES 
---------------------------------------------------------------------------------------------
*/

body{
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: 'Roboto', sans-serif;
    font-weight: normal;
    font-size: 1rem;
    line-height: 1.5;
    color: #8A8C8C;
    position: relative;
    background-color: #FAFBFC;
}

/*
---------------------------------------------------------------------------------------------
HEADER
---------------------------------------------------------------------------------------------
*/

header{
    border-top: 0.5rem solid #D1392C;
    background: #fff;
    margin-bottom: 3rem;
    box-shadow: 0 0 10px rgba(0,0,0,0.2);
    height: 6.25rem;
    display: flex;
    align-items: center;
}

header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

header img{
    width: 8.938rem;
    height: auto;
    margin: 0;
}

header .primer-menu{
    display: flex;
    align-items: center;
}
header .primer-menu a{
    margin-left: 1.25rem;
}

/* Pasos */

header .steps {
    margin-left: auto;
    display: flex;
    flex-direction: row;
    justify-content: start;
}

header .steps a{
    color: #003863;
    display: flex;
    flex-direction: row;
    position: relative;
    text-align: center;
    align-items:center;
    gap: 0.5rem;
}
header .steps a.disabled {
    cursor: default;
    pointer-events: none;
}
header .steps a:hover{
    text-decoration: none;
}

header .steps a .num{
    background: #ECF1F7;
    border-radius: 50%;
    width: 1.875rem;
    height: 1.875rem;
    font-size: 1rem;
    font-weight: 500;
    display: flex;
    justify-content: center;
    align-items: center;
}

header .steps a .step{
    font-size:0.875rem;
    flex-grow: 1;
    font-weight: 500;
}

header .steps a .dot{
    display: inline-block;
    margin-right: 1rem;
    margin-left: 1.25rem;
    border: 0.313rem solid #ffffff;
    background: #DCE5F5;
    border-radius: 50%;
    z-index : 2;
}
header .steps a .dot span:before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    right: 1.635rem;
    width: calc(15% + 0.1rem);
    height: 0.063rem;
    border-bottom: 0.063rem dashed #b3b3b3;
    transform: translateY(-50%);
    z-index: 1;
}
header .steps a .dot span {
    display: block;
    width: 0.25rem;
    height: 0.25rem;
    background: #003863;
    border-radius: 50%;
}

header .steps a.active .num{
    border-color: #FFF9F2;
    color: white;
    background: #003863;
}

header .steps a.active:after {
    background-position: center right;
}
header .steps a.disabled {
    cursor: default;
    pointer-events: none;
}

header .steps a.disabled .dot{
    background: #EDEDED;
}
header .steps a.disabled .dot span {
    border-color: #EDEDED;
    background: #003863;
}
header .steps a.disabled .num{
    background: #ECF1F7;
    color:  #003863;
}

header .steps a.preventClick{
    cursor: default;
    pointer-events: none;
}
/*
---------------------------------------------------------------------------------------------
FOOTER
---------------------------------------------------------------------------------------------
*/

footer{
    background: #FFFFFF;
    color: #003863;
    font-size: 0.85rem;
    padding:  0;
}

/* Ayuda */
footer .background-ayuda {
    position: relative;
    background: linear-gradient(to bottom, #FAFBFC 50%, #D1392C 50%);
}
footer .background-ayuda .container{
    padding-top: 3rem;
    padding-bottom: 3rem;
}
footer .div-ayuda{
    position: relative;
    padding-left: 3.75rem;
    border-radius:1rem;
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    background-color: #003863;
    background-image: url("/comun/img/aisa-logo-watermark.png");
    background-position: -46px -24px;
    background-repeat: no-repeat;
}
footer .info-ayuda{
    width: calc(44%);
    min-width: 25rem;
}
footer .info-ayuda .title-ayuda {
    color: white;
    margin-bottom: 1.25rem;
    font-size: 2rem;
    font-weight: 500;
    text-align: start;
}
footer .info-ayuda .desc-ayuda{
    color: white;
    margin-bottom:1.25rem;
    font-size: 1rem;
    font-weight: 400;
}
footer .info-ayuda .options-ayuda {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap:  0.938rem;
    margin-top: 1.25rem;
}
footer .info-ayuda .options-ayuda a{
    flex: 1 1 calc(50% - 0.938rem);
    padding:0.75rem 1rem 0.75rem 1.5rem;
    background-color: #ffffff;
    border-radius: 0.5rem;
    color: #003863 ;
    font-size: 1rem;
    font-weight:500;
    text-align: start;
    cursor: pointer;
    transition: all 0.3s ease;
    border: 0;
    white-space: nowrap;
}
footer .div-ayuda .img-ayuda{
    flex: 1;
    display: flex;
    justify-content: end;
}

footer .div-ayuda .img-ayuda img{
    width: 25.125rem;
    border-radius:0  1rem 1rem 0;
    height:auto;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 1.5rem;
    padding: 0;
}
.contact-footer{
    margin-top: 1rem;
}
.footer-column li{
    line-height: 1.344rem;
}
.footer-column .social-icons i{
    margin-bottom: 1rem;
    margin-top: 1rem;
    width: 1.875rem;
    height: 1.875rem;
    background-color: #003863 ;
    color:white;
    border-radius: 50%;
    padding-top: 0.5rem;
    padding-left: 0.625rem;
    transition: all 0.3s ease;
}
.footer-column .social-icons i:hover{
    background:#D1392C;
}
.footer-column .social-icons .instagram i{
    padding-left: 0.563rem;
}

.footer-column ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

footer .menu-item a{
    font-size: 0.813rem;
}
footer p{
    margin: 0;
}
footer a{
    color: #003863;
    transition: color .3s ease-out;
}
footer .logo-footer{
    padding:2rem 0 1rem 0;
}
footer .logo-footer img{
    width: 8.313rem;
    height: 4.375rem;
}
footer .title-footer{
    font-size: 1rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
}
.textwidget{
    margin-right: 9rem;
    font-size: 0.813rem;
}
footer i{
    color: #D1392C;
    margin-right: 0.375rem;
}
footer a:hover{
    color: #D1392C;
    text-decoration: none;
}
footer .footer2{
    padding: 1.5rem;
    background: #003863;
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    gap: 1rem;
    margin-top: 1.5rem;

}

footer .footer2 p , footer .footer2 a{
    color: #ECF1F7;
    display: flex;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: 500;
}
footer .footer2 p:nth-child(2){
    font-weight: 400;
}
footer .footer2 i{
    color: #ECF1F7;
    margin-right: 1rem;
    display: flex;
    align-self: center;
}
/*.menu-menu-footer-container a {*/
/*    font-size:1rem;*/
/*}*/


/*
---------------------------------------------------------------------------------------------
MAIN
---------------------------------------------------------------------------------------------
*/

main{
    margin-bottom: 2rem;
}

/*
---------------------------------------------------------------------------------------------
BOOTSTRAP
---------------------------------------------------------------------------------------------
*/
.form-control::placeholder{
    color: #888;
}

.custom-control-label::before,
.custom-control-label::after{
    top: 0.1rem
}

.mb-6{
    margin-bottom: 2rem;
}

.btn{
    border-radius: 1.5625rem;
    padding: 0.75rem 2.5rem;
    font-weight: 500;
}
.btn-sm{
    border-radius: 1.3125rem;
    padding: 0.5rem 1.75rem;
    font-size: 1rem;
}
.btn-outline-primary{
    background-color: #fff;
}

.btn-primary.disabled,
.btn-primary:disabled,
.btn-secondary.disabled,
.btn-secondary:disabled {
cursor: not-allowed;
}

/*
---------------------------------------------------------------------------------------------
MEDIAQUERIES
---------------------------------------------------------------------------------------------
*/


/* Desktop */
@media (max-width: 1024px) {
    main .steps a .num {
        width: 2.5rem;
        height: 2.5rem;
        padding-top: 0.625rem;
        font-size: 0.8rem;
    }
    main .steps a .step{
        font-size: 0.75rem;
    }

    footer .div-ayuda {
        height: auto;
        overflow: hidden;
        min-height: 24.5rem;
        display: flex;
        align-items: stretch;
    }
    footer .info-ayuda{
        margin-top: 4rem;
    }
    footer .info-ayuda .desc-ayuda {
        margin-right: 1rem;
    }

    footer .info-ayuda .options-ayuda button {
        flex: none;
        width: 14.188rem;
    }
    footer .div-ayuda .img-ayuda {
        flex: 1;
        display: flex;
        align-items: center;
    }
    footer .div-ayuda .img-ayuda img{
        width: 100%;
        height: 100%;
        max-width: 21.75rem;
        padding-left: 0;
        object-fit: cover;
        object-position: right;
    }
}

/*Tablet*/
@media (max-width: 991px) {
    header .steps a .step {
        display: none;
    }

    footer .div-ayuda{
        padding-left: 2.75rem;
    }
    footer .info-ayuda{
        margin: 2.5rem 1rem 2.5rem 0;
    }
    footer .info-ayuda .title-ayuda{
        font-size: 1.938rem;
    }
    footer .info-ayuda .options-ayuda {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }
    footer .info-ayuda .options-ayuda button{
        padding: 0.5rem 1rem;
        width: 100%;
    }
    footer .info-ayuda .desc-ayuda{
        font-size: 0.813rem;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }
    .textwidget{
        display: flex;
        flex-direction: column;
    }
    .social-icons{
        display: flex;
        justify-content: start;
    }

    .footer-column:first-child {
        grid-column: span 3;
    }

    .footer-column:nth-child(2),
    .footer-column:nth-child(3),
    .footer-column:nth-child(4) {
        grid-column: span 1;
    }

    .footer-column:nth-child(3){
        margin-right: 6rem;
    }

}

/*Movil horizontal*/
@media (max-width: 767px){
    header img{
        width: 11.875rem;
    }
    header .steps a{
        display: none;
    }
    header .steps a.active:not(.checked){
        display: flex;
    }
    header .steps a::after{
        background: transparent;
    }

    footer p:first-child{
        margin-bottom: 0.75rem;
    }

    footer .div-ayuda {
        padding: 2rem;
    }
    footer .div-ayuda .img-ayuda{
        display: none;
    }
    footer .info-ayuda{
        width: 100%;
        min-width: unset;
        margin: 0;
        display: flex;
        flex-direction: column;
        align-items: start;

    }
    footer .info-ayuda .options-ayuda,
    footer .info-ayuda .options-ayuda a{
        width: 100%;
    }
    footer .info-ayuda .desc-ayuda{
        text-align: start;
        font-size: 1rem;
    }


}

/*Movil verical*/
@media (max-width: 575px) {

    header img{
        width: 8.5rem;
    }

    header .steps{
        margin-left: unset;
    }
    header .steps a .dot {
        display: none;
    }

    .contact-footer .textwidget{
        display: flex;
        flex-direction: column;
        margin-right: 0;
    }
    .social-icons{
        display: flex;
        justify-content: center;
    }
    .footer-column .social-icons i{
        padding: 0.5rem;
    }
    footer .logo-footer, footer .footer-grid{
        text-align: center;
    }
    .footer-grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }
    .footer-column:first-child {
        grid-column: span 1;
    }
    .footer-column {
        grid-column: span 1;
    }
    .contact-footer .px-425{
        padding: 0 1rem;
    }
    .footer-column:nth-child(3){
        margin-right: 0;
    }
    footer .title-footer {
        margin-top: 0.75rem;
    }

    footer .footer2 {
        flex-direction: column;
        padding: 1rem 0;
        gap: 0;
    }
}

.daterangepicker {
    font-family: inherit;
    color: #003863;
}

.daterangepicker .calendar-table th,
.daterangepicker .calendar-table td{
    font-size: 0.875rem;
    padding: 0.625rem;
}

.daterangepicker td.in-range{
    background-color: #ECF1F7;
}

.daterangepicker td.active,
.daterangepicker td.active:hover{
    background-color: #003863;
}
