@charset "utf-8";
/* CSS Document */

/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
/* End Fonts */

body{
	margin: 0;
	font-family: "Montserrat", sans-serif;
	font-size: 16px;
	color: #4B5563;
}
h1{
	font-size: 50px;
	font-weight: 800;
	line-height: 58px;
	color: #000000;
}
h2{
	font-size: 40px;
	font-weight: 800;
	line-height: 48px;
	color: #000000;
}
h3{
	font-size: 30px;
	font-weight: 800;
	line-height: 38px;
	color: #000000;
}
h4{
	font-size: 24px;
	font-weight: 800;
	line-height: 32px;
	color: #000000;
}
h5{
	font-size: 18px;
	font-weight: 800;
	line-height: 26px;
	color: #000000;
}
img{
  max-width: 100%;
  height: auto;
  display: block;
}
a{
	text-decoration: none;
}
.txt-bco{
	color: #FFF;
}
header{
	padding: 10px 0;
}
.logo{
	height: 90px;
	display: flex;
}
#hero{
	margin-bottom: 120px;
}
#hero .container{
	background: #FFFFFF 0% 0% no-repeat padding-box;
	box-shadow: 0px 3px 6px #00000029;
	border: 1px solid #FBFBFB;
	border-radius: 50px;
	padding: 20px 30px;
}
#hero .container .col-md-8,
#hero .container .col-md-4{
	border-radius: 40px;
	padding: 30px;
}
#hero .container .col-md-8{
	background: #5A469C;
	background-image: url("../images/banner-principal.webp");
	background-size: contain;
	background-position: center -50px;
	background-repeat: no-repeat;
	position: relative; /* necesario para posicionar el overlay */
  	z-index: 0;
}
#hero .container .col-md-8::before{
	content:"";
	position:absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 70%;
	background: linear-gradient(0deg,rgba(90, 70, 156, 1) 40%, rgba(90, 70, 156, 0) 100%);
	z-index: 1;
	border-radius: 0 0 40px 40px;
}
.banner-txt h1{
	color: #FFF;
}
.banner-txt .subtitle{
	color: #FFF;
	font-size: 18px;
	text-transform: uppercase;
	font-weight: bold;
}
.banner-txt .text{
	color: #FFF;
	font-size: 18px;
	font-weight: bold;
}
.banner-txt{
	color: #FFF;
	z-index: 3;
	position: absolute;
	bottom: 0;
	left: 0;
	margin: 30px;
}
.btn-bco{
	padding: 12px 25px;
	background: #FFF;
	border: 1px solid #67EAFF;
	border-radius: 28px;
	color: #4597A4;
	font-size: 16px;
	margin: 15px 0;
	font-weight: bold;
	display: inline-block;
}
.btn-bco:hover{
	background: #4597A4;
	color: #FFF;
}
.btn-azul{
	padding: 12px 25px;
	background: #4597A4;
	border: 1px solid #67EAFF;
	border-radius: 28px;
	color: #FFF;
	font-size: 16px;
	margin: 15px 0;
	font-weight: bold;
	display: inline-block;
}
.btn-azul:hover{
	background: #5A469C;
	border: 1px solid #5A469C;
	color: #FFF;
}
.card-style-one{
	padding: 25px;
	background: #F5F3FF 0% 0% no-repeat padding-box;
	box-shadow: 0px 3px 6px #00000029;
	border-radius: 20px;
	margin-bottom: 20px;
}
.card-style-one h3{
	color: #5A469C;
}
.card-style-two{
	padding: 30px;
	background: #5A469C 0% 0% no-repeat padding-box;
	box-shadow: 0px 3px 6px #00000029;
	border-radius: 20px;
	margin-bottom: 20px;
	color: #FFF;
	min-height: 440px;
}
.card-style-two h3,
.card-style-two h5{
	color: #FFF;
}
.card{
	border: 0 !important;
	background-color: transparent;
}
#problems,
#servicios,
#ejecucion,
#diferenciador{
	margin-bottom: 100px;
}
#servicios .col-4{
	position: relative;
}
.img-bk{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	min-height: 160px !important;
	border-radius: 11px;
}
.one{
	background: url("../images/one.webp");
	background-position: center;
	background-size: cover;
}
.two{
	background: url("../images/two.webp");
	background-position: center;
	background-size: cover;
}
.three{
	background: url("../images/three.webp");
	background-position: center;
	background-size: cover;
}
.four{
	background: url("../images/four.webp");
	background-position: center;
	background-size: cover;
}
#ejecucion{
	padding: 100px 0;
	background: #F5F3FF;
}
.card-style-three{
	padding: 30px;
	background: #1E293B 0% 0% no-repeat padding-box;
	box-shadow: 0px 3px 6px #00000029;
	border-radius: 12px;
	margin-bottom: 20px;
	color: #FFF;
}
.card-style-three h3{
	color: #FFF;
	font-size: 18px;
	line-height: 26px;
}
.number{
	text-align: right;
	color: #1E293B;
	font-size: 34px;
	line-height: 42px;
	text-shadow: 
    -1px -1px 0 #F5F3FF,
     1px -1px 0 #F5F3FF,
    -1px  1px 0 #F5F3FF,
     1px  1px 0 #F5F3FF;
	font-weight: bold;
}
#diferenciador .container{
	background: url("../images/banner-2.webp");
	background-position: center;
	background-size: cover;
	padding: 40px;
	border-radius: 13px;
}
.glass{
	background: rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
	border: 1px solid rgba(255, 255, 255, 0.3);
	padding: 30px;
}
.bk-respaldo{
	background: url("../images/five.webp");
	background-position: center;
	background-size: cover;
	padding: 30px;
	border-radius: 13px;
}
.p40{
	padding: 40px;
}
.bk-azul{
	background: #1E293B;
	border-radius: 13px;
}
.custom-gap {
    margin-left: -20px;
    margin-right: -20px;
}
.custom-gap > [class*='col-'] {
    padding-left: 20px;
    padding-right: 20px;
}
footer{
	margin-top: 90px;
	padding: 20px;
	color:#fff;
	background: #5A469C;
	font-size: 14px;
	line-height: 22px;
}
/* FAQ SECTION */
.faq-section {
    background: #f5f5f5;
}
.faq-title span {
    color: #f58220;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
}
.faq-title h2 {
    font-size: 42px;
    font-weight: 800;
    color: #0d2235;
    margin-top: 5px;
}
.faq-title p {
    color: #666;
    margin-top: 10px;
}
/* CARD */
.faq-card {
    margin-bottom: 15px;
    border-radius: 10px;
    overflow: hidden;
}
/* BUTTON */
.faq-btn {
    width: 100%;
    background: #ffffff;
    color: #1E293B;
    border: none;
    padding: 12px 50px 12px 10px;
    text-align: left;
    font-size: 16px;
    font-weight: 600;
    position: relative;
    transition: .3s;
    outline: none !important;
}
.faq-btn:hover {
    background: #F5F3FF;
}
/* ICON */
.faq-icon {
    position: absolute;
    right: 25px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 22px;
    transition: .3s;
}
/* ROTATE ICON */
.faq-btn:not(.collapsed) .faq-icon {
    transform: translateY(-50%) rotate(45deg);
}
/* BODY */
.faq-body {
    background: #fff;
    padding: 25px;
    color: #555;
    line-height: 1.7;
    border-top: 1px solid #eee;
}
/* Form Styles */
.form-filed{
	margin-bottom: 15px;
}
.label{
	color: #989898;
	font-size: 12px;
    text-transform: uppercase;
	display: none;
}
.error,
#errmsg{
	display: block;
    color: red;
    font-size: 12px;
    text-transform: uppercase;
}
input,
textarea,
select{
	width: 100%;
	padding: 7px 10px;
	font-size: 14px;
	color: #242424;
	border: 0;
	border-bottom: 1px solid #4B5563;
}
textarea{
	height: 60px;
}
button{
	width: 100%;
	padding: 7px 0;
}
/* End Form Styles */

/* Responsive Tablet */

/* End Responsive Tablet */

/* Responsive Phone */

/* End Responsive Phone */