h1 {
  font-size: clamp(2rem, 5vw, 3.5rem);
}

h2 {
  font-size: clamp(1.5rem, 3vw, 2.5rem);
}

h3 {
  font-size: clamp(1.25rem, 2.5vw, 2rem);
}

h4 {
  font-size: clamp(1.125rem, 2vw, 1.75rem);
}

h5 {
  font-size: clamp(1rem, 1.5vw, 1.2rem);
}

h6 {
  font-size: clamp(0.875rem, 1vw, 1.15rem);
}
html {
  scroll-behavior: smooth;
}
img {
  max-width: 100%;
}
.main {
  background-image: url("https://assets.vitoria.es.gov.br/pmv/images/wave.svg");
  background-position: top center;
  background-repeat: no-repeat;
}

section h2 {
  font-weight: 700;
  text-align: center;
  margin: 2rem 0 1.5rem;
  position: relative;
  letter-spacing: -1px;
  padding: 20px 0;
}

section h2::after {
  content: "";
  display: block;
  width: 6rem; /* largura da trave */
  height: 0.4rem; /* altura/espessura da trave */
  border-radius: 999px;
  margin: 0.6rem auto 0;
}
.card,
.btn {
  border: none;
}
.gra-1 {
  background: linear-gradient(
    to bottom,
    rgba(254, 219, 111, 0.3) 0%,
    rgba(254, 219, 111, 1) 100%
  );
}
.gra-2 {
  background: linear-gradient(
    to bottom,
    rgba(243, 199, 224, 0.3) 0%,
    rgba(243, 199, 224, 1) 100%
  );
}
.gra-3 {
  background: linear-gradient(
    to bottom,
    rgba(185, 241, 232, 0.3) 0%,
    rgba(185, 241, 232, 1) 100%
  );
}
.gra-4 {
  background: linear-gradient(
    to bottom,
    rgba(218, 230, 255, 0.3) 0%,
    rgba(218, 230, 255, 1) 100%
  );
}
.gra-5 {
  background: linear-gradient(
    to bottom,
    rgba(231, 243, 217, 0.3) 0%,
    rgba(231, 243, 217, 1) 100%
  );
}
.gra-6 {
  background: linear-gradient(
    to bottom,
    rgba(230, 227, 247, 0.3) 0%,
    rgba(230, 227, 247, 1) 100%
  );
}
.gra-7 {
  background: linear-gradient(
    to bottom,
    rgba(249, 250, 255, 1) 0%,
    rgba(220, 226, 254, 1) 100%
  );
}
.gra-8 {
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 1) 0%,
    rgba(194, 218, 242, 1) 100%
  );
}
.gra-9 {
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 1) 0%,
    rgba(254, 220, 116, 1) 100%
  );
}
.bg-geometric {
  background: url(imagens/bg-hero-left.png) center left no-repeat,
    url(imagens/bg-hero-right.png) center right no-repeat;
}
.bg-rox {
  background-color: var(--cor-rox-pri);
}
.bg-ver {
  background-color: var(--cor-ver-pri);
}
.bg-ama {
  background-color: var(--cor-ama-pri) !important;
}
.offcanvas {
  background: var(--cor-sec);
  max-width: 80%;
}
.offcanvas h5 {
  color: var(--cor-bra);
}
.offcanvas button {
  color: var(--cor-bra);
}

