:root {
  --text-color-blue: #4E95F0;
  --text-color-gray: #111827;
  --text-color-slate: #F1F5F9;
  --color-slate-background: #F1F5F9;
  --text-color-slate-950: #020617;
  --text-color-slate-900: #0F172A;
  --button-text-color: #F8FAFC;
  --button-background: #4E95F0;
}

* {
  margin: 0;
  box-sizing: border-box;
}

body {
  overflow-x: hidden;
  width: 100vw;
  height: auto;
  background-color: var(--color-slate-background);
}

.home {
  background-image: url(/src/assets/img/tophome.png);
  /* object-fit: fill; */
  background-repeat: no-repeat;
  background-size: 100% auto;

  width: 100%;
  min-height: 110vh;

  padding-left: 5.12rem;
  padding-top: 4rem;
  position: relative;
  z-index: 1;
}

.home-text::after {
  content: '';
  display: block;
  height: 200px;
  width: 100%;
  background: transparent;
}

.home-header {
  width: 100%;
  margin-bottom: 10rem;
}

.home-header img {
  width: 120px;
  height: 86px;
}

.home-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 30px;
  align-self: stretch;
  max-width: 40rem;
}

.home-text h1 {
  color: var(--button-text-color);
  font-family: Poppins;
  font-size: 48px;
  font-style: normal;
  font-weight: 600;
  line-height: 57px; /* 118.75% */
  letter-spacing: 0.96px;
}

.home-text p {
  color: var(--button-text-color);
  font-family: Poppins;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 35px; /* 175% */
}

.button {
  display: flex;
  width: 361px;
  padding: 10px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 10rem;

  color: #F8FAFC;
  font-family: Poppins;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  letter-spacing: 0.48px;

  text-decoration: none;
  border-radius: 4px;
  background: var(--button-background);
}


.about-container img {
  width: 100%;
  height: auto;
}

.about .about-container {
  width: 100vw;
  height: auto;

  display: flex;
  flex-direction: center;
  align-items: center;
  gap: 65px;
  position: relative;
  z-index: 0;

  padding: 0 5.12rem;

  margin-bottom: 4rem;
}

.about-text h2 {
  color: var(--text-color-blue);
  font-family: Poppins;
  font-size: 25px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  align-self: stretch;
}

.about-text h3 {
  color: var(--text-color-gray);
  font-family: Poppins;
  font-size: 36px;
  font-style: normal;
  font-weight: 600;
  line-height: 170%; /* 61.2px */
  align-self: stretch;
}

.about-text p {
  color: var(--text-color-slate-950);
  font-family: Poppins;
  font-size: 16px;
  font-style: normal;
  font-weight: 300;
  line-height: 175%; /* 28px */
}

.services {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;

  width: 100%;
  height: auto;

  padding: 0 5.12rem;
  gap: 5rem;
}

.services-container {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 3rem;
}

.services-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  align-self: stretch;
}

.services-box img {
  margin-bottom: 2rem;
}

.services h3 {
  color: var(--text-color-slate-900);
  text-align: center;
  font-family: Poppins;
  font-size: 24px;
  font-style: normal;
  font-weight: 700;
  line-height: 120%; /* 28.8px */
}

.services p {
  color: var(--text-color-slate-900);
  text-align: center;
  font-family: Poppins;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: 140%; /* 33.6px */
}

.services p:last-child {
  color: var(--text-color-slate-950);
  text-align: center;
  font-family: Poppins;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 27px */
}

.solutions {
  width: 100%;
  height: auto;

  margin-bottom: 6.25rem;
  position: relative;
}

.solutions-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 2rem;
  max-width: 60%;
  padding: 0 5.12rem;
}

.solutions-text div {
  display: flex;
  flex-direction: column;
  align-items: cemter;
  justify-content: center;
  gap: 15px;
  align-self: stretch;
}

.solutions-text div p {
  display: inline-flex;
  align-items: center;
}

.solutions-text h2 {
  color: var(--button-background);
  font-family: Poppins;
  font-size: 25px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  align-self: stretch;
}

.solutions-text h3 {
  color: var(--text-color-gray);
  font-family: Poppins;
  font-size: 36px;
  font-style: normal;
  font-weight: 600;
  line-height: 170%; /* 61.2px */
  align-self: stretch;
}

.solutions-text div p {
  color: var(--text-color-slate-900);
  font-family: Poppins;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 170%; /* 34px */
}

.image-solutions {
  width: 48rem;
  height: 46.25rem;
  object-fit: contain;
  z-index: 2;
  position: absolute;
  right: 0;
  bottom: -8rem;
  background-image: url("src/assets/img/imageservices.png");
  background-repeat: no-repeat;
  background-size: contain;
}

.promotion {
  background-image: url(src/assets/img/BackgroundImage.png);
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  width: 100%;
  height: auto;
  padding: 5.75rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.promotion div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 55px;
}

.promotion div p {
  color: var(--button-text-color);
  text-align: center;
  font-family: Poppins;
  font-size: 48px;
  font-style: normal;
  font-weight: 500;
  line-height: 120%; /* 57.6px */
}

.box-container {
  display: flex;
  padding: 5.12rem;
  gap: 1rem;
}

.box-container > div:nth-child(1) {
  max-width: 15rem;
}

.box-container div h3 {
  color: var(--text-color-slate-950);

  font-family: Poppins;
  font-size: 36px;
  font-style: normal;
  font-weight: 600;
  line-height: 44px;
}

