@import url('https://fonts.googleapis.com/css?family=Montserrat:400,700');
@import url('https://fonts.googleapis.com/css?family=Lato:300,400,700');
/* GLOBAL STYLES
-------------------------------------------------- */
/* Padding below the footer and lighter body text */
@font-face {
  font-family: 'Brown Rosemary';
  src: url('../fonts/BrownRosemary.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Houschka Rounded';
  src: url('../fonts/fonnts.com-Houschka_Rounded_Bold.woff2') format('woff2');
  font-weight: bold;
  font-style: normal;
}

html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  width: 100%;
  max-width: 100%;
  min-height: 100%;
  box-sizing: border-box;
  font-family: 'Lato', sans-serif;
  color: #00517c;
}



h1, h2 {
  font-family: 'Brown Rosemary', serif; /* para títulos principales */
}

h3, h4, h5 {
  font-family: 'Houschka Rounded', sans-serif; /* para subtítulos */
}
/*
body {
	color: #5a5a5a;
	font-family: 'Lato', sans-serif;
}
h1, h2, h3, h4, h5 {
	font-family: 'Montserrat', sans-serif;
}*/
a {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

.parallax-section {
	background-attachment: fixed!important;
}
.btn-capsul {
	border-radius: 30px;
}
/*.btn-aqua {
	/*background: #1d998b;*/ /*#0297FF 71ccd9*
	background: linear-gradient(to bottom right, rgb(96, 163, 193) 0%, rgb(47, 140, 170) 40%, rgb(0, 81, 124) 100%);
	background-size: 200% 200%;
	transition: background-position 0.5s ease-in-out;
	color: #fff;
	cursor: pointer;
}
.btn-aqua:hover {
	background: linear-gradient(to bottom right, #266d31 0%, #8da33a 40%, #d0d06b 100%);
	background-position: right bottom;
	color: #fff;
}*/

.btn-aqua {
	position: relative;
	overflow: hidden;
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
	color: #fff;
	border: none;
	padding: 10px 20px;
	border-radius: 6px;
	cursor: pointer;
	z-index: 1;
	transition: color 0.3s;
}

.btn-aqua::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
	opacity: 0;
	transition: opacity 0.6s ease-in-out;
	z-index: -1;
}

.btn-aqua:hover::before {
	opacity: 1;
}

.btn-aqua:hover {
	color: #fff;
}

.btn-dark-blue {
	background: #0C242E;
	color: #fff;
}
.btn-dark-blue:hover {
	background: #063d28;
	color: #fff;
}
.btn-transparent-white {
	border: 2px solid #fff;
	color: #fff;
}
.btn-transparent-white:hover, .btn-transparent-white:focus {
	background: #fff;
	color: #116b7e; /*#0297ff*/
}
.relative-box {
	position: relative
}
section {
	float: left;
	width: 100%;
	padding: 40px 0;
}
/* Loader
-------------------------------------------------- */

.loaders {
	width: 100%;
	box-sizing: border-box;
	display: flex;
	flex: 0 1 auto;
	flex-direction: row;
	flex-wrap: wrap;
}
.loaders .loader {
	box-sizing: border-box;
	display: flex;
	flex: 0 1 auto;
	flex-direction: column;
	flex-grow: 1;
	flex-shrink: 0;
	flex-basis: 25%;
	max-width: 25%;
	height: 200px;
	align-items: center;
	justify-content: center;
}
.loader {
	display: table;
	height: 100%;
	position: fixed;
	width: 100%;
	z-index: 1200;
}
/*.loader-bg {
	background: #1d998b; 
}*/
.loader-bg {
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
}

.loader-inner {
	display: table-cell;
	text-align: center;
	vertical-align: middle;
}

.loader .ball-clip-rotate-pulse {
    left: 50%;
    position: absolute;
    top: 50%;
}
/* TOP HEADER
-------------------------------------------------- */

.navbar {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999;
}

/*.navbar.top-bar {
  border-radius: 0;
  padding: 16px 0;
  z-index: 16;
}*/
.navbar.top-bar {
  border-radius: 0;
  padding: 16px 0;
  z-index: 16;
  transition: all 0.3s ease-in-out;
  background-color: transparent;
  box-shadow: none; 
  position: fixed;
  top: 0;
  width: 100%;
}

.sps--blw.navbar.top-bar {
  background-color: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); 
}

/*.navbar-toggler {
  border: none;
  color: #fff;
  position: absolute;
  top: 20px;
  right: 10px;
  z-index: 20;
}*/
.navbar-toggler {
  position: fixed;
  top: 2rem;
  right: 1rem;
  z-index: 20;
}


