.main_area {
  background-image: url("../img/Recursos/Banner/banner\ 02.png");
  background-position: center;
  background-size: cover;
}

.main_area main {
  height: 750px;
  display: flex;
  color: #e4e4ef;
  align-items: center;
}

.main_area main h1 {
  width: 420px;

  font-size: 50px;
  font-family: GTWalsheimProBold;
}

.main_area main p {
  width: 320px;

  font-size: 22px;
  font-family: GTWalsheimProReg;
  margin: 1.5rem 0rem;
  margin-bottom: 2rem;
}
.main_area main a {
  font-family: GTWalsheimProReg;
  color: #fff;
  background-color: #0059ff;
  width: 230px;
  font-size: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.3s ease all;
  height: 50px;
  border-radius: 99px;
}
.main_area main a:hover {
  background-color: #ffa800;
}

/* roles_section */
.roles_section {
  margin: 4rem auto;
}
.roles_section h1 {
  text-align: center;
  margin-bottom: 4rem;
  font-size: 40px;
  font-family: GTWalsheimProBold;
  color: #e4e4ef;
}

.bottom_roles_section {
  align-items: center;
  display: flex;
  justify-content: center;
}
.bottom_roles_section .cards_section {
  display: flex;
  align-items: center;
  align-items: center;
  grid-gap: 1rem;
}
.bottom_roles_section .cards_section > * {
  flex: 1;
}
.bottom_roles_section .cards_section img {
  width: 100%;
  filter: brightness(60%);
}
.bottom_roles_section .cards_section .card {
  position: relative;
  cursor: pointer;
  transition: 1s ease all;
}
.bottom_roles_section .cards_section .card > * {
  pointer-events: none;
}

.bottom_roles_section .cards_section .card h1 {
  position: absolute;
  top: 50%;
  z-index: 9;
  left: 50%;
  transform: translate(-50%, -50%);
}

.bottom_roles_section .presentation {
  color: #e4e4ef;
  flex-direction: column;
  cursor: pointer;
  animation: show-off 1s;
  opacity: 0;
  display: block;
  margin-right: -300px;
}
.bottom_roles_section .presentation.active {
  animation: show-up 1s;
  display: block;
  opacity: 1;
  margin-right: 0px;
}
.bottom_roles_section .presentation > *:not(a) {
  pointer-events: none;
}
.roles_section .bottom_roles_section .presentation h1 {
  text-align: left;

  margin-bottom: 2rem;
  color: #e4e4ef;
}

@keyframes show-up {
  from {
    margin-right: -300px;
    opacity: 0;
  }
  to {
    margin-right: 0px;
    opacity: 1;
  }
}

@keyframes show-off {
  from {
    margin-right: 0px;
    opacity: 1;
    visibility: visible;
  }
  to {
    margin-right: -250px;
    opacity: 0;
    visibility: hidden;
  }
}

.roles_section .bottom_roles_section .presentation > * + * {
  margin-top: 1rem;
}
.roles_section .bottom_roles_section .presentation p {
  font-size: 20px;
  font-family: GTWalsheimProReg;
}

.roles_section .bottom_roles_section .presentation a {
  font-family: GTWalsheimProReg;
  color: #e4e4ef;
  background-color: #0059ff;
  width: 230px;
  font-size: 20px;
  display: flex;
  margin-top: 2rem;
  justify-content: center;
  align-items: center;
  transition: 0.3s ease all;
  height: 50px;
  border-radius: 99px;
}

.roles_section .bottom_roles_section .presentation a:hover {
  background-color: #e4e4ef !important;
  color: #000;
}