/* hero section */
.hero-section {
  background-color: #ebf0fe;
  height: calc(100vh - 148px);
}
.hero-cta {
  display: grid;
  justify-items: center;
  align-items: center;
  justify-content: stretch;
  align-content: center;
}
.btn-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  align-content: center;
  flex-wrap: wrap;
  flex-direction: row;
  border: 5px solid #dae6ff;
  margin: 13px 0;
  padding: 10px;
  width: 70%;
  background: radial-gradient(
    ellipse at center,
    rgba(254, 220, 116, 1) 34%,
    rgba(254, 193, 10, 1) 100%
  );
  font-family: "open_bold", arial;
  color: #0a77c6;
  border-radius: 30px;
}
.hero-cta .btn-cta .ico {
  color: #a67c00;
  font-size: 40px;
}
.hero-txt {
  font-family: "open_sansregular", arial;
  text-align: center;
  color: var(--cor-azu-pri);
  letter-spacing: -1px;
}
/* beneficios */
.ben-section {
  padding-top: 30px;
  padding-bottom: 80px;
}
.ben-section h2 {
  color: var(--cor-azu-pri);
}
.ben-section h2::after {
  background: var(--cor-ros-pri);
}
.box-ben {
  height: 100%;
  padding: 20px;
  border-radius: 10px;
}
.box-ben h5 {
  letter-spacing: -1px;
  font-family: "Open_Bold";
  margin-bottom: 20px;
}
/* prazos */
.pra-section {
  padding-top: 20px;
  padding-bottom: 80px;
  background: linear-gradient(
    to bottom,
    rgba(235, 240, 254, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
}
.pra-section h2 {
  color: var(--cor-azu-pri);
}
.pra-section h2::after {
  background: var(--cor-ver-pri);
}
.border-end {
  border-right: 10px solid #dde2fe !important ;
}
.pra-section table {
  line-height: 1;
  text-align: center;
}
.pra-section .table {
  --bs-table-bg: none !important;
}
.pra-section table tr {
  vertical-align: middle;
}
.pra-section table.t-r thead tr {
  background-color: var(--cor-rox-sec);
}
.pra-section table.t-v thead tr {
  background-color: var(--cor-ver-pri);
}
.pra-section table td {
  background-color: var(--cor-bra);
  padding: 6px;
}
.pra-section .card-body {
  padding: 8px;
}

/* perguntas frequentes */
.faq-section {
  padding-top: 20px;
  padding-bottom: 50px;
  background: linear-gradient(rgba(92, 156, 221, 0.7), rgba(92, 156, 221, 0.7)),
    url("imagens/bg-hero-left.png") left center no-repeat,
    url("imagens/bg-hero-right.png") right center no-repeat var(--cor-azu-pri);
  background-attachment: fixed;
}
.faq-section h2 {
  color: var(--cor-bra);
}
.faq-section h2::after {
  background: var(--cor-ama-pri);
}
.faq-section .accordion-item {
  margin-top: 8px;
}
.faq-section .accordion-header button {
  font-family: "open_bold";
  font-size: clamp(1.125rem, 2vw, 1.35rem) !important;
  color: var(--cor-azu-pri) !important;
  padding: 1.4rem;
}
.faq-section .accordion-button {
  background: #f3f2fd;
  -webkit-box-shadow: 1px 1px 9px 1px #2161a0;
  box-shadow: 1px 1px 9px 1px #2161a0;
}
.faq-section .accordion-button::after {
  background-color: var(--cor-ama-pri);
  border-radius: 100px;
  width: 30px;
  height: 30px;
  padding: 2px !important;
  border: 5px solid var(--cor-ama-pri);
}
/* leislação */
.leg-section {
  padding-top: 40px;
  padding-bottom: 180px;
  background: #f3f2fd;
}
.leg-section h2,
.leg-section h3 {
  color: var(--cor-azu-pri);
}
.leg-section h5 {
  color: var(--cor-pre);
  font-family: "open_sansregular";
  font-weight: 500;
}
.leg-section h2::after {
  background: var(--cor-rox-pri);
}
.leg-section .btn {
  border-radius: 100px;
}
/* atendimento */
.ate-section {
  padding-top: 20px;
  padding-bottom: 100px;
  background: var(--cor-azu-pri);
  color: var(--cor-bra);
}
.ate-section h2 {
  color: var(--cor-bra);
}
.ate-section h2::after {
  background: var(--cor-ama-pri);
}
.ate-section h6 {
  font-family: "Open_Bold";
  margin-bottom: 20px;
}
.ate-section a {
  color: var(--cor-bra);
}
.ate-section .can-ico {
  display: flex;
  vertical-align: baseline;
  align-items: center;
  justify-content: flex-start;
  justify-items: start;
  float: left;
  width: 100%;
}
.ate-section .zap {
  filter: invert(1) brightness(2);
  width: 25px;
}
.ate-section .btn {
  line-height: 1.4;
  padding: 20px;
  color: #287bd7;
  font-size: 16px;
  font-family: "open_bold";
}
.bf {
  background-color: #287bd7;
}
/* footer */

footer {
  background-color: #287bd7;
  padding-top: 30px;
  padding-bottom: 30px;
  color: var(--cor-bra);
}
footer img {
  width: 80px !important;
  margin-right: 10px;
}

/* shape */
.custom-shape-divider-bottom-1767029275 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  transform: rotate(180deg);
}

.custom-shape-divider-bottom-1767029275 svg {
  position: relative;
  display: block;
  width: calc(129% + 1.3px);
  height: 80px;
}

.custom-shape-divider-bottom-1767029275 .shape-fill {
  fill: #ffffff;
}

/* atualizar no frontend */
.main {
  background-color: #ebf0fe;
  height: 76px;
  margin-top: 69px;
}
.main-header {
  background-color: var(--cor-pri);
  width: 100%;
}
.main-header .nav-link,
.main-header .navbar-brand {
  color: var(--cor-bra);
}
.main-header .navbar-toggler {
  background-color: var(--cor-bra);
}
.main-header .navbar .nav-item button {
  border: 0;
  background: none;
  color: var(--cor-bra);
  margin: 0 0 0 20px;
  font-family: "open_bold";
  font-size: 14px;
}
.main-header .navbar .nav-item button:hover {
  color: #fff !important;
}

/* MEDIA QUERY BREAKPOINT 
//////////////////////////////////////////////////////*/

@media (max-width: 576px) {
  .box-ben {
    margin-bottom: 10px;
    padding: 10px;
  }
  table,
  p,
  ul li {
    font-size: 14px;
  }
  .pra-section h4 {
    margin-top: 30px;
  }
  .main {
    display: none;
  }
  .main-header {
    position: absolute;
  }
  .btn-cta {
    width: 100%;
    font-size: 14px;
  }
  .main-header {
    top: 0 !important;
    z-index: 99999999999;
  }
  .hero-section {
    height: 100vh;
  }
  .hero-section .hero-content {
    padding-top: 50px;
  }
  .offcanvas .nav-item {
    margin-top: 10px;
    -ms-transition: all 0.4s ease-out;
    -moz-transition: all 0.4s ease-out;
    -webkit-transition: all 0.4s ease-out;
    -o-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
  }
  .fix-h {
    position: fixed;
    float: left;
    top: 0;
    z-index: 999999;
  }
}

@media (max-width: 768px) {
  .main-header {
    top: 54px;
  }
  .main {
    margin-top: 54px;
  }
}

@media (max-width: 992px) {
  .border-end {
    border-right: 1px solid #dde2fe !important ;
  }
}

/* paleta do site (aqui nao deleta) */
:root {
  --cor-azu-pri: #5c9cdd;
  --cor-ros-pri: #f54e84;
  --cor-ver-pri: #b9f1e8;
  --cor-ver-sec: #cde6b3;
  --cor-ama-pri: #fedb6f;
  --cor-rox-pri: #c1b8eb;
  --cor-rox-sec: #d9d7f7;
}