.navbar-toggler:focus,
.navbar-toggler:active {
  outline: none !important;
  box-shadow: none !important;
  border: none !important;
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%231d998b' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.navbar .dropdown:hover .dropdown-menu {
  display: block;
  margin-top: 0;
}
/* Mostrar dropdown al hacer hover en desktop */
@media (min-width: 992px) {
  .navbar .dropdown:hover .dropdown-menu {
    display: block;
    margin-top: 0;
	text-decoration: none;
  }
}
@media (max-width: 991.98px) {
  .dropdown-menu {
    display: none;
  }

  .dropdown-menu.show {
    display: block;
    position: relative;
    float: none;
    width: 100%;
    margin-top: 0;
    background-color: #ffffff;
    border: none;
    box-shadow: none;
  }
}
@media (max-width: 768px) {
  .navbar-brand img {
    height: 80px !important;
  }

  .navbar.top-bar {
    padding: 8px 0;
  }
  /*.navbar-toggler {
    right: 1rem;
  }*/
}



.sps {
  padding: 1em 0.5em;
  position: absolute;
  top: 0;
  left: 0;
  transition: all 0.25s ease;
  width: 100%;
}

.sps--abv {
  background-color: transparent;
  color: #000;
}

.sps--blw {
  background-color: #fff;
  color: #fff;
}

.top-bar a.navbar-brand {
  color: #fff;
  font-size: 26px;
  font-weight: 800;
  padding: 5px 0 0 10px;
  text-transform: uppercase;
}

.sps--blw.top-bar a.navbar-brand {
  color: #000;
}

.top-bar a.navbar-brand span {
  color: #00517c; /*#1d998b; */
}

.top-bar .nav-link {
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  padding: 12px 18px;
  margin-left: 20px;
}

.sps--blw.top-bar .nav-link {
  color: #000;
}

.top-bar .navbar-nav .nav-item {
  margin: 0;
}

.top-bar .navbar-collapse.show .navbar-nav .nav-item {
  background: #1a2d3a; /* Contraste con letras menta */
  border-radius: 8px;
  margin: 5px 0;
}

.top-bar .nav-link:hover,
.top-bar .nav-item.active a {
  color: #fff;
  border-bottom: 2px solid #fff;
  border-radius: 0;
}

.sps--blw.top-bar .nav-item.active a {
  color: #00517c; /*#1d998b;*/
  border-bottom: 2px solid #71CDDA;
}
.sps--blw.top-bar .nav-link:hover {
  color: #71CDDA !important;
  border-bottom: 2px solid #71CDDA;
}
/* Líneas hamburguesa blancas cuando el fondo es oscuro (sps--abv) */
.sps--abv .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Líneas hamburguesa verde menta cuando el fondo es blanco (sps--blw) */
.sps--blw .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%2371cdda' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
/* Enlaces blancos dentro del menú desplegado con fondo oscuro */
.top-bar .navbar-collapse.show .nav-link {
  color: #fff !important;
}

/* Hover en el menú desplegado (para mantener blanco o aplicar efecto deseado) */
.top-bar .navbar-collapse.show .nav-link:hover {
  color: #71CDDA !important;
  border-bottom: none;
}

/* Transición suave sin romper funcionalidad Bootstrap */
/*.navbar-collapse {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
}*/

.navbar-collapse.collapsing {
  max-height: 0 !important;
  opacity: 0;
  transition: none;
}

.navbar-collapse.show {
  max-height: 1000px;
  opacity: 1;
  transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
}

/* Cuando navbar es transparente: fondo oscuro y texto claro */
.sps--abv .dropdown-menu {
  background-color: #71CDDA;
  border: none;
  text-decoration: none;
}

.sps--abv .dropdown-menu a.dropdown-item {
  color: #fff;
}

.sps--abv .dropdown-menu a.dropdown-item:hover {
  background-color: #00517c;
  color: #fff;
}

/* Cuando navbar tiene fondo blanco: fondo claro y texto oscuro */
.sps--blw .dropdown-menu {
  background-color: #fff;
  border: none;
}

.sps--blw .dropdown-menu a.dropdown-item {
  color: #000;
}

.sps--blw .dropdown-menu a.dropdown-item:hover {
  background-color: #71CDDA;
  color: #fff;
}



/* CUSTOMIZE THE CAROUSEL
-------------------------------------------------- */

/*Swiper*/
.swiper-container {
	width: 100%;
	height: 100vh;
	position: relative;
    z-index: 1;
}
.swiper-slide {
	text-align: center;
	font-size: 18px;
	background: #fff;
	/* Center slide text vertically */
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
}
.main-slider .slider-bg-position {
	background-size: cover!important;
	background-position: center center!important;
}
.main-slider .swiper-button-prev, .main-slider .swiper-button-next {
	background-image: none!important;
	color: #fff;
	width: 50px;
	height: 50px;
	border: 1px solid #fff;
	text-align: center;
	line-height: 50px;
	font-size: 20px;
}
.main-slider h2 {
	/*font-family: 'Montserrat', serif;*/
	color: #fff;
	font-size: 54px;
	line-height: 59px;
	padding: 0 19%;
	text-transform: uppercase;
}
.main-slider .swiper-pagination-bullet {
	width: 20px;
	height: 20px;
	background: rgba(255,255,255,0.9)
}
.main-slider .swiper-pagination-bullet-active {
	background: #116b7e; /*#0297ff*/
}
/* SERVICE SECTION
-------------------------------------------------- */

