/* 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;
}
.carousel{
	margin-top: 100px;
}
.flickity-viewport{
	padding-bottom: 100px;
}
.carousel__control-diapositiva{
	width: calc( 100% / 3 );
}
.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
}
/* 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% / 2 );
	}
	.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;
	}
}
@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;
	}
}
@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 */
