@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
  --color-default: #006778;
  --color-primary: #0D4680;
  --color-secondary: #1497D1;
  --color-proyecto: #22673D;
  --color-barra:#93C020;
}

.form-body{
  position: relative;
}

.form-holder {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: end;
    text-align: center;
    min-height: 100vh;
    
}

.form-holder .form-content {
  position: relative;
  text-align: center;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  margin-right: 10rem;
  background-color: var(--color-proyecto);
  color: #ffffff;
  z-index: 10;
}

.form-content .form-items {
  border: 1px solid #fff;
  padding: 40px;
  display: inline-block;
  width: 100%;
  min-width: 540px;  
  text-align: left;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.form-content h3 {
  color: #fff;
  text-align: left;
  font-size: 28px;
  font-weight: 600;
  margin-bottom: 5px;
}

.form-content h3.form-title {
  margin-bottom: 30px;
}

.form-content p {
  color: #fff;
  text-align: left;
  font-size: 17px;
  font-weight: 300;
  line-height: 20px;
  margin-bottom: 30px;
}


.form-content label, .was-validated .form-check-input:invalid~.form-check-label, .was-validated .form-check-input:valid~.form-check-label{
  color: #fff;
}

.form-content input[type=text], .form-content input[type=password], .form-content input[type=email], .form-content textarea [type=text], .form-content select {
  width: 100%;
  padding: 9px 20px;
  text-align: left;
  border: 1px solid #ffffff;
  outline: 0;
  background-color:var(--color-proyecto);
  font-size: 15px;
  font-weight: 300;
  color: #ffffff !important;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  margin-top: 16px;
}

.form-items ::placeholder{
  color: #ffffff;
}


.form-button {
  width: 250px !important;
}

.btn-formu{
  width: 200px;
  padding: 5px 0 5px 0;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  background-color: #22673D;
  border: 1px #ffffff solid;
  color:#ffffff ;
}

.btn-formu:hover{
  background-color: #ffff;
  border: 1px #ffffff solid;
  color: var(--color-proyecto) ;
}

.form-content textarea {
  width: 100%;
  padding: 8px 20px;
  border-radius: 6px;
  text-align: left;
  background-color: var(--color-proyecto);
  border: 1px solid #ffffff ;
  color: #ffffff;
  font-size: 15px;
  font-weight: 300;
  height: 120px;
  -webkit-transition: none;
  transition: none;
  margin-bottom: 14px;
}

/* ############# formulario movil ################### */

.form-body_i{
  display: flex;
  justify-content: center;
  width: 100%;
}

.form-holder_i {
    display: flex;
    justify-content: center;
    text-align: center;
    width: 100%;  
}

.form-holder_i .form-content_i {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  background-color: var(--color-proyecto);
  color: #ffffff;
}

.form-content_i .form-items_i {
  border: 1px solid #fff;
  padding: 40px;
  width: 100%;
  text-align: left;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.form-content_i h3 {
  color: #fff;
  text-align: left;
  font-size: 28px;
  font-weight: 600;
  margin-bottom: 5px;
}

.form-content_i p {
  color: #fff;
  text-align: left;
  font-size: 17px;
  font-weight: 300;
  line-height: 20px;
  margin-bottom: 30px;
}


.form-content_i label, .was-validated .form-check-input:invalid~.form-check-label, .was-validated .form-check-input:valid~.form-check-label{
  color: #fff;
}

.form-content_i input[type=text], .form-content_i input[type=password], .form-content_i input[type=email], .form-content_i textarea [type=text], .form-content_i select {
  width: 100%;
  padding: 9px 20px;
  text-align: left;
  border: 1px solid #ffffff;
  outline: 0;
  background-color:var(--color-proyecto);
  font-size: 15px;
  font-weight: 300;
  color: #ffffff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  margin-top: 16px;
}

.form-items_i ::placeholder{
  color: #ffffff;
}

.form-button_i {
  width: 250px !important;
}

.btn-formu_i{
  width: 200px;
  padding: 5px 0 5px 0;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  background-color: #22673D;
  border: 1px #ffffff solid;
  color:#ffffff ;
}


.form-content_i textarea {
  width: 100%;
  padding: 8px 20px;
  border-radius: 6px;
  text-align: left;
  background-color: var(--color-proyecto);
  border: 1px solid #ffffff ;
  font-size: 15px;
  font-weight: 300;
  color:#ffffff;
  height: 120px;
  -webkit-transition: none;
  transition: none;
  margin-bottom: 14px;
}


/* validadción de formulario */

.mv-up{
  margin-top: -9px !important;
  margin-bottom: 8px !important;
}

.invalid-feedback{
  color: #ff606e;
}

.valid-feedback{
 color: #2acc80;
}


#myVideo {
  width: 100%;
  font-family: var(--font-primary);
  font-size: 2rem;
}

#myBtn {
  font-size: 1.2rem;
  font-family: var(--font-primary);
  color: var(--color-secondary);
}

.boton-brochure{
  display: flex;
  justify-content: center;
  align-items: end;
  background-color: var(--color-primary) !important;
}


/* icono de play de video de proyectos */

.play-video{
  position: relative;
  color: transparent ;
}

.play-i{
  position: absolute !important;
  top: 90% ;
  left: 7%;
  transform: translate(-50%, -50%);
  z-index: 10000;
}

.play-i i{
  color: #fffffff6 !important;
  font-size: 3rem !important;
}

.play-video>.play-i i:hover{
  color: rgba(240, 248, 255, 0.651) !important;
}


.bg-titlef{
  background-color: var(--color-barra);
  padding: 2rem 0 2rem 0;
  margin-bottom: 3rem;
  color: #ffff;
  font-family: var(--font-primary);
 }

.bg-titlef h2{
  color: #ffff;
  text-shadow: #000000  2px 2px 5px;
  font-size: 1.5rem;
}
/* boton brochure */

.brochure{
  background-color: var(--color-proyecto);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  height: 5rem;
}

.brochure_text{
  color: #ffffff !important;
}

.brochure:hover{
  background-color: transparent !important;
  border: 1px solid var(--color-proyecto);
  color: var(--color-proyecto) !important;

}

.brochure>.brochure_text:hover{
  color: var(--color-proyecto) !important;

}

.overview {
  background-color: var(--color-proyecto);
    padding: 15px;
    text-align: center;
    border-left: none;
    border-right: none;
}

.overview2 h2{
    background-color: var(--color-proyecto);
    display: flex;
    text-align: center;
    width: 100vw;
    height: 100px;
    font-size: 1.5rem;
    
    justify-content: center;
    align-items: center;
}

.overview h4{
  border-bottom:2px solid #fff ;
  padding: 0 0px 20px 0;
}

.overview .col {
  background-color: var(--color-proyecto);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    line-height: 20px;
    font-size: 10px
}

.overview .icon {
    text-align: center;
    display: block;
    width: 70px;
    margin: 5px auto;
    font-size: 2rem;
}

.text__icon{
    font-size: 1.2rem;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.747);
}

.text-float{
  display: flex;
  justify-content: center;
  font-family: var(--font-secondary);
}