.service-sec .heading {
	float: left;
	width: 100%;
	/*margin-bottom: 70px;*/
}
.service-sec h2 {
	display: block;
/*	text-transform: capitalize;*/
	font-weight: 600;
	color: #00517c; /*#0297FF*/
	font-size: 32px;
}
.service-sec h2 small {
	color: #71CDDA;
	display: block;
	font-size: 22px;
	margin-bottom: 18px;
}
/*.service-sec i {
	border: 1px solid #1d998b; 
	border-radius: 2px;
	font-size: 25px;
	padding: 12px 0;
	width: 52px;
	color: #1d998b;
	margin-bottom: 20px
}*/
.service-sec i {
	border: 1px solid transparent;
	border-image: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b) 1;
	border-radius: 2px;
	font-size: 25px;
	padding: 12px 0;
	width: 52px;
	background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-align: center;
	margin-bottom: 20px;
}

.service-sec h3 {
	font-size: 23px;
	font-weight: 600;
}
.service-sec p {
	line-height: 22px;
	margin-top: 13px;
	padding: 0 21px;
}
.service-sec .service-block {
	margin-top: 30px;
    text-align: center;
}
/* ABOUT SECTION
-------------------------------------------------- */
/*.about-sec {
	background-size: cover;
	color: #fff;
	position: relative;
}*/
/*.about-sec:before {
	content: ' ';
	position: absolute;
	width: 100%;
	height: 100%;
	background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
	top: 0;
	left: 0
}*/
/*.about-sec {
  background-size: cover;
  color: #fff;
  position: relative;
  height: 500px;
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
  z-index: 1;
}*/
.about-sec {
  background-size: cover;
  color: #fff;
  position: relative;
  min-height: 500px; /* permite crecer si hay más contenido */
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
  z-index: 1;
  padding-top: 60px;
  padding-bottom: 60px;
}

.about-sec::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
  clip-path: polygon(0 0, 100% 0, 100% 80%, 0% 100%);
  z-index: -1;
  transform: rotate(-2deg);
}


.about-sec h2 {
	font-size: 55px;
	font-weight: 800;
	/*margin-top: 25%;*/
	margin-top: 0;
}
.about-sec h2 small {
	display: block;
	font-size: 24px;
	margin-bottom: 15px;
	padding-left: 10px;
}
.about-sec p {
	font-size: 16px;
}

@media (max-width: 768px) {
  .about-sec h2 {
    font-size: 28px;
    text-align: center;
  }

  .about-sec p {
    font-size: 14px;
  }

  .col-md-3,
  .col-md-9,
  .col-md-6 {
    text-align: center;
    margin-bottom: 30px;
  }

  .btn-capsul {
    display: inline-block;
    margin-top: 20px;
  }
}

/* BLOG SECTION
-------------------------------------------------- */
.blog-sec .blog-box {
	text-align: center;
}
.blog-sec .heading {
	float: left;
	width: 100%;
	margin-bottom: 70px;
}
.blog-sec h2 {
	display: block;
	text-transform: capitalize;
	font-weight: 600;
	color: #00517c; /*#0297FF*/
	font-size: 32px;
}
.blog-sec h2 small {
	color: #71CDDA;
	display: block;
	font-size: 22px;
	margin-bottom: 18px;
}

.blog-sec h2 span {
	color: #00517c;
	display: block;
	font-size: 24px;
	margin-bottom: 18px;
}

.blog-sec h3 small {
	display: block;
	color: #00517c; /*#0297FF*/
	margin-bottom: 15px;
	font-weight:600;
}
.blog-sec h3 a {
	color: #266d31;
	font-size: 22px;
}
.blog-sec h3 a:hover {
	color: #71CDDA; /*#0297FF*/
	text-decoration: none;
}
.blog-sec .blog-image-block {
	margin-bottom: 40px;
}
.blog-sec .blog-image-block img {
	border-radius: 5px;
}
/*-------------- Video section  --------------*/
.video-sec {
	background: url('../img/video-bg.jpg') 50% 0 repeat-y fixed;
	-webkit-background-size: cover;
	background-size: cover;
	background-position: center center;
	text-align: center;
	position: relative;
	color: #fff;
}
.video-sec .overlay {
	background: rgba(03,03,03,0.6);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
}
.video-sec h2 {
	color: #ffffff;
	padding-top: 20px;
	padding-bottom: 16px;
}
.video-sec small {
	color: #fff;
	display: block;
	margin-top: 10px;
	font-family: 'Lato', sans-serif;
	font-size: 18px;
}
.video-sec .fa {
	position: relative;
	border: 2px solid #ffffff;
	border-radius: 100px;
	color: #ffffff;
	font-size: 28px;
	width: 80px;
	height: 80px;
	line-height: 80px;
	text-align: center;
	vertical-align: middle;
	margin-top: 22px;
}
/*-------------- Gallery section  --------------*/

