@import url("../../user_interface_standards/styles/colors/qmd_cores.css");
@import url("../../user_interface_standards/styles/fonts/qmd_fonte.css");

.main-banner {
  height: auto;
  overflow: hidden;
  margin-bottom: 2rem;
  transform: scale(1);
  transition: transform 0.2s ease-in-out;
}
.main-banner:hover {
  transform: scale(1.05);
}
.main-banner a {
  text-decoration: none;
}

.main-banner-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  background-color: var(--color-dark-primary);
  background-image: linear-gradient(
    45deg,
    var(--color-dark-gray) 0%,
    var(--color-dark-primary) 100%
  );
}
.main-banner-content h2 {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-dark-secondary);
  text-align: center;
}
.main-banner-content p {
  font-size: 0.9rem;
  text-align: center;
  color: var(--color-dark-secondary);
}
.main-banner-content p:last-of-type {
  margin-bottom: 0;
}

.main-banner-image {
  display: flex;
  flex-direction: column;
  align-items: end;
  padding: 0;
}
.main-banner-image img {
  width: 135%;
}

/* Static Alert Main Banner  */
.main-banner-alert {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  position: relative;
}
.main-banner-alert::after {
  content: "";
  position: absolute;
  top: -5px;
  right: -5px;
  bottom: -5px;
  left: -5px;
  /* background-image: url(../img/banner_manutencao-programada.png); */
  /* background-image: url(../img/banner_aviso-sat.jpg); */
  background-image: url(../img/banner-banco-curriculos-02.jpg);
  background-size: cover;
  background-position: center;
  filter: blur(3px);
  z-index: -1;
}
.main-banner-alert h2 {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  text-align: center;
}
.main-banner-alert p {
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
}
.main-banner-alert i {
  color: #f93;
  font-size: 3rem;
}

/* Animated Main Banner */
.main-banner-animated {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 16px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.main-banner-animated::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../img/banner_portal_1176.png");
  background-position: left;
  animation: scaleBackground 15s infinite alternate;
}
.main-banner-animated p,
.main-banner-animated h2 {
  position: relative;
  line-height: 1.2;
  background-color: rgba(165, 42, 42, 0.7);
  color: var(--color-light-primary);
  text-align: center;
  padding: 0.5rem;
  margin: 0.2rem 0;
}
.main-banner-animated p {
  font-size: 1.2rem;
}
.main-banner-animated h2 {
  font-weight: 600;
  font-size: 1.4rem;
  text-transform: none;
}
@keyframes scaleBackground {
  0% {
    transform: scale(1.2);
    background-position: left;
  }
  100% {
    transform: scale(1);
    background-position: left center;
  }
}

@media (min-width: 768px) {
  .main-banner {
    border-radius: 15px;
  }

  .main-banner-content {
    padding: 2rem;
  }
  .main-banner-content h2 {
    font-size: 1.8rem;
    font-weight: 700;
  }
  .main-banner-content p {
    font-size: 1rem;
  }

  .main-banner-alert {
    padding: 2rem;
  }
  .main-banner-alert h2 {
    font-size: 1.8rem;
    font-weight: 700;
  }
  .main-banner-alert p {
    font-size: 1rem;
  }

  .main-banner-animated {
    padding: 0 3rem 0 12rem;
    align-items: end;
  }
  .main-banner-animated p,
  .main-banner-animated h2 {
    font-size: 1.5rem;
    background-color: rgba(0, 0, 0, 0);
    color: var(--cor-do-texto);
    text-align: right;
    padding: 0;
  }
  .main-banner-animated h2 {
    font-size: 1.9rem;
    text-transform: none;
    font-weight: 700;
  }
}

@media (min-width: 1024px) {
  .main-banner-image img {
    width: 100%;
  }

  .main-banner-content {
    flex-direction: row;
    column-gap: 1rem;
    align-items: center;
  }
  .main-banner-content h2 {
    font-size: 1.8rem;
    font-weight: 700;
    text-align: left;
  }
  .main-banner-content p {
    font-size: 1rem;
    text-align: left;
  }

  .main-banner-alert h2 {
    font-size: 1.7rem;
    font-weight: 700;
  }
  .main-banner-alert p {
    font-size: 1.25rem;
  }

  .main-banner-animated {
    padding: 1rem 2rem 1rem 14rem;
    align-items: start;
  }
  .main-banner-animated p,
  .main-banner-animated h2 {
    text-align: left;
  }
  .main-banner-animated h2 {
    font-size: 2.1rem;
  }
  .main-banner-animated::before {
    animation: scaleBackground 20s infinite alternate;
  }
}
