/* start variables */
:root {
    /* Colors: */
    --color-general: #616161;
    --color-primary: #2952AB;

    /* Font/text values */
    --font-body:  400 16px "Poppins", serif;
    --font-title: 700 30px  "exo 2", Arial, Helvetica, sans-serif;
    --font-title-small: 600 18px  "exo 2", Arial, Helvetica, sans-serif;
}
@media only screen and (max-width:767px) {
    :root {
        /* Font/text values */
        --font-body:  400 16px "Poppins", serif;
        --font-title: 700 25px  "exo 2", Arial, Helvetica, sans-serif;
        --font-title-small: 600 18px  "exo 2", Arial, Helvetica, sans-serif;
    }
}
/* end variables */
img{
    width: 100%;
}
body,
p{
    font: var(--font-body);
    color: var(--color-general);
    margin-bottom: 20px;
}
body{
    margin: 0;
}
a{
    transition:0.3s ease
}
strong{
    font-weight: 700;
}
.wrap{
    max-width: 1400px;
    padding-left: 20px;
    padding-right: 20px;
    margin:auto
}

/* start header */
.main-header{
    background-color: white;
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    z-index: 2;
}
.main-header__wrap{
    max-width: 1800px;
    margin: auto;
    padding-top: 60px;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 30px;
}
.main-header__columns{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
/*.main-header__columns > *{
	border:1px solid red
}*/
.main-header__columns-logo{
    width: 180px;
}
.main-header__columns-buttons-control{
    display: flex;
    align-items: center;
    gap:30px;
}
.main-header__columns-buttons-button{
    border-radius: 999em;
    box-shadow: 0 0 10px #ddd;
    display: block;
    padding: 10px 35px;
    text-decoration: none;
    font: 400 14px "Poppins", serif;
}
.main-header__columns-buttons-button--white{
    background-color: white;
    color: var(--color-general);
}
.main-header__columns-buttons-button--blue{
    background-color: var(--color-primary);
    color: white;
}
.main-header__columns-buttons-edit{
    display: flex;
    align-items: center;
    gap:10px;
    font: 400 14px "Poppins", serif;
    text-decoration: none;
    color: var(--color-general);
}
.main-header__columns-buttons-edit-icon{
    width: 40px;
    height: 40px;
    border-radius: 999em;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-general);
}
.main-header__columns-buttons-edit-icon img{
    width: 20px;
}
/* end header */
/* start welcome banner */
.welcome-banner{
    background-size: cover;
    background-position: center;
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.welcome-banner__border-image{
    margin: 0 auto 20px;
    width:145px;
    height:145px;
    border-radius: 999em;
    border:1px solid var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
}
.welcome-banner__image{
    background-size: cover;
    background-position: center;
    width: 140px;
    height: 140px;
    border-radius: 999em;

}
.welcome-banner__control{
    text-align: center;
    max-width: 900px;
    padding: 50px 20px;
}
.welcome-banner__name{
    color: var(--color-general);
    font: 400 16px "Poppins", serif;
}
.welcome-banner__sentence{
    font:var(--font-title);
    color: var(--color-primary);
}
/* end welcome banner */
/* start search */
.search{
    max-width: 1000px;
    margin: auto;
    padding-left: 20px;
    padding-right: 20px;
    margin-top: -28px;
}
.search__control{
    display: flex;
    align-items: center;
    gap:5px
}
.search__control-field{
    border-radius: 999em;
    width: 100%;
    background-color: white;
    border: 0;
    font: var(--font-body);
    columns: var(--color-general);
    padding: 15px 25px;
    box-shadow: 10px 10px 10px #aaa;
}
.search__control-button{
    width: 54px;
    height: 54px;
    border-radius: 999em;
    flex-shrink: 0;
    border:1px solid white;
    background-color: var(--color-primary);
    box-shadow: 10px 10px 10px #aaa;
    background-image: url(../images/icon-search.png);
    background-repeat: no-repeat;
    background-size: 30px;
    background-position: center;
}
/* end search */
/* start plus */
.plus{
    padding: 100px 0;
}
.plus__columns{
    display: grid;
    grid-template-columns: repeat(2 , 1fr);
    grid-column-gap: 20px;
}
.plus__columns-second{
    padding-left: 100px;
}
.plus__title{
    border-bottom: 1px solid var(--color-general);
    padding-bottom: 4px;
    display: inline-block;
}
.plus__columns-title{
    color: var(--color-primary);
    font:var(--font-title);
    font-weight: 400;
}
.banner-boxes{
    background-color: #f1f1f1;
    padding-top: 100px;
    padding-bottom: 100px;
}
.banner-boxes__control{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-column-gap: 50px;
}
.banner-boxes__item-bg{
    background-color: white;
    text-align: center;
    padding: 50px 30px 30px;
    box-shadow: 5px 5px 10px #ddd;
    min-height: 265px;
}
.banner-boxes__item-image{
    object-fit: contain;
    object-position: center;
    height: 70px;
}
.banner-boxes__item-title{
    font: var(--font-title-small);
    color: var(--color-primary);
    margin: 15px 0;
}
.banner-boxes__item-text--orange{
    border-bottom:3px solid #f2a993;
}
.banner-boxes__item-text--blue-light{
    border-bottom:3px solid #7dc2fd;
}
.banner-boxes__item-text--blue-dark{
    border-bottom:3px solid #2952ab
}
.banner-boxes__item-text--blue-green{
    border-bottom:3px solid #2952ab
}
.banner-boxes__item-text--blue-green{
    border-bottom:3px solid #80c9d2
}
.banner-boxes__item--top{
    margin-top: 40px;
}

/* end plus */

/* start cursos */
.cursos{
    padding-top: 100px;
    padding-bottom: 100px;
    background-color: #f8f8f8;
}
.cursos__title{
    border-bottom: 1px solid var(--color-general);
    padding-bottom: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align:center;
    margin: auto 20px;
}
.cursos__subtitle{
    color: var(--color-primary);
    font: var(--font-title);
    text-align:center;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}
.cursos__title-control{
    text-align: center;
    margin-bottom: 20px;
}

.flickity-viewport{
    padding-bottom: 100px;
}
.carousel__control-diapositiva{
    width: calc( 100% / 2 );
}
.carousel__item{
    margin: 0 20px 20px;

}
.carousel__item-image{
    height: 300px;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.number-curso{
    position: absolute;
    color: white;
    top: 20px;
    left: 20px;
    font-size: 30px;
}
.carousel__item-image-percent{
    width: 125px;
    height: 125px;
    background-color: rgba(255, 255, 255, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
}
.carousel__item-image-percent span{
    font: 700 30px  "exo 2", Arial, Helvetica, sans-serif;
    color: var(--color-primary);
}
.carousel__item_text{
    padding: 40px 40px 1px;
    position: relative;
    background-color: white;
    position: relative;
}
.carousel__item-title{
    font: 700 22px "exo 2", Arial, Helvetica, sans-serif;
    text-decoration: none;
    color: var(--color-primary);
    text-align: center;
    display: block;
}
.carousel__item-description{
    text-align: center;
}
.carousel__item-arrow{
    text-align: right;
    margin-right: -20px;
}
.carousel__item-arrow a{
    text-decoration: none;
    color: var(--color-primary);
    font-size: 20px;
    display: block;
    margin-bottom: 10px;
}
.carousel__item-line{
    position: relative;
    display: block;
    width: 80%;
    margin: 5px auto 20px;
    background-color: #80c9d2;
    height: 12px;
    border-radius: 999em;
}
.carousel__item-line-interior{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    background-color: var(--color-primary);
    border-radius: 999em;
}
.carousel__item-percent{
    width: 80%;
    margin: 15px auto 0;
    color: var(--color-primary);
    font: 400 12px "Poppins", serif;
    margin-bottom: 0;
    text-align: right;
}
.carousel__item-coming{
    background-color: var(--color-primary);
    padding: 25px;
}
.carousel__item-coming-title{
    font: 700 22px "exo 2", Arial, Helvetica, sans-serif;
    text-decoration: none;
    color: white;
    text-align: center;
    display: block;
}
.carousel__item-coming-description{
    color: white;
    text-align: center;
    margin-top: 35px;
}
.carousel__item-coming-image{
    width: 100%;
    height: 250px;
    object-fit: cover;
    object-position: center;
    margin-top: 40px;
}
.flickity-page-dots .dot.is-selected{
    background-color: #80c9d2;
}
.flickity-page-dots .dot{
    width: 13px!important;
    height: 13px!important;
}
.flickity-prev-next-button {
    top: 101%!important;
    background-color: transparent!important;
}
.flickity-button-icon{
    display: none;
}
.flickity-prev-next-button.previous:before{
    content: '\f060';
    font: var(--fa-font-solid);
    color: var(--color-general);
    font-size:26px
}
.flickity-prev-next-button.next:before{
    content: '\f061';
    font: var(--fa-font-solid);
    color: var(--color-general);
    font-size:26px
}
.cursos__control{
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-column-gap: 0;
    margin-top: 100px;
}
.control-without-slider{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}
.carousel__control-diapositiva--without-slider{
    width: 100%;
}
.control-without-slider--onlyone{
    grid-template-columns: 1fr;
}

/* end cursos */
/* start footer */
.main-footer{
    position: relative;
    z-index: 2;
}
.main-footer__first{
    background-color:#1a3e8c;
    padding: 30px 0;
}
.main-footer__first-columns{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.main-footer__first-logo{
    width: 220px;
    flex-shrink: 0;
}
.main-footer__first-right{
    display: flex;
    align-items: center;
    gap:40px
}
.main-footer__first-right a {
    color: white;
    text-decoration: none;
    font-size: 14px;
}
.main-footer__first-right-legal ul{
    display: flex;
    align-items: center;
    gap:25px
}
.main-footer__first-right-social a{
    display: flex;
    width:35px;
    height:35px;
    align-items: center;
    justify-content: center;
    background-color: white;
    color: var(--color-primary);
    border-radius: 999em;
}
.main-footer__second{
    background-color: var(--color-primary);
    padding: 15px;
}
.main-footer__second p{
    margin: 0;
    text-align: center;
}
.main-footer__second a{
    color: white;
    text-decoration: none;
    font-size: 12px;
}
/* end footer */
/* start formacion */
.formacion{
    padding: 100px 0;
}
.formacion__wrap{
    max-width: 1000px;
    margin: auto;
    padding-left: 20px;
    padding-right: 20px;
}
.formacion__title{
    border-bottom: 1px solid var(--color-general);
    padding-bottom: 4px;
    display: inline-block;
}
.formacion__subtitle{
    font: var(--font-title);
    color: var(--color-primary);
    max-width: 790px;
}
.formacion__list{
    display: flex;
    flex-direction: column;
    gap:50px;
    margin-top: 100px;
}
.formacion__list-item-control{
    display: flex;
    box-shadow: 0 0 10px #c0c0c0;
    position: relative;
    border-radius: 10px;
    overflow: hidden;
}
.formacion__list-item-image{
    width: 250px;
    flex-shrink: 0;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
}
.formacion__button{
    display: inline-block;
    background-color: var(--color-primary);
    border:1px solid var(--color-primary);
    color: white;
    border-radius: 999em;
    padding: 8px 25px;
    text-align: center;
    text-decoration: none;
    font-size: 12px;
}
.formacion__button:hover{
    background-color: white;
    color: var(--color-primary);
}
.formacion__list-item-percent{
    background-color: #e0f8ff;
    width: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.formacion__list-item-percent span{
    font: 700 45px "exo 2", Arial, Helvetica, sans-serif;
    color: var(--color-primary);
}
.formacion__list-item-text{
    background-color: white;
    padding: 40px;
    position: relative;
}
.formacion__save{
    position: absolute;
    top:10px;
    right: 10px;
    color: var(--color-primary);
    font-size: 20px;
}
.formacion__list-item-text-title{
    font: 700 25px  "exo 2", Arial, Helvetica, sans-serif;
    color: var(--color-primary);
}
.formacion__list-item-image--coming{
    width: 40%;
    flex-shrink: 0;
}
.formacion__list-item-text-description--coming{
    width: 100%;
    background-color: var(--color-primary);
}
.formacion__list-item-text-title--coming{
    color: white;
}
.formacion__list-item-text-description--coming{
    color: white;
}
.formacion__list-item-text--coming{
    background-color: var(--color-primary);
}
.evolucion{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap:20px;
    width: 80%;
}
.evolucion__chapter{
    margin: 0;
    font-size: 11px;
}
.evolucion__percent{
    margin: 0;
    font-size: 12px;
    color: var(--color-primary);
}
.carousel__item-line--control{
    margin-left: 0;
}

.welcome-banner__interior{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 30px;
    padding-left: 15px;
    padding-right: 15px;
}

.person-presentation{
    display: flex;
    align-items: center;
    gap:20px;
}
.person-presentation__border-image{
    width: 120px;
    height: 120px;
    border-radius: 999em;
    border: 1px solid var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
}
.person-presentation__image{
    background-size: cover;
    background-position: center;
    width: 115px;
    height: 115px;
    border-radius: 999em;
}
.person-presentation__name{
    color: var(--color-general);
    font: 400 16px  "exo 2", Arial, Helvetica, sans-serif;
    margin: 0;
}
.person-presentation__puesto{
    color: var(--color-primary);
    font: var(--font-title);
    margin: 0;
}
.welcome-cursos{
    padding: 15px 35px;
    background-color: rgba(255, 255, 255, 0.7);
    display: flex;
    flex-direction: column;
    border-radius: 20px;
    box-shadow: 0 0 10px #c0c0c0;
}
.welcome-cursos__sentence{
    color: var(--color-primary);
    text-align: center;
    margin: 0;
}
.welcome-cursos__progress{
    display: flex;
    align-items: center;
    justify-content: center;
    gap:5px;
    margin-top: -20px;
}
.welcome-cursos__progress-numbers{
    color: var(--color-primary);
    font: 700 50px "exo 2", Arial, Helvetica, sans-serif;
}
.welcome-cursos__progress-numbers--1{
    font-size: 70px;
}
.welcome-cursos__progress-numbers--2{
    font-size: 70px;
    margin-top: 35px;
    margin-left: -15px;
}
.welcome-cursos__progress-numbers--3{
    margin-top: 70px;
    margin-left: -15px;
}
.welcome-cursos__final-sentence{
    color: var(--color-primary);
    text-align: center;
    margin: 10px 0 0;
    font-size: 20px;
}
.box-curso{
    padding: 15px;
    background-color: rgba(255, 255, 255, 0.7);
    display: flex;
    flex-direction: column;
    gap:5px;
    border-radius: 20px;
    box-shadow: 0 0 10px #c0c0c0;
}
.box-curso__icon{
    height: 20px;
    object-fit: contain;
    object-position: center;
}
.box-curso__status{
    font-size: 11px;
    text-align: center;
    margin: 0;
    min-height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.box-curso__number{
    display: block;
    background-color: #e8e8e8;
    font-size: 12px;
    text-align: center;
    padding: 5px;
    margin: 0;
    border-radius: 3px;
    min-width: 80px;
}
/* end formacion */
.mobile-control,
.mobile-bg,
.mobile-menu{
    display: none;
}
.mobile-bg{
    opacity: 0;
    transition: 0.3s ease;
}

/* start media queries */
@media only screen and (max-width:1500px) {

}
@media only screen and (max-width:1200px) {
    .main-header__wrap{
        padding-top: 30px;
    }
    .main-footer__first-logo {
        width: 175px;
    }
    .plus__columns{
        grid-column-gap: 45px;;
    }
    .plus__columns-second {
        padding-left: 0;
    }
    .banner-boxes__control{
        grid-column-gap: 30px;
    }
}
@media only screen and (max-width:991px) {
    .banner-boxes__control{
        grid-template-columns: repeat(2,1fr);
    }
    .banner-boxes__item--top{
        margin-top: 0;
    }
    .banner-boxes__control {
        grid-row-gap: 30px;
    }
    .carousel__control-diapositiva{
        width: calc( 100% / 1 );
    }
    .carousel__control-diapositiva{
        opacity: 0.5;
    }
    .carousel__control-diapositiva.is-selected{
        opacity: 1;
    }
    .formacion__list-item-percent{
        width: 140px;
    }
    .formacion__list-item-image {
        width: 205px;
    }
    .cursos__control {
        display: grid;
        grid-template-columns: repeat(2, 2fr);
    }
    .cursos__control--without-slider{
        grid-template-columns: repeat(1, 1fr);
        grid-row-gap: 40px;
    }
    .cursos__control--without-slider--onlyone{
        grid-template-columns: repeat(2, 1fr);
    }
    .control-without-slider--onlyone{
        grid-template-columns: repeat(1, 1fr);
    }
}
@media only screen and (max-width:767px) {
    .main-header__columns-buttons{
        display: none;
    }
    .plus__columns{
        grid-template-columns: repeat(1,1fr);
        grid-row-gap: 20px;
    }
    .carousel__control-diapositiva {
        width: 100%;
    }
    .main-footer__first-columns{
        flex-direction: column;
        gap:20px
    }
    .box-curso,
    .welcome-cursos{
        display: none;
    }
    .welcome-banner{
        height: 240px;
    }
    .formacion__list-item-control{
        flex-direction: column;
    }
    .formacion__list-item-image{
        width: 100%;
        height: 300px;
    }
    .carousel__item-line{
        width: 100%;
    }
    .evolucion{
        width: 100%;
    }
    .formacion__list-item-percent{
        width: 100%;
        height: 100px;
    }
    .mobile-control{
        display: block;
        font-size: 35px;
        color: var(--color-primary);
        padding: 15px;
    }
    .mobile-bg{
        pointer-events: none;;
        display: block;
        opacity: 1;
        position: fixed;
        top:0;
        right: 0;
        bottom: 0;
        left: 0;
        background-color: rgba(0, 0, 0, 0.0);
        z-index: 10;
    }
    .mobile-bg--open{
        background-color: rgba(0, 0, 0, 0.77);
        pointer-events: auto;
    }
    .mobile-menu{
        display: block;
        position: fixed;
        top: 0;
        right: -310px;
        bottom: 0;
        overflow: auto;
        width: 300px;
        z-index: 11;
        background-color: white;
        transition:0.3s ease
    }
    .mobile-menu--open{
        right: 0;
    }
    .mobile-menu__close{
        color: var(--color-primary);
        text-align: right;
        font-size: 30px;
        padding: 15px;
    }
    .welcome-banner__control--mobile{
        padding-top: 0;
        padding-bottom: 20px;
    }
    .main-header__columns-buttons-control--mobile{
        flex-direction: column;
    }
    .cursos__control {
        grid-template-columns: repeat(1, 2fr);
    }
    .flickity-page-dots{
        bottom: 48px!important;
    }
    .flickity-prev-next-button {
        top: 91% !important;
    }
    .control-without-slider{
        grid-template-columns: repeat(1, 1fr);
        grid-row-gap: 40px;
    }
}
@media only screen and (max-width:575px) {
    .main-header__wrap{
        padding-top: 15px;
        padding-bottom: 15px;
    }
    .banner-boxes__control{
        grid-template-columns: repeat(1,1fr);
    }
    .carousel__item {
        margin: 0;
    }
    .main-footer__first-right,
    .main-footer__first-right-legal ul{
        flex-direction: column;
    }
    .formacion__list-item-percent span{
        font-size: 35px;
    }
    .formacion__list-item-percent{
        height: 75px;
    }
    .formacion__list-item-image{
        height: 200px;
    }
    .formacion__list-item-text{
        padding: 40px 20px;
    }
}

/* start modal
.modal-bg{
	background-color: rgba(0, 0, 0, 0.7);
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
.modal-outline{
	position: fixed;
	background-color: transparent;
	top: 50%;
  	left: 50%;
  	transform: translate(-50%, -50%);
	width: 600px;
	border-radius: 100px;
	border:1px solid white;
	z-index: 3;
}
.modal-login{
	border-radius: 100px;
	background-color: #f5f5f5;
	margin: 40px;
}
.modal-login__control p{
	margin: 0;
}
.modal-login__control{
	max-width: 270px;
	margin: auto;
	padding: 50px 100px;
	display: flex;
	flex-direction: column;
	gap:10px;
	justify-content: center;
	align-items: center;
}
.modal-login__sentence{
	font-size: 14px;
	text-align: center;
}
.modal-login__logo{
	width: 200px;
}
.modal-login__welcome{
	font-weight: 600;
	font-size: 25px;
}
.modal-login__form-field input[type="text"],
.modal-login__form-field input[type="password"]{
	display: block;
    width: calc(100% - 50px);
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 10px 40px 10px 10px;
    margin-bottom: 10px;
    background-position: 95% center;
    background-repeat: no-repeat;
    background-size: 15px;
}
.modal-login__form-field--user{
	margin-top: 20px;
}
.modal-login__form-field-pass{
	color: var(--color-general);
	font-size: 14px;
	text-align: center;
	display: block;
}
.modal-login__form-field-button{
	background-color: var(--color-primary);
	color: white;
	padding: 10px 40px 10px 10px;
	font-size: 14px;
	border:0;
	margin: 20px auto;
	display: block;
	border-radius: 3px;
	background-repeat: no-repeat;
	background-size: 14px;
	background-position: 90% center;
}
.modal-login__form-field-register{
	color: var(--color-general);
	font-size: 14px;
	text-align: center;
	display: block;
}
.modal-login__form-field-register a{
	color: var(--color-primary);
	font-weight: 600;
}
@media only screen and (max-width:767px) {
	.modal-outline{
		width: 500px;
	}
	.modal-login__control{
		padding: 50px 40px;
	}
}
@media only screen and (max-width:575px) {
	.modal-outline{
		width: 90%;
	}
	.modal-login{
		margin: 5px;
	}
	.modal-login__form-field input[type="text"],
	.modal-login__form-field input[type="password"]{
		width: 90%;
	}
	.modal-login__control {
        padding: 30px 40px;
    }
}
 end modal */
.formacion__list-item-text--coming > p{
    color: white!important;
}