.gallery-sec .heading {
	float: left;
	width: 100%;
	margin-bottom: 40px;
}
.gallery-sec h2 {
	display: block;
	text-transform: inherit;
	font-weight: 600;
	color: #1d998b; /*#0297FF*/
	font-size: 32px;
}
.gallery-sec h2 small {
	color: #222;
	display: block;
	font-size: 22px;
	margin-bottom: 18px;
}
.gallery-sec .gallery-thumb {
	position: relative;
	overflow: hidden;
	margin: 0;
}
.gallery-sec .gallery-thumb .gallery-overlay {
	background: #1d998b; /*#0297FF*/ /* fallback for old browsers */
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	-webkit-transition: all 0.4s ease-in-out;
	transition: all 0.4s ease-in-out;
}
.gallery-sec .gallery-thumb:hover .gallery-overlay {
	opacity: 0.9;
}
.gallery-sec .gallery-thumb .gallery-overlay .gallery-item {
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.gallery-sec .gallery-thumb .fa {
	background: #ffffff;
	border-radius: 100%;
	font-size: 24px;
	color: #222;
	width: 60px;
	height: 60px;
	line-height: 60px;
	text-align: center;
	vertical-align: middle;
}
/*--------------filter css--------------*/
.filter-wrapper {
	width: 100%;
	margin-bottom: 42px;
	overflow: hidden;
}
.filter-wrapper li {
	display: inline-block;
	margin: 4px;
}
.filter-wrapper li a {
	color: #222;
	font-size: 18px;
	font-weight: 600;
	padding: 8px 17px;
	margin-right: 2px;
	margin-left: 2px;
	display: block;
	text-decoration: none;
	-webkit-transition: all 0.5s ease-in-out;
	transition: all 0.5s ease-in-out;
	border-bottom: 2px solid #fff;
}
.filter-wrapper li a:hover, .filter-wrapper li a:focus {
	color: #1d998b; /*#0297FF*/
	border-bottom: 2px solid #1d998b; /*#0297FF*/
}
/*--------------isotope box css--------------*/
.iso-box-section {
	width: 100%;
}
.iso-box-wrapper {
	width: 100%;
	padding: 0;
	clear: both;
	position: relative;
}
.iso-box {
	position: relative;
	min-height: 50px;
	float: left;
	overflow: hidden;
	margin-bottom: 30px;
}
.iso-box > a {
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.fluid-img {
	width: 100%;
	display: block;
}
/* CALL TO ACTION
-------------------------------------------------- */
.cta-block {
	background: url("../img/cta-bg.webp") repeat;
	padding: 30px 0;
	color: #fff;
	text-transform: capitalize
}
.cta-block h4 {
	margin-bottom: 10px;
	font-weight: 700;
	font-size: 28px;
}
.cta-block p {
	margin-bottom: 0;
	font-size: 18px;
}
/* ABOUT SECTION
-------------------------------------------------- */

.about-home-block h2 {
	color: #4c4c4c;
	font-size: 38px;
	margin: 35px 0 10px;
	text-transform: capitalize;
}
.about-home-block h2 small {
	color: #01BF86;
	display: block;
	text-transform: uppercase;
	font-size: 28px;
}
.about-home-block .lead {
	font-size: 18px;
	line-height: 28px;
}
/* PRICE SECTION
-------------------------------------------------- */

.price-sec h2 {
	color: #4c4c4c;
	font-weight: 600;
	text-transform: capitalize;
	text-align: center;
}
.price-sec h2 small {
	color: #01BF86;
	display: block;
	line-height: 27px;
	margin-top: 10px;
}
.price-sec .plan-block {
	border: 2px solid #01BF86;
	color: #01BF86;
	float: left;
	padding: 60px 0;
	text-align: center;
	width: 100%;
	margin-top: 90px;
	border-radius: 10px;
}
.price-sec .plan-block.middle {
	margin-top: 70px;
	padding: 80px 0
}
.price-sec .plan-block .heading, .price-sec .plan-block .heading > span, .price-sec .plan-block .detail-sec {
	float: left;
	width: 100%;
}
.price-sec .plan-block .detail-sec ul {
	padding: 0;
	list-style: none;
}
.price-sec .heading .price {
	font-size: 36px;
	font-weight: 700;
	background: #01bf86 none repeat scroll 0 0;
	color: #fff;
}
.price-sec .heading .price b {
	font-weight: 400;
}
.price-sec .heading .plan-type {
	font-size: 24px;
	font-weight: 600;
	text-transform: uppercase;
}
.price-sec .heading .duration {
	margin: 5px 0 20px;
}
.price-sec .plan-block .detail-sec ul {
	list-style: outside none none;
	margin: 0 auto 50px;
	padding: 0;
	text-align: left;
	width: 50%;
}
.price-sec .plan-block .detail-sec li {
	font-size: 18px;
	margin: 20px 0;
	text-align: center
}
.price-sec .plan-block .detail-sec i {
	margin-right: 10px;
	margin-top: 3px;
}
.price-sec .btn {
	padding-left: 50px;
	padding-right: 50px;
}
/* QA SECTION
-------------------------------------------------- */
.qa-section {
	background: url(../img/section-bg-white.webp) no-repeat 0 bottom #f5f5f5;
	background-size: cover;
}
.qa-section h2 {
	color: #4c4c4c;
	font-weight: 600;
	text-transform: capitalize;
	text-align: center;
	margin-bottom: 50px;
}
.qa-section h2 small {
	color: #01BF86;
	display: block;
	line-height: 27px;
	margin-top: 10px;
}
.qa-section .card-header h5 a.collapsed {
	color: #01BF86;
}
.qa-section .card-header h5 a {
	color: #01BF86;
	;
	font-weight: 500;
	font-size: 25px;
}
.qa-section .card-header h5 a:hover, .qa-section .card-header h5 a:focus {
	text-decoration: none;
}
.qa-section .card-header {
	background: #0C242E
}
/* TESTIMONIAL SECTION
-------------------------------------------------- */

.testimonial-sec {
	background: #01BF86;
}
.testimonial-sec h2 {
	display: block;
	text-transform: capitalize;
	font-weight: 600;
	color: #fff;
	margin-bottom: 50px;
}
.testimonial-sec h2 small {
	display: block;
	font-size: 24px;
	margin-top: 10px;
}
.testimonial-sec .card {
	background: #fff;
	border: none;
	padding-top: 30px;
	border-radius: 16px;
	box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.2);
}
.testimonial-sec .card img {
	border-radius: 50%;
	width: 150px;
	border: 7px solid #01BF86
}
.testimonial-sec .card h3 {
	color: #01BF86
}
.testimonial-sec .card h3 small {
	display: block;
	font-family: 'Source Sans Pro', sans-serif;
	text-transform: uppercase;
	color: #4c4c4c;
	font-size: 17px;
	margin-top: 5px;
}
.testimonial-sec .card .card-text {
	font-style: italic;
	padding: 0 20px
}
/* CONTACT SECTION
-------------------------------------------------- */
.contact-sec {
	background-size: cover;
	padding-top: -40px;
}
/*.contact-sec {
  background-size: cover;
  color: #fff;
  height: 500px;
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
  z-index: 1;
}

.contact-sec::after {
  content: '';
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
  clip-path: polygon(0 0, 100% 0, 100% 80%, 0% 100%);
  z-index: -1;
  transform: rotate(-2deg);
}*/
.contact-sec h2 {
	color: #fff;
	font-weight: 600;
	text-transform: inherit;
	text-align: center;
	margin-bottom: 50px;
}
.contact-sec h2 small {
	color: #fff;
	display: block;
	line-height: 27px;
	margin-top: 10px;
}
.contact-sec label {
	color: #fff;
}
.contact-sec input[type="text"], .contact-sec input[type="email"] {
	border-radius: 0px;
}
.contact-sec textarea {
	border-radius: 0;
	height: 50px;
}
.contact-sec .action-block {
	margin-top: 40px;
}
.contact-sec .action-block a.btn {
	padding-left: 35px;
	padding-right: 35px;
	text-transform: uppercase;
	font-weight: 600
}
.contact-sec .form-control {
	background: transparent;
	border-bottom: 1px solid #fff;
	border-top: none;
	border-left: none;
	border-right: none;
	color: #fff;
	padding-left: 0
}

.contact {
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.contact .contact-form {
    background: rgba(255, 255, 255, 0.6);
}


.contact-form .form-control {
  margin-bottom: 20px; /* espaciado vertical entre campos */
  height: 50px;
  border-radius: 8px;
  font-size: 16px;
}

.contact-form textarea.form-control {
  height: auto;
  min-height: 120px;
  resize: vertical;
}

/* custom.css */

.contact-info-box {
  background: 
    linear-gradient(#ffffff, #ffffff) padding-box,  /* fondo blanco interior */
    linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b) border-box;  /* borde degradado */
  border: 2px solid transparent;
  padding: 20px;
  border-radius: 12px;
  transition: all 0.3s ease;
}

.contact-info-box:hover {
  background-color: #f1fdfc;
  transform: translateY(-5px);
}

/*.contact-info-box i {
  color: #1d998b;
  margin-right: 15px;
}*/
.contact-info-box i {
  border-image: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b) 1;
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-align: center;
  margin-right: 15px;
}

.contact-info-box h4 {
  margin-bottom: 5px;
  font-size: 20px;
  font-weight: 700;
  color: #00517c;;
}

.contact-info-box p {
  margin: 0;
  font-size: 16px;
  color: #00517c;
}

/*.contact-form button {
  background-color: #1d998b;
  color: #fff;
  border: none;
  font-weight: 600;
  font-size: 16px;
  border-radius: 8px;
  transition: all 0.3s ease;
}

.contact-form button:hover {
  background-color: #116b7e;
}*/
.contact-form button {
  position: relative;
  overflow: hidden;
  background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
  color: #fff;
  border: none;
  font-weight: 600;
  font-size: 16px;
  border-radius: 8px;
  padding: 12px 24px;
  cursor: pointer;
  z-index: 1;
  transition: color 0.3s ease;
}

.contact-form button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b); /* verde limón */
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
  z-index: -1;
}