/* DataRocker */
.DataRocker {
  margin-top: 10rem !important;
}
.DataRocker > h1 {
  font-family: GTWalsheimProBold;
  font-size: 40px;
  color: #e4e4ef;
  margin-bottom: 4rem;
}
.DataRocker > .camino_grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  grid-gap: 1rem;
}
.DataRocker > .camino_grid .box {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.DataRocker > .camino_grid .box img {
  transition: 0.3s ease all;
}
.DataRocker > .camino_grid .box h1 {
  font-family: GTWalsheimProBold;
  font-size: 30px;
  color: #e4e4ef;
  margin-top: 1rem;
  position: relative;
}
.DataRocker > .camino_grid .box h1::after {
  content: "";
  transition: 0.3s ease all;
  bottom: -10px;
  left: 50%;
  transform: translateX(-80%);
  position: absolute;

  height: 3px;
  width: 80%;
}
.DataRocker > .camino_grid .box:hover img {
  transform: scale(1.1);
}
.DataRocker > .camino_grid .box:hover h1::after {
  transform: translateX(-50%);
  background-color: #ffa800;
}

/* map_area */
.map_area {
  margin-top: 10rem !important;
  display: grid;
  grid-template-columns: 0.6fr 1fr;
}
.map_area .presentation {
  color: #e4e4ef;
  width: 70%;
}
.map_area .presentation > * + * {
  margin-top: 2rem;
}
.map_area .presentation h1 {
  font-family: GTWalsheimProBold;
  font-size: 40px;
}
.map_area .presentation p {
  font-family: GTWalsheimProReg;
  font-size: 20px;
}
.map_area .presentation a {
  font-family: GTWalsheimProReg;
  color: #e4e4ef;
  background-color: #0059ff;
  width: 200px;
  font-size: 18px;
  display: flex;
  margin-top: 2rem;
  justify-content: center;
  align-items: center;
  transition: 0.3s ease all;
  height: 45px;
  border-radius: 99px;
}
.map_area .presentation a:hover {
  background: #ffa800;
}
.map_area > *:last-child {
  position: relative;
}
.map_area > *:last-child img {
  justify-self: flex-end;
}
.map_area > *:last-child img:hover {
  justify-self: flex-end;
}
.map_area > *:last-child p {
  position: absolute;
  font-family: GTWalsheimProReg;
  color: #fff;
  z-index: 9;
  display: flex;
  align-items: center;
  transition: 0.3s ease all;
}
.map_area > *:last-child p:hover {
  transform: scale(1.1);
}
.map_area > *:last-child p img {
  margin: 0rem 10px;
}
.map_area > *:last-child p.mexico {
  top: 180px;
  left: 20px;
}
.map_area > *:last-child p.Colombia {
  top: 200px;
  left: 140px;
}
.map_area > *:last-child p.Peru {
  top: 270px;
  left: 120px;
}
.map_area > *:last-child p.Chile {
  top: 330px;
  left: 120px;
}
.map_area > *:last-child p.Argentina {
  top: 330px;
  left: 200px;
}
.map_area > *:last-child p.Espana {
  top: 100px;
  left: 280px;
}

.map_area img {
  width: 100%;
}

/* form_area */
.form_area {
  margin-top: 10rem;
  width: 1100px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 5rem;
}
.form_area .left_area > * + * {
  margin-top: 4.7rem;
}
.form_area .box {
  background-color: #31303a;
  padding: 3rem;
  color: #e4e4e4;
  position: relative;
}
.form_area .box .activo1,
.form_area .box .activo2 {
  position: absolute;
}
.form_area .box .activo1 {
  top: 30%;
  transform: translateY(-30%);
  left: 20px;
}
.form_area .box .activo2 {
  bottom: 30%;
  transform: translateY(-30%);
  right: 20px;
}
.form_area .box h1 {
  font-family: GTWalsheimProBold;
  font-size: 35px;
  margin-bottom: 1rem;
}
.form_area .box p,
.form_area .box label {
  font-family: GTWalsheimProReg;
  font-size: 20px;
}
.form_area .grid_images {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.form_area .grid_images img {
  width: 100%;
}

.form_area .box form {
  display: grid;
  margin-top: 0rem;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 20px;
}
.form_area .box form .input_wrapper {
  margin-top: 3rem;
  grid-column: span 2;
}
.form_area .box form .input_one {
  grid-column: span 1;
}
.form_area .box form input {
  width: 100%;
  height: 45px;

  border: 1px solid #0059ff;
  background-color: #5b5a62;
  font-size: 16px;
  color: #fff;
  padding: 0rem 1rem;
  outline: none;
  margin-top: 10px;
}

.form_area .box form button {
  background-color: #0059ff;
  color: #fff;
  height: 45px;
  border: none;
  grid-column: span 2;
  width: 50%;
  cursor: pointer;
  justify-self: flex-end;
  outline: none;
  font-size: 16px;
  margin-top: 3rem;
  transition: 0.3s ease all;
  border-radius: 99px;
}
.form_area .box form button:hover {
  background-color: #ffa800;
}

/* profile_pic */
.profile_pic {
  display: flex;
  align-items: center;
  margin-top: 2rem;
}
.profile_pic > img {
  border-radius: 50%;
  object-fit: cover;
  width: 65px;
  height: 65px;
}
.profile_pic .presentation {
  margin-left: 10px;
}
.profile_pic .presentation h1 {
  font-size: 18px;
  margin-bottom: 5px;
}
.profile_pic .presentation p {
  font-size: 16px;
}
/* dropdown_section */
.dropdown_section {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  height: 800px;
  position: relative;
}
.dropdown_section .dropdown {
  display: flex;

  align-items: flex-end;
}
.dropdown_section .dropdown:nth-child(2) {
  position: absolute;
  left: 50%;
  top: 90px;
  transform: translateX(-50%);
}
.dropdown_section .dropdown:nth-child(1) {
  position: absolute;
  left: 35%;
  top: 180px;
  transform: translateX(-35%);
}
.dropdown_section .dropdown:nth-child(3) {
  position: absolute;
  left: 65%;
  transform: translateX(-65%);
}
.dropdown_section .bar {
  display: flex;
  align-items: flex-end;
  animation-duration: 1s;
  animation-name: slide-top;
  height: 350px;
  min-width: 120px;
  margin-right: 10px;
  border: 4px solid #fff;
  padding: 2rem 0rem;
  border-radius: 99px;
  justify-content: center;
}
.dropdown_section .bar.active {
  animation-duration: 1s;
  animation-name: slide-down;
  height: 500px;
}
.dropdown_section .presentation p {
  opacity: 0;
  animation-duration: 0.5s;
  animation-name: slide-top-p;
  transform: 0.3s ease all !important;
}
.dropdown_section .presentation p.active {
  opacity: 1;
  animation-duration: 1s;
  animation-name: slide-down-p;
}
@keyframes slide-down {
  from {
    height: 350px;
  }
  to {
    height: 500px;
  }
}
@keyframes slide-top {
  from {
    height: 500px;
  }
  to {
    height: 350px;
  }
}
@keyframes slide-down-p {
  from {
    opacity: 0;
  }
  top {    
    opacity: 1;
  }
}
@keyframes slide-top-p {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.dropdown_section .dropdown:nth-child(2) .bar {
  border-color: #0059ff;
}
.dropdown_section .dropdown:nth-child(3) .bar {
  border-color: #ffa800;
}
.dropdown_section .dropdown {
  position: relative;
}

.dropdown_section .presentation {
  position: relative;
  transform: translateY(120px);
}

.dropdown_section .presentation p {
  width: 250px;
  color: #fff;
  font-size: 18px;
  font-family: GTWalsheimProReg;
}
.dropdown_section img {
  cursor: pointer;
}
.dropdown_section h1 {
  font-family: GTWalsheimProBold;
  color: #fff;
  cursor: pointer;
  font-size: 30px;

  margin-bottom: 1rem;
}
.dropdown_section h1 > * {
  pointer-events: none;
}
.dropdown_section .dropdown:last-child h1 span {
  color: #ffa800;
}
.dropdown_section .dropdown:nth-child(2) h1 span {
  color: #0059ff;
}
@media screen and (max-width: 1350px) {
  .roles_section .bottom_roles_section .presentation p {
    width: 100%;
  }
  .form_area {
    width: 90%;
  }
  .map_area .presentation {
    width: 95%;
  }
  .dropdown_section {
    display: none;
  }
}
@media screen and (max-width: 1200px) {
  .bottom_roles_section {
    grid-template-columns: 1fr;
  }
  .main_area header nav {
    display: none;
  }
}
@media screen and (max-width: 1250px) {
  .map_area {
    grid-template-columns: 1fr;
  }
  .map_area > *:last-child {
    display: none;
  }
}
@media screen and (max-width: 1000px) {
  .form_area {
    grid-template-columns: 1fr;
  }
  .bottom_roles_section .cards_section {
    flex-direction: column;
  }
  .bottom_roles_section .presentation {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .bottom_roles_section .presentation > * {
    text-align: center !important;
  }
}
@media screen and (max-width: 1000px) {
  .main_area main {
    justify-content: center;
    text-align: center;
  }
  .main_area main p {
    width: 420px;
  }
  main .presentation {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 800px) {
  .bottom_roles_section .cards_section .card h1 {
    font-size: 26px;
  }
  .main_area main h1 {
    font-size: 40px;
  }
  .roles_section h1,
  .DataRocker > h1,
  .form_area .box h1,
  .map_area .presentation h1 {
    font-size: 30px;
  }
  .DataRocker > .camino_grid .box h1 {
    font-size: 20px;
  }
}

@media screen and (max-width: 550px) {
  .DataRocker > .camino_grid {
    display: grid;

    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (max-width: 450px) {
  .main_area main h1 {
    font-size: 30px;
    width: 90%;
  }
  .main_area main p {
    font-size: 14px;
    width: 90%;
  }
  .roles_section .bottom_roles_section .presentation p,
  .roles_section .bottom_roles_section .presentation a {
    font-size: 14px;
  }
  .bottom_roles_section .cards_section .card h1 {
    font-size: 20px;
  }

  /*  button */
  .roles_section .bottom_roles_section .presentation a {
    height: 40px;
    width: 170px;
  }
  .roles_section h1,
  .DataRocker > h1,
  .form_area .box h1,
  .map_area .presentation h1 {
    font-size: 20px;
  }

  /* box */
  .form_area .box {
    padding: 2rem;
  }

  main .presentation {
    transform: translateY(-50px);
  }
}
