/*----------------------------------- Globales -----------------------------------*/

*,
*::before,
*::after {
	padding: 0;
	margin: 0;
	text-decoration: none;
	list-style: none;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}


html {
	font-size: 16px;
}

body {
	background-color: #CCE9EF;
}

img {
	max-width: 100%;
	height: auto;
}




h1 {
	font-size: 2.1rem;
}

h2 {
	font-size: 1.9rem;
}

h3 {
	font-size: 1.6rem;
}

h4 {
	font-size: 1.3rem;
}

a, p, span {
	font-size: 1rem;
	line-height: 1.7;
}




@font-face {
	font-family: "Monserrat-Semibold";
	src: url("../../fonts/Montserrat-SemiBold.ttf") format("truetype");
}

@font-face {
	font-family:"Monserrat-Bold";
	src: url("../../fonts/Montserrat-Bold.ttf") format("truetype");
}

@font-face {
	font-family:"Bodoni-06-Bold";
	src: url("../../fonts/Bodoni-06-Bold.otf") format("truetype");
}

@font-face {
	font-family:"Monserrat-Medium";
	src: url("../../fonts/Montserrat-Medium.ttf") format("truetype");
}

@font-face {
	font-family:"Monserrat-Regular";
	src: url("../../fonts/Montserrat-Regular.ttf") format("truetype");
}

@font-face {
	font-family:"Monserrat-Light";
	src: url("../../fonts/Montserrat-Light.ttf") format("truetype");
}





















.main-container {
	background-color: #EBEBEB;
}

.main-container img {
	width: 100%;
	max-height: 100vh;
}


.btn {
	display:inline-block;
	padding:0.5rem 1.5rem;
	margin-bottom:0;
	font-size:1rem;
	font-weight:400;
	line-height:1.42857143;
	text-align:center;
	white-space:nowrap;
	vertical-align:middle;
	-ms-touch-action:manipulation;
	touch-action:manipulation;
	cursor:pointer;
	-webkit-user-select:none;
	-moz-user-select:none;
	-ms-user-select:none;
	user-select:none;
	background-image:none;
	border:1px solid transparent;
	border-radius:4px;
	font-family: 'Monserrat-Bold';
	text-transform: uppercase;
}


.btn-blue {
	color: #CCC;
	background-color: #0F4C81;
}

.btn-aqua {
	color: #0F4C81;
	background-color: #64DDB4;
}

.btn-gray {
	color: #0F4C81;
	background-color: #EBEBEB;
}

.btn-transparent {
	padding: 0.4rem 1.5rem;
	color: #0F4C81;
	background-color: #EBEBEB;
	border: 3px solid #64DBB4;
}





.container-header {
	width: 95%;
	margin:0 auto;
}


.container-menu {
	width: 85%;
	max-width: 1200px;
	margin: 0 auto;
}




.icon {
	max-width: 2.8rem;
}

.icon-alt {
	display: inline-block;
	max-width: 3rem;
	border-radius: 50%;
	margin-left: 5px;
	line-height: 0;
}


.text-center {
	text-align: center;
}

.text-left {
	text-align: left;
}




.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex-2 div {
	flex-basis: calc(50% - 1rem);
}

.flex-3 div {
	flex-basis: calc(33.33% - 2rem);
}

@media screen and (max-width: 940px) {
	.flex-2 div {
		flex-basis: 100%;
	}
}









a.scroll-top {
    color: #fff;
    display: none;
    width: 40px;
    height: 40px;
    position: fixed;
    z-index: 1000;
    bottom: 50px;
    right: 30px;
    font-size: 20px;
    background: #64DBB4;
    border-radius: 3px !important;
    text-align: center;
    border: 1px solid hsla(0, 0%, 78%, 0.3)
}
a.scroll-top i {
    position: relative;
    top: 3px;
    font-size:1.5em;
}



@media screen and (max-width: 940px) {
	.container-menu {
		width: 90%;
	}
}



/*----------------------------------- End Globales -----------------------------------*/






/*----------------------------------- Header -----------------------------------*/

.header {
	min-height: 62px;
	background-color: #EBEBEB;
	color: white;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 1000;
	width: 100%;
}

.header a {
	color:white;
	text-decoration: none;
	text-transform: uppercase;
}


.header-style-color,
.header-style-alt-color {
	transition: all 0.5s linear;
}