.contact-form button:hover::before {
  opacity: 1;
}

.contact-form button:hover {
  color: #fff;
}


.bg-florence-green {
/*  background-color: #00517c;*/
  background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
}


.footer {
	float: left;
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
	width: 100%;
	color: #fff;
	padding: 20px 0
}

/* Mejora visual del contenedor del mapa */
iframe {
    border-radius: 12px 12px 0 0;
}

/* Estilos mejorados para los íconos de redes sociales */
.social-icon {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
    color: #ffffff; /* color turquesa de Maribel Cleaning */
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 18px;
    transition: all 0.3s ease-in-out;
    text-decoration: none;
	margin: 0 8px;
}

.social-icon:hover {
    background-color: #fff;
    color: #71CDDA;
	text-decoration: none;
}


.footer a {
  color: #ffffff;
  transition: 0.3s;
}
.footer a:hover {
  color: #71CDDA;
}

footer ul {
	list-style: none;
	padding-left: 0
}
footer h2 {
	font-size: 20px;
	font-weight: 600;
}
footer li a {
	color: #fff;
	float: left;
	padding-bottom: 15px;
	width: 100%;
}
.footer .copyright {
  margin-top: 20px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.7);
}

.footer .copyright .webplus-link {
  color: #ffffff;
  font-weight: bold;
  text-decoration: none;
  transition: color 0.3s ease;
}