.box-container div h3 span {
  color: #4E95F0;

  font-family: Poppins;
  font-size: 36px;
  font-style: normal;
  font-weight: 600;
  line-height: 44px;
}

.box-container > div:nth-child(1) p {
  color: var(--text-color-slate-950);

  font-family: Poppins;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px;
}

.coment-box {
  display: flex;
  padding: 32px 23px;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;

  max-width: 15rem;

  border-radius: 12px;
  background: #FFF;

  /* Shadow/8px */
  box-shadow: 0px 8px 16px 0px rgba(171, 190, 209, 0.40);
}

.coments-container {
  display: flex;
  gap: 1rem;
}

.coment-box div {
  display: flex;
  flex-direction: column;
}

.coment-box .coment-box-img {
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
}

.coment-title p {
  color: var(--text-color-slate-950);
  font-family: Poppins;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 20px;
}

.coment-title p:last-child {
  color: #9CA3AF;

  font-family: Poppins;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 16px;
}

.coment-text {
  color: #262626;

  font-family: Poppins;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 16px;
}

.footer {
  display: flex;
  width: 100%;
  justify-content: space-between;
  padding: 5.12rem;

  flex-shrink: 0;
  background: #04122B;
  gap: 2.25rem;
}

.footer-map {
  width: 37.5rem;
}

.footer-map iframe {
  width: 100%;
  height: 18rem;
}

.more-info {
  display: inline-flex;
  flex-direction: column;
  gap: 0.5rem;
}

.more-info div {
  color: #FFF;
  font-family: Poppins;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 120%;

  display: flex;
  align-items: center;
  gap: .5rem;
}

.more-info div a {
  text-decoration: none;
  color: #FFF;
}

.more-info div a img {
  margin-right: 0.5rem;
}

@media (max-width: 769px) {

  body {
    padding: auto;
  }
  .home {
    background-image: url(/src/assets/img/tophomemobile.png);
    background-size: 100% 100%;
    min-height: 100vh;
    padding-left: 2rem;
    padding-right: 2rem ;

    padding-top: 3rem;
  }

  .home-text h1 {
    color: var(--button-text-color);
    text-align: center;
    font-family: Poppins;
    font-size: 20px;
    font-style: normal;
    font-weight: 600;
    line-height: 57px; /* 285% */
    letter-spacing: 0.4px;
  }

  .home-text p {
    color: var(--button-text-color);
    text-align: center;
    font-family: Poppins;
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: 35px;
  }

  .button {
    color: var(--button-text-color);
    font-family: Poppins;
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 0.28px;

    display: flex;
    width: 192px;
    justify-content: center;
    align-items: center;
    gap: 10px;

    margin-bottom: 8rem;
  }
  
  .home-header {
    margin-bottom: 2rem;
  }

  .home-text::after {
    height: 100px;
  }

  .about .about-container {
    flex-direction: column;
    padding: 0 2rem;
    padding-bottom: 2rem;
    margin-bottom: 0;
  }

  .about-text h2, .solutions-text h2 {
    color: var(--text-color-blue);
    text-align: center;
    font-family: Poppins;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
  }

  .about-text h3 {
    color: var(--text-color-gray);
    text-align: center;
    font-family: Poppins;
    font-size: 20px;
    font-style: normal;
    font-weight: 600;
    line-height: 170%;
  }

  .about-text p {
    color: var(--text-color-slate-950);
    font-family: Poppins;
    font-size: 12px;
    font-style: normal;
    font-weight: 300;
    line-height: 175%; /* 21px */
  }

  .services-container {
    flex-direction: column;
  }

  .services h3 {
    color: var(--text-color-slate-950);
    text-align: center;
    font-family: Poppins;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%; /* 24px */
  }

  .services p {
    color: var(--text-color-slate-900);
    text-align: center;
    font-family: Poppins;
    font-size: 24px;
    font-style: normal;
    font-weight: 600;
    line-height: 140%; /* 33.6px */
  }

  .services p:last-child {
    color: var(--text-color-slate-950);
    text-align: center;
    font-family: Poppins;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%; /* 27px */
  }

  .box-container {
    flex-direction: column;
  }

  .coments-container {
    flex-direction: column;
  }

  .services {
    padding: 0 2rem;
  }

  .solutions {
    margin-bottom: 0;
    padding: 2rem 0;
  }

  .solutions-text {
    padding: 0 2rem;
    max-width: 100%;
  }

  .solutions-text h3 {
    color: var(--text-color-gray);
    text-align: center;
    font-family: Poppins;
    font-size: 20px;
    font-style: normal;
    font-weight: 600;
    line-height: 170%; /* 34px */
  }

  .solutions-text div p {
    color: var(--text-color-slate-950);
    font-family: Poppins;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 170%; /* 20.4px */
  }

  .button {
    margin-bottom: 2rem;
  }

  .image-solutions {
    display: none;
  }

  .promotion {
    padding: 2rem;
  }

  .promotion div {
    gap: 1rem;
  }

  .promotion div p {
    color: var(--button-text-color);
    text-align: center;
    font-family: Poppins;
    font-size: 24px;
    font-style: normal;
    font-weight: 500;
    line-height: 120%;
    padding: 1rem;
  }

  .box-container {
    padding: 2rem;
    align-items: center;
  }

  .box-container div h3, .box-container div h3 span {
    font-size: 24px;
    font-style: normal;
    font-weight: 600;
    line-height: 44px;
  }

  
  .footer {
    padding: 2rem;
    flex-direction: column;
  }

  .footer-map {
    width: 100%;
  }

  .footer-map iframe {
    width: 100%;
  }

  .footer-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
}