.header-style-color {
	background-color: #EBEBEB;
	box-shadow: 0px 2px 3px rgba(0,0,0,.5);
}

.header-style-color .navigation ul li a:hover {
	background-color: #C8C8C8;
}

.header-style-color .navigation ul li a {
	color: #262626;
}



.header-style-alt-color {
	/*background-color: #CCE9EF;
	opacity: 0.9;*/
	background-color: transparent;
	
}

.header-style-alt-color .navigation ul li a:hover {
	background-color: #B6D3D9;
}

.header-style-alt-color .navigation ul li a {
	color: #262626;
}



.header-style-alt-color .navigation ul li > .btn,
.header-style-color .navigation ul li > .btn {
	color: #CCC;
	font-family: 'Monserrat-Bold';
}

.header-style-alt-color .navigation ul li > .btn:hover,
.header-style-color .navigation ul li > .btn:hover {
	background-color: #0F4C81;
}










.logo,
.logo-alt {
	transition: all 0.1s linear;
}


.logo-alt {
	max-width: 8rem;
	
}

.logo {
	max-width: 12rem;
	padding: 0;
}


@media screen and (max-width: 850px) {
	.logo {
		max-width: 11rem;
		margin-top: 0.5rem;
		margin-bottom: 0.5rem;
	}

	.logo-alt {
		margin-top: 0.5rem;
		margin-bottom: 0.5rem;
	}
}














.menu-icon {
	display: none;
	font-size: 1.5rem;
}





.logo-nav-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

.navigation > ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	align-items: center;
}

.navlist li {
	display: inline-block;
}

.navigation ul li a {
	display: block;
	padding: 0.8rem 0.5rem;
	font-size: 1rem;
	font-family: 'Monserrat-Semibold';
}

.navigation ul li a:hover {
	transition: all 0.4s linear;
	border-radius: 5px;
}


.navigation ul li .btn-blue {
	display: block;
	margin-left: 0.5rem;
	padding: 0.5rem 1rem;
	color: #262626;
	font-size: 1rem;
	text-transform: uppercase;
}









.submenu {
	width: 20rem;
	display: block;
	position: absolute;
	border-top: 1px solid #989898;
	background-color: #EBEBEB;
	z-index: 10;
	top: 5rem;
	opacity: 0;
	visibility: hidden;
}

.submenu::before {
	content: "";
	position: absolute;
	top: -2.5rem;
	left: 3rem;
}



.submenu li {
	display: block;
	line-height: 3rem;
}




@media only screen and (min-width: 768px) {

	.submenu {
		transition: all 0.4s ease;
		margin: 0;
		padding: 0;
	}

	.navlist li:hover > .submenu {
		top: 5rem;
		opacity: 1;
		visibility: visible;
		padding: 0;
		margin: 0;
	}
}


@media only screen and (min-width: 851px) and (max-width: 911px) {

	.header-style-color .logo {
		max-width: 10rem;
	}

	.header-style-color .navigation ul li a {
		font-size: 0.9rem;
	}
}

@media only screen and (max-width: 850px) {

	.header-style-alt-color {
		background-color: #EBEBEB;
		box-shadow: 0px 2px 3px rgba(0,0,0,.5);
	}

	.header-style-color .container-header {
		margin: 8px auto;
	}

	.menu-icon {
		display: block;
		cursor: pointer;
		padding: 0.5rem 1rem;
		/*background-color: #C71616;
		border-radius: 30px;*/
		color: #262626;
	}

	.navigation {
		width: 100%;
	}

	.navigation > ul {
		display: none;
	}

	.navigation ul.show {
		display: block;
		border-top: 1px solid #262626;
	}

	.navigation ul li {
		display: block;
	}

	.navigation ul li a {
		display: block;
		padding: 0.5rem 0;
	}

	.navigation ul li a:hover {
		background-color: #C8C8C8;
		transition: all 0.4s linear;
		border-radius: 5px;
	}



	.navigation ul li.icon-responsive {
		display: inline-block;
		margin-right: 1rem;
	}

	.navigation ul li:last-child {
		margin-bottom: 1rem;
	}





	.submenu {
		position: initial;
		margin-left: 1.5rem;
		max-height: 0;
	}
	
	.submenu-responsive {
		opacity: 1;
		visibility: visible;
		max-height: initial;
		width: auto;
		padding: 0;
		margin-left: 1.5rem;
		border-bottom: 1px solid #989898;
	}
	
}