.footer .copyright .webplus-link:hover {
  color: #71CDDA;
}

.footer .footer-heading {
/*  font-family:'Crimson Pro SemiBold', serif;*/
  font-size: 26px;
  margin-bottom: 30px;
  font-weight: 700;
  color: #ffffff;
  position: relative;
}
.footer .footer-heading:after {
  position: absolute;
  bottom: -4px;
  left: 0;
  content: '';
  width: 30px;
  height: 4px;
  background: #71CDDA; /* Amarillo detalle */
}

/*.footer .ftco-footer-social li a {
  background: #ffffff;
  color: #1d998b;
  border-radius: 50%;
  height: 30px;
  width: 30px;
  display: block;
  text-align: center;
  line-height: 30px;
}*/
/*.footer .ftco-footer-social li a:hover {
  background: #116b7e;
  color: #1d998b;
}*/
.footer .ftco-footer-social {
  padding-left: 0;
  margin: 0;
  list-style: none;
  display: flex;
  gap: 10px; /* espacio entre íconos */
}

.footer .ftco-footer-social li {
  display: inline-block;
}

.footer .ftco-footer-social li a {
  background: #71CDDA;
  color: #ffffff;
  border-radius: 50%;
  height: 40px;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px; /* Tamaño de ícono directamente aquí */
  transition: 0.3s;
  text-decoration: none;
  line-height: 1; /* Asegura sin desplazamiento */
  padding: 0; /* Asegura que no haya espacio interno adicional */
}

.footer .ftco-footer-social li a span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  font-size: inherit; /* hereda del padre */
}


.footer .ftco-footer-social li a:hover {
  background: #00517c;
  color: #71CDDA;
}

.icon {
  margin-right: 8px; /* Ajusta el espacio según tu gusto */
}


/* RESPONSIVE CSS
-------------------------------------------------- */

@media (min-width: 40em) {
/* Bump up size of carousel content */
.carousel-caption p {
	margin-bottom: 1.25rem;
	line-height: 1.4;
}
.featurette-heading {
	font-size: 50px;
}
}
 @media (min-width: 62em) {
.featurette-heading {
	margin-top: 7rem;
}
}
 @media (max-width: 767px) {
.carousel-caption {
	top: 25%
}
.carousel {
	height: 100vh
}
.carousel-caption h1 {
	font-size: 29px;
}
.top-bar .navbar-nav {
	width: 100%;
	background: #0C242E;
	margin-top: 20px;
}
.collapsing {
	transition-duration: 0s;
	overflow: none;
}
.carousel-caption {
	top: 20%
}
.carousel {
	height: 100vh
}
}
 @media (max-width: 543px) {
.carousel-caption {
	left: 2%;
	top: 25%;
	width: 96%;
}
     .main-slider h2 {
    color: #fff;
    font-size: 25px;
         line-height: 39px;}
}

/*section[id] {
  scroll-margin-top: 120px;
  position: relative;
  padding-top: 60px;
}*/

/* LOGO VARIANTES
-------------------------------------------------- */
/* Mostrar logo blanco por defecto */
.logo-light {
  display: inline;
}
.logo-dark {
  display: none;
}

/* Al hacer scroll (SPS activa .sps--blw), mostrar logo a color */
.sps--blw .logo-light {
  display: none;
}
.sps--blw .logo-dark {
  display: inline;
}

/* Titulos personalizados
-------------------------------------------------- */
.titulo-asistencia {
  /*font-family: 'Crimson Pro SemiBold', serif;*/
  font-size: 45px !important;
}

.titulo-asistencia small {
  display: block; /* Opcional: para que se vea debajo */
  font-family: 'Conneqt Regular', sans-serif;
  font-weight: normal;
  font-size:18px !important;
}

.titulo-servicio {
  /*font-family: 'Crimson Pro SemiBold', serif;*/
  font-size: 20px !important;
}

/* Tarjetas de servicios
-------------------------------------------------- */

.service-card {
  background: #ffffff;
  border-radius: 20px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  padding: 30px 20px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
}

.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}

.service-text {
  flex: 1;
}

.icono-servicio {
  font-size: 40px;
  color: #a23ebf; /* color distintivo Florence */
  margin-bottom: 15px;
}

.titulo-servicio {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 10px;
  /*font-family: 'Conneqt Regular', sans-serif;*/
}

/* Estilo Mision Vision
-------------------------------------------------- */
/* Línea divisoria elegante */
.section-divider {
  width: 220px;
  height: 2px;
  background: linear-gradient(90deg, #fff, #fff);
  margin: 0.5rem 0 1.5rem 0;
  border-radius: 2px;
}

/* Bloques de sección */
.section-block + .section-block {
  margin-top: 1.5rem;
}

/* Subtítulos (Misión / Visión) */
.section-subtitle {
  /*font-family: 'Conneqt Regular', sans-serif;*/
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
  color: #fff;
}

/* Texto en blockquote */
.section-text {
  border-right: 2px solid #fff;
  padding-right: 1rem;
  font-size: 0.9rem;
  font-style: italic;
  color: #fff;
  margin: 0;
}

/* Tarjetas Blog
-------------------------------------------------- */
.blog-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  margin-bottom: 30px;
  transition: all 0.3s ease-in-out;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.blog-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.blog-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.blog-content {
  padding: 20px;
}

.blog-content h4 {
  font-size: 1.2rem;
  color: #1d998b;
  margin-bottom: 10px;
  font-weight: 600;
}

.blog-content p {
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 15px;
}

.blog-content .btn {
  padding: 8px 16px;
  font-size: 0.9rem;
}

/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/
.back-to-top {
  position: fixed;
  display: none;
  width: 45px;
  height: 45px;
  border-radius: 50px;
  right: 15px;
  bottom: 15px;
  background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
  color: #fff;
  transition: color 0.3s ease-in-out;
  z-index: 99999;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

.back-to-top::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
  opacity: 0;
  transition: opacity 0.6s ease-in-out;
  z-index: -1;
  border-radius: inherit;
}

.back-to-top:hover::before {
  opacity: 1;
}

.back-to-top:hover {
  color: #fff;
}

.back-to-top i {
  font-size: 22px;
  position: absolute;
  top: 11px;
  left: 11px;
}


.ftco-appointment {
  background-position: center center !important;
  position: relative;
  z-index: 2; }
  .ftco-appointment .wrap-appointment {
    -webkit-box-shadow: 0px 12px 31px -16px rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0px 12px 31px -16px rgba(0, 0, 0, 0.15);
    box-shadow: 0px 12px 31px -16px rgba(0, 0, 0, 0.15); }
    @media (min-width: 992px) {
      .ftco-appointment .wrap-appointment {
		background: #FFFFFF;
        position: relative;
		top: -90px; /* Empuja visualmente hacia arriba */
		margin-top: 0;
		z-index: 1;
	  } 
	}

.appointment .form-group {
  position: relative;
  width: 100%;
  display: block;
  margin-bottom: 0; }
  .appointment .form-group label {
    font-size: 14px;
    font-weight: 700;
	/*font-family: 'Montserrat', serif;*/
    color: #116b7e;
    text-transform: uppercase;
    margin-bottom: 0; }
  .appointment .form-group .icon {
    position: absolute;
    top: 50% !important;
    right: 15px;
    font-size: 16px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%); }
    .appointment .form-group .icon span {
      font-size: 14px;
      color: rgba(0, 0, 0, 0.5) !important; }
  .appointment .form-group .select-wrap, .appointment .form-group 
.input-wrap {
    position: relative; }
    .appointment .form-group .select-wrap select, .appointment .form-group .input-wrap select {
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none; }
  .appointment .form-group .btn {
    width: 100%;
    display: block !important; }

.appointment .form-control {
  border: transparent;
  background: #fff !important;
  color: rgba(0, 0, 0, 0.8) !important;
  font-size: 14px;
  font-weight: 500;
  border-radius: 0;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  padding: 0;
  height: 34px !important;
  border-bottom: 2px solid rgba(0, 0, 0, 0.1) !important; }
  .appointment .form-control::-webkit-input-placeholder {

    color: rgba(0, 0, 0, 0.5); }
  .appointment .form-control::-moz-placeholder {

    color: rgba(0, 0, 0, 0.5); }
  .appointment .form-control:-ms-input-placeholder {

    color: rgba(0, 0, 0, 0.5); }
  .appointment .form-control:-moz-placeholder {

    color: rgba(0, 0, 0, 0.5); }