/*----------------------------------- End Header -----------------------------------*/













/*----------------------------------- Home -----------------------------------*/


.home-1 {
	position: relative;
	/*display: inline-block;*/
}

.img-home-1 {
	object-fit: cover;
	object-position: center;
}

.img-home-1-responsive {
	display: none;
}


.home-1 div,
.home-7 div {
	position: absolute;
}


.desc-home-1 {
	width: 33%;
	left: calc(100vw - 76.5%);
	top: 60%;
	transform: translate(-50%, -20%);
}

.desc-home-1 p{
	font-family: 'Monserrat-Medium';
	text-align: center;
}


.btn-home-1 {
	left: calc(100vw - 76.5%);
	top: 75%;
	transform: translate(-50%, 10%);
}

@media screen and (max-width: 859px) {

	.desc-home-1 {
		width: 36%;
	}
	.desc-home-1 p {
		font-size: 0.85rem;
	}
	.btn-home-1 {
		transform: translate(-50%, 50%);
	}
	
}


@media screen and (max-width: 700px) {

	.img-home-1 {
		display: none;
	}

	.img-home-1-responsive {
		display: block;
		background-color: #C1E5ED;
	}

	.img-home-1-responsive-smile {
		padding-top: 1rem;
	}


	.home-1 div {
		position: relative;
	}

	.desc-home-1 {
		width: 100%;
		top: 0;
		left: 0;
		transform: none;
		background-color: #C1E5ED;
		padding-top: 1rem;
		padding-bottom: 2rem;
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.btn-home-1 {
		width: 100%;
		top: 0;
		left: 0;
		transform: none;
		background-color: #C1E5ED;
		padding-bottom: 2rem;
		text-align: center;
	}
}








.home-2, 
.home-3, 
.home-4, 
.home-5, 
.home-6 {
	padding: 2rem 0;
}

.container-home-desc {
	width: 50%;
	margin: 1.5rem auto; 
}

.side-bar {
	text-align: center;
	border-left: 7px solid #64DDB4;
}

.container-home-desc p {
	line-height: 2.5rem;
	font-size: 1.4rem;
	font-family: 'Bodoni-06-Bold';
}

.container-home-desc p:not(:last-child) {
	margin-bottom: 1rem;
}

@media screen and (max-width: 1000px) {

	.container-home-desc {
		width: 85%;
		margin: 1.5rem auto;
	}

	.container-home-desc p {
		text-align: center;
		font-size: 1.2rem;
		line-height: 2rem;
	}
}

@media screen and (max-width: 540px) {

	.container-home-desc {
		width: 100%;
		margin: 0.5rem;
	}

	.container-home-desc p {
		text-align: center;
		font-size: 1rem;
		line-height: 1.3rem;
		margin-right: 1rem;
	}
}














.background-blue {
	background: linear-gradient(to bottom, #64DDB4 0%, #64DBB4 40%, #A0E6F0 40%, #A0E6F0 100%);
	padding: 1.2rem;
}


.background-blue-content {
	background-color: #0F4C81;
	padding: 1rem;
	display: flex;
    align-items: center;
    justify-content: space-around;
    flex-wrap: wrap;
    color: #CCC;
}

.line-white {
	border-top: 1px solid #CCC;
	width: 95%;
	margin: 0 auto;
}

.background-blue-content div {
	flex-basis: calc(50% - 2rem);
}


.background-blue-content div p:not(:last-child) {
	margin-bottom: 1rem;
}

.background-blue-content div h1 {
	font-family: 'Bodoni-06-Bold';
	line-height: 1.4;
}

.background-blue-content div h4 {
	font-family: 'Monserrat-Medium';
	line-height: 1.8;
	margin: 1rem auto;
}

.background-blue-content div p {
	font-family: 'Monserrat-Regular';
}


@media screen and (max-width: 767px) {

	.background-blue-content div {
		flex-basis: 100%;
	}

	.background-blue-content .text-center {
		margin-top: 2rem;
	}
}

@media screen and (max-width: 540px) {

	.background-blue-content p {
		font-size: 1rem;
		line-height: 1.3rem;
	}
}

@media screen and (max-width: 360px) {

	.background-blue-content h4 {
		font-size: 1rem;
	}
}










/*Home 4*/

.cell {
	width: 50%;
	height: 90vh;
	display: inline-block;
	margin: 0 1rem;
	overflow: hidden;
}

.cell img {
	width: 100%;
	height: 90vh;
	object-fit: cover;
}

.flickity-page-dots .dot {
	background-color: #64DDB4;
}

@media screen and (max-width: 1110px) {
	.cell {
		width: 65%;
	}
}

@media screen and (max-width: 991px) {
	.cell {
		width: 65%;
	}
}

@media screen and (max-width: 850px) {
	.cell {
		width: 100%;
		height: 400px;
	}
	.cell img {
		height: 400px;
	}
}

@media screen and (max-width: 500px) {
	.cell {
		height: 300px;
	}
	.cell img {
		height: 300px;
	}
}

@media screen and (max-width: 300px) {
	.cell {
		height: 200px;
	}
	.cell img {
		height: 200px;
	}
}











.background-green {
	background-color: #64DBB4;
	padding: 1.5rem;
}

.background-green div {
	width: 50%;
	margin: 0 auto;
}

.background-green div:first-child {
	margin-bottom: 1.5rem;
}

.background-green div p {
	font-family: 'Monserrat-Medium';
	line-height: 2.2;
}





.home-6 img {
	max-height: 75vh;
	object-fit: cover;
	object-position: center;
}

.home-6-content {
	padding: 3.5rem 0 1.5rem 0;
}


.home-6-content div:last-child p{
	width: 85%;
	margin: 0 auto;
	font-family: 'Bodoni-06-Bold';
	line-height: 2;
}

.home-6-left {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
}

.home-6-left div:first-child {
	text-align: left;
	margin-left: 2rem;
}

.home-6-left div:first-child h3 {
	color: #0F4C81;
	font-family: 'Bodoni-06-Bold';
}


@media screen and (min-width: 941px) {

	.home-6-left div:last-child {
		text-align: left;
		margin-left: 5.5rem;
	}	

}


@media screen and (max-width: 940px) {

	.home-6-left div:first-child {
	    margin-left: 1rem;
	}

	.home-6-content > div:last-child {
		border-left: 7px solid #64DDB4;
		padding-left: 1rem;
	}

	.home-6-content > div:last-child p {
		margin-top: 2rem;
		width: 100%;
	}

	.home-6-left {
		margin-bottom: 1rem;
	}
}

@media screen and (max-width: 768px) {

	.background-green div {
		width: 90%;
	}
}


@media screen and (max-width: 940px) {

	.home-6 .home-6-left div:last-child {
		margin-top: 2rem;
	}
}

@media screen and (max-width: 300px) {

	.home-6-left h3 {
		font-size: 1.3rem;
	}
}









.home-7 {
	margin-top: 1.5rem;
	position: relative;
	/*display: inline-block;*/
	background-color: #A0E6F0;
}

.img-home-7-responsive {
	display: none;
}

.btn-home-7 {
	right: 5%;
	top: 65%;
	transform: translate(-2%, -20%);
}


@media screen and (max-width: 549px) {

	.img-home-7 {
		display: none;
	}

	.img-home-7-responsive {
		 display: block;
	}

	.img-home-7-responsive:last-of-type {
		max-width: 50%;
		margin-left: 25%;
	}


	.home-7 div {
		position: relative;
	}

	.btn-home-7 {
		right: 0;
		top: 0;
		transform: none;
		padding-top: 2rem;
		padding-bottom: 2rem;
		text-align: center;
	}
}


/*------------------------------ End Home -----------------------------------*/













/*------------------------------ Especialidades -----------------------------------*/

.especialidades-1 {
	position: : relative;
}

.especialidades-1 img {
	object-fit: cover;
	object-position: center;
}

.side-bar-especialidades {
	padding-bottom: 5rem;
	margin-top: 5rem;
}


.flex-especialidadaes-smile {
	border-left: 13px solid #64DDB4;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.desc-especialidades-smile {
	flex-basis: 100%;
	text-align: center;
	padding: 2rem;
}
.desc-especialidades-smile p {
	font-size: 1.4rem;
	font-family: 'Bodoni-06-Bold';
}


.img-especialidades-smile {
	flex-basis: 15%;
	margin-top: 2rem;
}




.flex-2-especialidades {
	border-left: 13px solid #64DDB4;
	flex-wrap: nowrap;
	padding-top: 5rem;
}

.flex-2-especialidades:last-child {
	padding-bottom: 5rem;
}

.flex-2-especialidades div:first-child {
	flex-basis: calc(35% - 1rem);
}

.flex-2-especialidades div:last-child {
	flex-basis: calc(65% - 1rem);
	border-top: 7px solid #0F4C81;
}

.flex-2-especialidades h3 {
	color: #0F4C81;
	font-family: 'Bodoni-06-Bold';
}

.flex-2-especialidades p {
	font-family: 'Monserrat-Medium';
}

.flex-2-especialidades h3,
.flex-2-especialidades a {
	margin: 1rem auto;
}
.flex-2-especialidades img {
	height: 100%;
}


.flex-2-especialidades div:last-child .btn-transparent {
	margin-left: 1rem;
}


@media screen and (max-width: 1000px) {

	.flex-2-especialidades div:first-child {
		flex-basis: calc(45% - 1rem);
	}

	.flex-2-especialidades div:last-child {
		flex-basis: calc(55% - 1rem);
	}
}

@media screen and (max-width: 800px) {

	.flex-2-especialidades {
		flex-wrap: wrap;
		border-bottom: 7px solid #0F4C81;
		padding-bottom: 2rem;
	}

	.flex-2-especialidades div:first-child,
	.flex-2-especialidades div:last-child {
		flex-basis: 100%;
	}

	.flex-2-especialidades div:last-child {
		margin-left: 1rem;
		border-top: none;
	}

	.flex-2-especialidades p {
		text-align: justify;
	}
}

@media screen and (max-width: 800px) {

	.img-especialidades-smile {
		flex-basis: 25%;
	}
}

@media screen and (max-width: 480px) {

	.img-especialidades-smile {
		flex-basis: 50%;
	}
}

@media screen and (max-width: 373px) {

	.flex-2-especialidades div:last-child .btn-transparent,
	.flex-2-especialidades div:last-child .btn-aqua {
		display: block;
	}

	.flex-2-especialidades div:last-child .btn-transparent {
		margin-left: 0;
	}
}

/*------------------------------ End Especialidades -----------------------------------*/








/*------------------------------ Especialistas -----------------------------------*/

.especialistas-1 {
	position: relative;
}

.especialistas-1 img {
	object-fit: cover;
	object-position: center;
}






.side-bar-especialistas {
	border-left: 13px solid #64DDB4;
	margin: 3rem auto; 
}


.flex-especialistas-smile {
	
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.desc-especialistas-smile {
	flex-basis: 100%;
	text-align: center;
	padding: 2rem;
}
.desc-especialistas-smile p {
	font-size: 1.4rem;
	font-family: 'Bodoni-06-Bold';
	line-height: 1;
}


.img-especialistas-smile {
	flex-basis: 15%;
	margin-top: 2rem;
}





.especialistas-3 {
	margin-top: 10rem;
	padding: 2rem 0;
}


.especialistas-container .flex {
	margin-bottom: 5rem;
}


.especialistas-container div {
	margin-bottom: 2rem;
}

.especialistas-container .flex {
	justify-content: space-around;
}

.especialista-desc h3, 
.especialista-desc h4 {
	color: #0F4C81;
}

.especialista-desc h3 {
	font-family: 'Bodoni-06-Bold';
	margin-bottom: 0.5rem;
	font-weight: 700;
}

.especialista-desc h4 {
	font-family: 'Monserrat-Medium';
	font-weight: 500;
	margin-bottom: 1.5rem;
}

.especialista-desc p {
	font-family: 'Monserrat-Medium';
}

.bar-green-especialistas {
	width: 100%;
	border-bottom: 5px solid #64DBB4;
	margin-bottom: 1.5rem;
}

.especialista-desc p:not(:last-child) {
	margin-bottom: 1rem;
}


.especialista-image {
	padding-left: 6rem;
	padding-right: 6rem;
}

.especialista-desc-alt h3,
.especialista-desc-alt h4,
.especialista-desc-alt p {
	text-align: right;
}


@media screen and (max-width: 1000px) {

	.especialistas-container .flex {
		align-items: center;
	}	

}

@media screen and (max-width: 940px) {

	.especialistas-container .flex-2 .especialista-image {
		flex-basis: 60%;
	}

	.especialista-desc-alt {
		order: 1;
	}
}

@media screen and (max-width: 800px) {

	.especialista-image {
		padding-left: 0;
		padding-right: 0;
	}
}

@media screen and (max-width: 800px) {

	.img-especialistas-smile {
		flex-basis: 25%;
	}
}

@media screen and (max-width: 480px) {

	.img-especialistas-smile {
		flex-basis: 50%;
	}
}

@media screen and (max-width: 400px) {

	.especialistas-container .flex-2 .especialista-image {
    	flex-basis: 100%;
	}

	.especialista-desc-alt h3,
	.especialista-desc-alt h4,
	.especialista-desc h3,
	.especialista-desc h4 {
		text-align: left;
	}

	.especialista-desc-alt p,
	.especialista-desc p {
		text-align: justify;
	}

}

/*------------------------------ End Especialistas -----------------------------------*/














/*------------------------------ Contacto -----------------------------------*/


.contacto-1 {
	position: relative;
}

.contacto-1 img {
	object-fit: cover;
	object-position: center;
}

.contacto-3 {
	margin-bottom: 3rem;
}




.side-bar-contacto {
	border-left: 13px solid #64DDB4;
	margin: 3rem auto; 
}


.flex-contacto-smile {
	
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.desc-contacto-smile {
	flex-basis: 100%;
	text-align: center;
	padding: 2rem;
}
.desc-contacto-smile p {
	font-size: 1.4rem;
	font-family: 'Bodoni-06-Bold';
	line-height: 1;
}


.img-contacto-smile {
	flex-basis: 15%;
	margin-top: 2rem;
}





.background-aqua-contacto {
	background-color: #A0E6F0;
}

.flex-contacto,
.flex-contacto-item {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex-contacto div {
	flex-basis: calc(25% - 1rem);
}

.flex-contacto-item div {
	flex-basis: 100%;
	text-align: center;
}


.flex-contacto-item-img {
	margin: 2rem auto;
}
.flex-contacto-item img {
	width: 25%;
}

.flex-contacto-item-desc {
	margin-bottom: 2rem;
}

.flex-contacto-item-desc div:first-child {
	margin-bottom: 1rem;
}




.contacto-correo {
	display: flex;
	flex-basis: 94% !important;
	justify-content: flex-end;
	align-items: center;
	margin-top: -7rem;
}

.contacto-correo-img {
	flex-basis: 5% !important;
}

.contacto-correo-desc {
	flex-basis: 25% !important;
	margin-left: 1rem;
}



.flex-contacto h3 {
	font-family: 'Monserrat-Bold';
	color: #0F4C81;
	font-size: 1.3rem;
}

.flex-contacto h4 {
	font-family: 'Monserrat-Regular';
	color: #0F4C81;
}
/*
.contacto-line-height-h4 h4 {
	line-height: 1.85;
}
*/



@media screen and (max-width: 1280px) {

	.contacto-correo {
		display: flex;
		flex-basis: 100% !important;
		justify-content: center;
		align-items: center;
		margin-top: 0;
		padding-bottom: 2rem;
	}

}


@media screen and (max-width: 1200px) {

	.flex-contacto div {
	    flex-basis: 50%;
	}
	.flex-contacto-item {
		flex-basis: 100% !important;
	}

	.flex-contacto-item-desc {
		flex-basis: 100% !important;
	}

	.flex-contacto-item img {
	    width: 40%;
	}

	.contacto-correo {
		margin-top: 1rem;
	}

	.contacto-correo-img {
	    flex-basis: 8% !important;
	}
}

@media screen and (max-width: 500px) {

	.flex-contacto div {
	    flex-basis: 100%;
	}

	.flex-contacto-item img {
	    width: 30%;
	}

	.contacto-correo {
		flex-wrap: wrap;
	}

	.contacto-correo-img {
		flex-basis: 100% !important;
		text-align: center;
	}
	.contacto-correo-img img {
		width: 30%;
	}
	
	.contacto-correo-desc {
	    flex-basis: 100% !important;
	    margin-left: 0;
	    text-align: center;
	}

	.contacto-correo-desc h4 {
	    font-size: 1rem;
	}
}










.formulario-container {
	background-color: #0F4C81;
	padding-top: 4rem;
	padding-bottom: 4rem;
	color: #CCC;
}

.side-bar-contacto {
	border-left: 7px solid #64DDB4;
}

.side-bar-contacto > div {
	margin-left: 1rem;
}

fieldset {
	border: none;
}

legend {
	margin-bottom: 1rem;
}

legend,
label span {
	font-family: 'Monserrat-Regular';
}

.form-control-container {
	width: 100%;
	margin: 1rem auto;
}

.form-control-container div {
	display: inline-block;
}

.form-control-container div:first-child {
	width: 10%;
}

.form-control-container div:last-child {
	width: 89%;
}

.form-control-container:last-child div {
	width: 100%;
}



.form-control-container-mensaje div:first-child {
	margin-bottom: 1rem;
}
.form-control-container-mensaje div {
	display: block;
}




.form-control {
	width: 100%;
	background-color: #0F4C81 !important;
	color: #CCC;
	min-height: 30px;
}

input.form-control[type=text] {
	border: none;
	border-bottom: 1px solid #64DBB4;
	font-family: 'Monserrat-Regular';
}

textarea.form-control {
	border: 2px solid #64DBB4;
	font-family: 'Monserrat-Regular';
	resize: none;
}

.form-control:focus {
	outline: none;
}




@media screen and (max-width: 900px) {

	legend h3 {
		text-align: left;
	}

	.form-control-container div {
	    display: block;
	}

	.form-control-container div:first-child, 
	.form-control-container div:last-child {
		width: 100%;
	}
}


@media screen and (max-width: 800px) {

	.img-contacto-smile {
		flex-basis: 25%;
	}
}

@media screen and (max-width: 480px) {

	.img-contacto-smile {
		flex-basis: 50%;
	}
}

/*------------------------------ End Contacto -----------------------------------*/
















/*------------------------------ Footer -----------------------------------*/

.footer-main {
	background-color: #262626;
	padding: 2rem 0;
	border-bottom: 1px solid white;
}

.footer-main h3, 
.footer-main p,
.footer-sec p {
	color: white;
}

.footer-main h3 {
	font-family: 'Bodoni-06-Bold';
}

.footer-main p,
.footer-main span {
	font-family: 'Monserrat-Medium';
}

.footer-sec p {
	font-family: 'Monserrat-Light';
	font-size: 0.85rem;
}

.footer-main span {
	color: #64DDB4;
}

.footer-sec {
	background-color: #171717;
	padding: 1rem 0;
}

.footer-title {
	border-bottom: 2px solid white;
	padding-bottom: 1rem;
}

.footer-desc {
	margin-top: 1rem;
}


@media screen and (max-width: 1080px) {

	.flex-3 div:first-child {
		order: 3;
	    flex-basis: 50%;
	    text-align: center;
	    margin: 0 auto;
	}

	.flex-3 div:not(:first-child) h3 {
		text-align: left;
	}

	.flex-3 div {
		flex-basis: calc(50% - 2rem);
		margin-bottom: 2rem;
	}
}

@media screen and (max-width: 640px) {

	.flex-3 div:first-child {
		text-align: left;
	    flex-basis: 100%;
	    margin: 0 auto;
	}

	.flex-3 div {
		flex-basis: 100%;
		margin-bottom: 2rem;
	}

}

@media screen and (max-width: 300px) {

	.footer-title:first-child h3 {
		font-size: 1.3rem;
	}
}

/*------------------------------ End Footer -----------------------------------*/




/*---------------------------------------- Loading ------------------------------------------------*/
/*#region*/

.swal2-title,
.swal2-html-container {
	font-family: 'Monserrat-Medium';
}

.swal2-html-container {
	font-size: 0.9rem !important;
}

/*#endregion*/
/*---------------------------------------- Loading ------------------------------------------------*/
/*#region*/
.loader-container {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	z-index: 10000;
	background-color: rgba(0, 0, 0, 0.6);
}

.loader-container-active {
	display: block;
}

.loader {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	display: inline-block;
	position: relative;
	border: 3px solid;
	border-color: #ebebeb #ebebeb transparent transparent;
	box-sizing: border-box;
	animation: rotation 1s linear infinite;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

	.loader::after,
	.loader::before {
		content: '';
		box-sizing: border-box;
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		border: 3px solid;
		border-color: transparent transparent #64ddb4 #64ddb4;
		width: 50px;
		height: 50px;
		border-radius: 50%;
		box-sizing: border-box;
		animation: rotationBack 0.5s linear infinite;
		transform-origin: center center;
	}

	.loader::before {
		width: 40px;
		height: 40px;
		border-color: #0f4c81 #0f4c81 transparent transparent;
		animation: rotation 1.5s linear infinite;
	}

@keyframes rotation {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

@keyframes rotationBack {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(-360deg);
	}
}


/*#endregion*/