.appointment textarea.form-control {
  height: inherit !important; }

.appointment .btn-primary {
  background: #71CDDA;
  /*font-family: 'Crimson Pro SemiBold', serif;*/
  font-size: 28px;
  color: #fff; }
  
.appointment .btn-primary:hover {
  color: #116b7e; }
  
/*APPOINT PRINCIPAL*/
.appointment-sec {
  background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url(../img/appointment-background.webp) center center / cover  no-repeat;
  color: #fff;
  padding: 60px 0;
}

/*appointment-sec {
    background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url(../img/appointment-background.webp);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
	color: #fff;
 	padding: 60px 0;
}*/

.appointment-form, .appointment-time {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}

.appointment-form input,
.appointment-form select,
.appointment-form textarea {
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border: 1px solid #fff;
  transition: all 0.3s ease;
}

.appointment-form input:focus,
.appointment-form input:valid,
.appointment-form textarea:focus,
.appointment-form textarea:valid,
.appointment-form select:focus,
.appointment-form select:valid {
  background-color: #fff !important;
  color: #000 !important;
}

.appointment-form input::placeholder,
.appointment-form textarea::placeholder {
  color: #fff;
}

.appointment-form select option {
  color: #000;
  background-color: #fff;
}

/*.appointment-form select.form-select {
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border: 1px solid #fff;
  border-radius: 5px;
  height: auto;
  padding: 0.75rem 1rem;
  transition: all 0.3s ease;
}*/

.appointment-form select.form-select {
  width: 100%; /* ocupa todo el ancho */
  display: block;
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border: 1px solid #fff;
  border-radius: 5px;
  padding: 0.75rem 1rem;
  height: 58px; /* igual que los inputs */
  font-size: 1rem;
  box-sizing: border-box;
  transition: all 0.3s ease;
  appearance: none;
}

.appointment-time ul {
  padding-left: 0;
}

.appointment-time li {
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding: 5px 0;
}

.appointment-form .col-md-6,
.appointment-form .col-md-12,
.appointment-form .col-12 {
  margin-bottom: 15px;
}

.btn {
  font-weight: 600;
  transition: 0.5s;
  border-radius: 5px; /* un borde redondeado para suavizar */
  cursor: pointer;
  padding: 12px 30px; /* tamaño cómodo */
  font-size: 1.1rem;
  display: inline-block;
  text-align: center;
  user-select: none;
}

.btn-primary-outline-0 {
  border: 2px solid var(--bs-white);
  background-color: transparent;
  color: var(--bs-white) !important;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.btn-primary-outline-0:hover {
  background-color: var(--bs-secondary) !important;
  color: var(--bs-white) !important;
  border-color: var(--bs-secondary);
  text-decoration: none;
}

.btn-primary-outline-0:focus,
.btn-primary-outline-0:active {
  outline: none;
  box-shadow: 0 0 10px var(--bs-secondary);
}

.btn-primary-outline-0.w-100 {
  width: 100%;
}

/* Variables para tus colores (si no las tienes definidas) */
:root {
  --bs-white: #fff;
  --bs-secondary: #116b7e; /* o el color secundario que uses */
}

#cookie-banner button {
	margin-left: 1rem;
	padding: 0.5rem 1rem;
	border: 1px solid #71CDDA;
	color: #FFF;
	border-radius: 5px;
	cursor: pointer;
	transition: background 0.3s ease;
}

#cookie-banner button:first-of-type {
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
	/* Aceptar */
}

#cookie-banner button:first-of-type:hover {
	background: linear-gradient(to bottom right, #266d31, #8da33a, #d0d06b);
	/* Aceptar hover */
}

#cookie-banner button:last-of-type {
	background: linear-gradient(to bottom right, #60a3c1, #2f8caa, #00517c);
	/* Rechazar */
}

#cookie-banner button:last-of-type:hover {
	background: #c82333;
	/* Rechazar hover */
}

#cookie-banner a:hover {
	text-decoration: underline;
	color: #ffffff;
}

/* Boton de Whatsapp */
.whatsapp {
	position: fixed;
	bottom: 70px;
	right: 14px;
	z-index: 2147483646;
	/* un nivel debajo del banner de cookies */
	background-color: #25D366;
	color: white;
	border-radius: 50%;
	padding: 12px;
	font-size: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
	text-decoration: none;
	transition: transform 0.3s ease;
	width: 50px;
	height: 50px;
}
.whatsapp,
.whatsapp:visited,
.whatsapp:focus,
.whatsapp:hover,
.whatsapp:active {
	color: white !important;
	/* outline: none; */
	/* elimina el borde de foco si quieres */
}

.whatsapp:hover {
	transform: scale(1.1);
}

.whatsapp-icon {
	font-size: 28px;
	margin: 0;
}

