@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&family=Permanent+Marker&family=JetBrains+Mono:wght@400;600;700&family=Roboto+Slab:wght@400;500;700;800&family=Inter:wght@400;500;700&family=Kalam:wght@400;700&display=swap');

:root {
  --kraft: #D4B896;
  --kraft-dark: #A8895C;
  --kraft-light: #E8D4AE;
  --ink: #1A1814;
  --ink-soft: #3D3528;
  --pencil: #5A4F3F;
  --red: #B91C1C;
  --red-soft: #FFCDD2;
  --yellow: #E8B923;
  --yellow-soft: #FFF3C4;
  --orange: #FF6B1A;
  --green: #0E5C2F;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

html,
body {
  background: var(--kraft);
  color: var(--ink);
  font-family: Inter, sans-serif;
  line-height: 1.5;
  max-width: 100%
}

body:before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(circle at 10% 20%, rgba(0, 0, 0, .06) 0, transparent 40%), radial-gradient(circle at 80% 70%, rgba(0, 0, 0, .08) 0, transparent 50%), repeating-linear-gradient(45deg, rgba(168, 137, 92, .08) 0 2px, transparent 2px 6px)
}

a {
  color: inherit;
  text-decoration: none
}

.wrap {
  position: relative;
  z-index: 1
}

.forum-bar {
  background: var(--ink);
  padding: 18px 60px;
  display: flex;
  justify-content: center;
  border-bottom: 3px solid var(--yellow)
}

.forum-bar img {
  height: 90px;
  max-width: 420px;
  object-fit: contain
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 60px;
  background: var(--ink);
  color: var(--kraft);
  border-bottom: 6px solid var(--yellow);
  font-family: Oswald;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .06em;
  position: relative
}

.topbar:after,
.rodape:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 6px;
  background: repeating-linear-gradient(90deg, var(--yellow) 0 14px, var(--ink) 14px 18px)
}

.topbar:after {
  bottom: -6px
}

.brand .logo,
.logo {
  font-family: "Permanent Marker";
  font-size: 30px;
  color: var(--yellow);
  text-transform: none;
  letter-spacing: 0
}

.nav {
  display: flex;
  gap: 28px
}

.nav a {
  opacity: .86
}

.hero {
  padding: 80px 60px 100px;
  position: relative;
  overflow: hidden;
  border-bottom: 4px solid var(--ink)
}

.hero:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 50%;
  background: linear-gradient(180deg, rgba(26, 24, 20, .15), rgba(26, 24, 20, .55)), repeating-linear-gradient(90deg, rgba(0, 0, 0, .04) 0 2px, transparent 2px 8px);
  background-color: var(--kraft-dark);
  clip-path: polygon(8% 0, 100% 0, 100% 100%, 0 100%);
  z-index: 0
}

.hero .grid {
  position: relative;
  z-index: 1;
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 80px;
  align-items: center
}

.label-carimbo,
.label-c {
  display: inline-block;
  font-family: "JetBrains Mono";
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--yellow);
  padding: 8px 14px;
  margin-bottom: 28px;
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 var(--ink);
  transform: rotate(-1deg)
}

.hero h1 {
  font-family: Oswald;
  font-weight: 700;
  font-size: 124px;
  line-height: .9;
  text-transform: uppercase;
  margin-bottom: 24px
}

.hero h1 .pergunta {
  display: block;
  font-family: "Permanent Marker";
  font-weight: 400;
  color: var(--red);
  text-transform: none;
  font-size: 48px;
  transform: rotate(-1.5deg);
  margin-top: 14px;
  letter-spacing: 0
}

.hero h1 .resposta {
  display: block;
  font-family: Kalam;
  font-weight: 700;
  text-transform: none;
  font-size: 30px;
  transform: rotate(.8deg);
  margin-top: 28px;
  letter-spacing: 0
}

.hero h1 .resposta b {
  background: var(--yellow);
  padding: 2px 10px;
  border: 2px solid var(--ink);
  box-shadow: 3px 3px 0 var(--ink)
}

.lede {
  font-family: "Roboto Slab";
  font-size: 22px;
  line-height: 1.5;
  max-width: 720px;
  color: var(--ink-soft);
  margin-bottom: 36px
}

.assinatura {
  margin-top: 30px;
  font-family: "Permanent Marker";
  font-size: 22px;
  color: var(--ink-soft);
  transform: rotate(-1.5deg);
  display: inline-block
}

.btn,
.btn-cad,
.btn-wpp {
  display: inline-block;
  font-family: Oswald;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  border: 3px solid var(--ink);
  cursor: pointer
}

.btn {
  font-size: 18px;
  padding: 16px 28px;
  background: var(--ink);
  color: var(--yellow);
  box-shadow: 6px 6px 0 var(--orange)
}

.btn.outline {
  background: var(--kraft);
  color: var(--ink);
  box-shadow: 6px 6px 0 var(--ink)
}

.cta-row {
  display: flex;
  gap: 18px;
  flex-wrap: wrap
}

.geo-card,
.rec-cont,
.regua-cont {
  background: var(--kraft-light);
  border: 5px solid var(--ink);
  box-shadow: 12px 12px 0 var(--ink);
  padding: 32px
}

.geo-card .pin,
.estado-box .pin {
  font-family: "JetBrains Mono";
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 12px
}

.geo-card h3,
.estado-box h3 {
  font-family: Oswald;
  font-size: 30px;
  line-height: 1;
  text-transform: uppercase
}

.estado-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px
}

.uf-big,
.estado-box .uf {
  font-family: "Permanent Marker";
  font-size: 54px;
  color: var(--orange);
  line-height: 1;
  display: inline-block;
  transform: rotate(-1deg)
}

.estado-select-wrap {
  flex: 1;
  position: relative
}

.estado-select-wrap label,
.form-card label {
  display: block;
  font-family: "JetBrains Mono";
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--pencil);
  margin-bottom: 4px
}

.estado-select,
.busca-input,
.form-card input {
  width: 100%;
  padding: 12px 14px;
  background: #fff;
  color: var(--ink);
  border: 3px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink)
}

.estado-select {
  font-family: Oswald;
  font-weight: 600;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 10px 36px 10px 14px;
  appearance: none;
  cursor: pointer
}

.busca-input,
.form-card input {
  font-family: "Roboto Slab"
}

.meta {
  font-family: "JetBrains Mono";
  font-size: 11px;
  color: var(--pencil);
  letter-spacing: .1em;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 2px dashed var(--ink)
}

.busca-bar {
  display: flex;
  gap: 8px;
  margin-bottom: 14px
}

.busca-input-wrap {
  flex: 1
}

.filtro-btn {
  font-family: Oswald;
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 10px 14px;
  background: var(--ink);
  color: var(--yellow);
  border: 3px solid var(--ink);
  box-shadow: 3px 3px 0 var(--orange)
}

.filtros-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 16px
}

.chip {
  font-family: "JetBrains Mono";
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 10px;
  background: var(--kraft);
  border: 2px solid var(--ink)
}

.chip.ativo {
  background: var(--yellow)
}

.chip.aprov {
  border-left: 5px solid var(--green)
}

.chip.neutro {
  border-left: 5px solid var(--yellow)
}

.chip.repr {
  border-left: 5px solid var(--red)
}

.lista {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 330px;
  overflow-y: auto
}

.lista .item {
  background: var(--kraft);
  border: 2px solid var(--ink);
  padding: 10px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "Roboto Slab";
  font-size: 14px
}

.item.aprov {
  border-left: 8px solid var(--green)
}

.item.neutro {
  border-left: 8px solid var(--yellow)
}

.item.repr {
  border-left: 8px solid var(--red)
}

.partido {
  font-family: "JetBrains Mono";
  font-size: 11px;
  color: var(--pencil);
  letter-spacing: .1em
}

.empty {
  background: #fff;
  border: 3px solid var(--ink);
  padding: 18px;
  font-family: "Roboto Slab"
}

.empty.wide {
  grid-column: 1/-1
}

.faixa {
  background: var(--yellow);
  border-top: 4px solid var(--ink);
  border-bottom: 4px solid var(--ink);
  padding: 40px 60px
}

.faixa-cont {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 50px
}

.faixa h4,
.passos h2,
.step h5 {
  font-family: Oswald;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.05
}

.faixa h4 {
  font-size: 26px;
  margin-bottom: 8px
}

.faixa p,
.step p {
  font-family: "Roboto Slab";
  font-size: 15px;
  color: var(--ink-soft)
}

.num {
  font-family: "Permanent Marker";
  font-size: 48px;
  color: var(--red)
}

.passos {
  padding: 80px 60px
}

.passos h2 {
  text-align: center;
  font-size: 54px;
  margin-bottom: 50px
}

.passos h2 em,
.hero3 h1 em,
.cadastro-cont h2 em,
.votacoes h3 em {
  font-family: "Permanent Marker";
  font-style: normal;
  color: var(--red)
}

.passos .grid {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px
}

.step {
  background: var(--kraft-light);
  border: 4px solid var(--ink);
  padding: 32px 24px;
  box-shadow: 8px 8px 0 var(--ink);
  position: relative
}

.step .n {
  position: absolute;
  top: -18px;
  left: -18px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--orange);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Oswald;
  font-weight: 700;
  font-size: 34px;
  border: 4px solid var(--ink)
}

.crumb {
  background: var(--kraft-dark);
  padding: 14px 60px;
  font-family: "JetBrains Mono";
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-bottom: 2px solid var(--ink)
}

.sep {
  margin: 0 8px;
  color: var(--pencil)
}

.hero-parl {
  padding: 50px 60px 30px
}

.hero-parl .grid {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 220px 1fr 480px;
  gap: 50px;
  align-items: start
}

.foto-box {
  width: 220px;
  height: 280px;
  background: var(--kraft-dark);
  border: 5px solid var(--ink);
  box-shadow: 10px 10px 0 var(--ink);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden
}

.foto-box:after {
  content: "FOTO";
  font-family: "JetBrains Mono";
  font-weight: 700;
  letter-spacing: .3em
}

.foto-box:has(.foto-perfil):after {
  content: ""
}

.foto-perfil {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover
}

.carimbo-id {
  position: absolute;
  bottom: 8px;
  left: 8px;
  right: 8px;
  background: var(--yellow);
  font-family: "JetBrains Mono";
  font-size: 10px;
  font-weight: 700;
  padding: 4px 6px;
  border: 2px solid var(--ink);
  text-align: center
}

.dados h1 {
  font-family: Oswald;
  font-size: 72px;
  line-height: .95;
  text-transform: uppercase
}

.meta-grid {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 22px;
  margin-top: 18px
}

.meta-item {
  font-family: "JetBrains Mono";
  font-size: 12px;
  color: var(--ink-soft);
  border-left: 4px solid var(--ink);
  padding-left: 12px
}

.meta-item strong {
  display: block;
  font-family: Oswald;
  font-size: 22px;
  color: var(--ink)
}

.bio {
  margin-top: 24px;
  font-family: "Roboto Slab";
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-soft);
  padding: 18px;
  background: var(--kraft-light);
  border-left: 6px solid var(--yellow)
}

.bio.aprovado {
  border-color: var(--green)
}

.bio.reprovado {
  border-color: var(--red)
}

.selo-destaque {
  border: 6px solid var(--ink);
  padding: 30px;
  box-shadow: 12px 12px 0 var(--ink);
  position: relative;
  background: #E8E5DC
}

.selo-destaque.aprovado {
  background: #C8E6C9;
  border-color: var(--green)
}

.selo-destaque.reprovado {
  background: var(--red-soft);
  border-color: var(--red)
}

.tag-c {
  position: absolute;
  top: -16px;
  right: -12px;
  background: var(--yellow);
  font-family: "JetBrains Mono";
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .18em;
  padding: 6px 10px;
  border: 2px solid var(--ink);
  box-shadow: 3px 3px 0 var(--ink);
  transform: rotate(3deg)
}

.polegar-img {
  width: 180px;
  height: 180px;
  background: var(--yellow);
  border: 6px solid var(--ink);
  border-radius: 50%;
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden
}

.aprovado .polegar-img {
  background: var(--green)
}

.reprovado .polegar-img {
  background: var(--red)
}

.polegar-img img {
  width: 92%;
  height: 92%;
  object-fit: contain
}

.selo-destaque h2 {
  font-family: Oswald;
  font-size: 36px;
  text-align: center;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 12px
}

.selo-destaque .veredito {
  font-family: "Roboto Slab";
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  background: #fff;
  border: 3px solid var(--ink);
  padding: 14px
}

.regua-section,
.votacoes,
.recomendados {
  padding: 30px 60px 60px
}

.regua {
  height: 60px;
  border: 4px solid var(--ink);
  background: linear-gradient(to right, var(--red) 0 35%, #FFD200 35% 60%, var(--green) 60% 100%);
  position: relative;
  margin-top: 30px
}

.marca {
  position: absolute;
  top: -8px;
  bottom: -8px;
  width: 6px;
  background: var(--ink)
}

.ponteiro {
  position: absolute;
  top: -32px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 14px solid transparent;
  border-right: 14px solid transparent;
  border-top: 22px solid var(--ink)
}

.ponteiro:after {
  content: attr(data-percent);
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  font-family: Oswald;
  background: var(--ink);
  color: var(--yellow);
  padding: 3px 8px
}

.regua-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 14px;
  font-family: "JetBrains Mono";
  font-size: 11px
}

.regua-resumo {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 28px
}

.regua-resumo .item {
  padding: 18px;
  border: 3px solid var(--ink);
  background: #fff
}

.regua-resumo .a {
  border-left: 10px solid var(--green)
}

.regua-resumo .n {
  border-left: 10px solid var(--yellow)
}

.regua-resumo .r {
  border-left: 10px solid var(--red)
}

.regua-resumo h5,
.regua-cont h3,
.votacoes h3 {
  font-family: Oswald;
  font-size: 36px;
  text-transform: uppercase;
  line-height: 1
}

.regua-resumo .num {
  font-size: 46px
}

.votacoes-cont {
  max-width: 1760px;
  margin: 0 auto
}

.sub {
  font-family: "Roboto Slab";
  font-size: 15px;
  color: var(--ink-soft);
  margin-bottom: 24px
}

.legenda-bloco {
  background: var(--kraft-light);
  border: 3px solid var(--ink);
  padding: 18px 22px;
  margin-bottom: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  box-shadow: 5px 5px 0 var(--ink)
}

.legenda-bloco h6 {
  font-family: Oswald;
  font-size: 14px;
  text-transform: uppercase;
  border-bottom: 2px solid var(--ink);
  margin-bottom: 6px
}

.vot-header,
.vot-row {
  display: grid;
  grid-template-columns: 1fr 280px 280px 110px;
  gap: 20px;
  align-items: center
}

.vot-header {
  background: var(--ink);
  color: var(--yellow);
  padding: 14px 22px;
  margin-bottom: 8px;
  font-family: Oswald;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 13px
}

.vot-row {
  background: var(--kraft-light);
  border: 3px solid var(--ink);
  padding: 18px 22px;
  margin-bottom: 10px;
  box-shadow: 5px 5px 0 var(--ink)
}

.titulo {
  font-family: Oswald;
  font-weight: 700;
  font-size: 20px;
  text-transform: uppercase
}

.pl-info .meta {
  border: 0;
  padding: 0;
  margin: 3px 0
}

.pauta {
  font-family: "Roboto Slab";
  font-size: 13px;
  color: var(--ink-soft);
  font-style: italic
}

.col-pos,
.col-vot {
  display: flex;
  align-items: center;
  background: #fff;
  border: 3px solid var(--ink);
  padding: 10px 14px
}

.col-pos {
  gap: 14px
}

.col-vot {
  justify-content: center
}

.icone {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border: 3px solid var(--ink);
  font-weight: 700
}

.ok {
  background: var(--green)
}

.nok {
  background: var(--red)
}

.aus {
  background: var(--yellow);
  color: var(--ink)
}

.texto {
  font-family: Oswald;
  text-transform: uppercase
}

.texto small {
  display: block;
  font-family: "JetBrains Mono";
  font-size: 10px;
  color: var(--pencil)
}

.tag {
  font-family: Oswald;
  text-transform: uppercase;
  padding: 8px 14px;
  border: 3px solid var(--ink);
  color: #fff;
  background: #1565C0
}

.tag.contra {
  background: #6A1B9A
}

.tag.abstencao,
.tag.ausente {
  background: #9A7B00
}

.data {
  font-family: "JetBrains Mono";
  font-size: 13px;
  text-align: right
}

.hero3 {
  padding: 60px 60px 30px
}

.hero3-cont,
.cadastro-cont {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items: center
}

.hero3 h1,
.cadastro-cont h2 {
  font-family: Oswald;
  font-size: 84px;
  line-height: .95;
  text-transform: uppercase
}

.estado-box {
  background: var(--kraft-light);
  border: 5px solid var(--ink);
  padding: 30px;
  box-shadow: 12px 12px 0 var(--ink)
}

.estado-box .uf {
  font-size: 80px
}

.centrais-row {
  padding: 30px 60px 50px
}

.centrais-grid {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px
}

.central-btn {
  background: #fff;
  border: 3px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 24px
}

.central-btn.ativa {
  border-color: var(--orange);
  transform: translate(-3px, -3px);
  box-shadow: 9px 9px 0 var(--ink)
}

.logo-c-big img {
  max-height: 120px;
  max-width: 90%;
  object-fit: contain
}

.qtd {
  position: absolute;
  top: 8px;
  right: 12px;
  background: var(--ink);
  color: var(--yellow);
  font-family: Oswald;
  font-weight: 700;
  font-size: 18px;
  padding: 4px 10px;
  border-radius: 4px
}

.rec-cont {
  max-width: 1760px;
  margin: 0 auto
}

.rec-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: 3px solid var(--ink)
}

.logo-grande {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  border: 4px solid var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Oswald;
  font-weight: 700;
  font-size: 30px
}

.rec-header h2 {
  font-family: Oswald;
  font-size: 38px;
  text-transform: uppercase
}

.rec-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px
}

.candidato {
  background: #fff;
  border: 3px solid var(--ink);
  padding: 20px;
  box-shadow: 5px 5px 0 var(--ink);
  display: flex;
  gap: 16px;
  position: relative
}

.foto-mini {
  width: 80px;
  height: 100px;
  border: 3px solid var(--ink);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center
}

.foto-mini img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain
}

.info h4 {
  font-family: Oswald;
  text-transform: uppercase;
  font-size: 20px
}

.partido-uf {
  font-family: "JetBrains Mono";
  font-size: 11px;
  color: var(--pencil);
  letter-spacing: .1em;
  margin-bottom: 10px
}

.razao {
  font-family: "Roboto Slab";
  font-size: 12px;
  background: var(--kraft-light);
  border-left: 4px solid var(--red);
  padding: 8px
}

.stamp {
  position: absolute;
  top: -10px;
  right: -10px;
  background: var(--red);
  color: #fff;
  font-family: "JetBrains Mono";
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .15em;
  padding: 4px 8px;
  border: 2px solid var(--ink);
  transform: rotate(8deg)
}

.cadastro-bar {
  background: var(--yellow);
  padding: 50px 60px;
  border-top: 5px solid var(--ink);
  border-bottom: 5px solid var(--ink)
}

.form-card {
  background: var(--ink);
  color: var(--kraft);
  padding: 30px;
  border: 5px solid var(--ink);
  box-shadow: 10px 10px 0 var(--orange)
}

.form-card label {
  color: var(--yellow);
  margin-top: 14px
}

.form-card input {
  background: var(--kraft-light);
  border-color: var(--yellow);
  box-shadow: none
}

.btn-cad {
  width: 100%;
  margin-top: 20px;
  padding: 18px;
  background: var(--orange);
  color: var(--ink);
  font-size: 18px
}

.btn-wpp {
  width: 100%;
  text-align: center;
  margin-top: 12px;
  padding: 14px;
  background: var(--green);
  color: #fff;
  border-color: var(--yellow)
}

.rodape {
  background: var(--ink);
  color: var(--kraft);
  padding: 50px 60px;
  border-top: 6px solid var(--yellow);
  position: relative
}

.rodape:before {
  top: -6px
}

.rodape-grid {
  max-width: 1760px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(390px, 1.7fr) minmax(220px, 1fr) minmax(160px, .7fr) minmax(220px, 1fr);
  gap: 60px;
  font-family: "JetBrains Mono";
  font-size: 12px
}

.rodape-grid>* {
  min-width: 0
}

.rodape h6 {
  font-family: Oswald;
  font-size: 14px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 14px
}

.footer-brand {
  display: block;
  width: 360px;
  font-family: "Permanent Marker";
  font-size: 28px;
  color: var(--yellow);
  line-height: 1.55;
  white-space: normal;
  word-break: normal;
  overflow-wrap: normal;
  margin: 0;
  padding-bottom: 15px;
  margin-top: -10px;
}

.footer-description {
  display: block;
  margin: 0 0 14px;
  clear: both
}

.rodape .marca {
  font-family: "Permanent Marker";
  font-size: 30px;
  color: var(--yellow);
  line-height: 1
}

.muted {
  margin-top: 14px;
  opacity: .7
}

.erro-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
  text-align: center
}

.erro-page h1 {
  font-family: Oswald;
  font-size: 84px
}

@media (max-width: 900px) {
  .wrap {
    width: 100%
  }

  .forum-bar,
  .topbar,
  .hero,
  .faixa,
  .passos,
  .hero-parl,
  .regua-section,
  .votacoes,
  .hero3,
  .centrais-row,
  .recomendados,
  .cadastro-bar,
  .rodape {
    padding-left: 16px;
    padding-right: 16px
  }

  .forum-bar img {
    height: 64px;
    max-width: 100%
  }

  .topbar {
    align-items: flex-start;
    gap: 16px;
    flex-direction: column
  }

  .nav {
    flex-wrap: wrap;
    gap: 12px;
    max-width: 100%
  }

  .hero:before {
    display: none
  }

  .hero .grid,
  .hero-parl .grid,
  .hero3-cont,
  .cadastro-cont {
    grid-template-columns: 1fr;
    gap: 32px
  }

  .hero h1 {
    font-size: 56px;
    line-height: .92;
    overflow-wrap: normal;
    word-break: normal
  }

  .hero h1 .pergunta {
    font-size: 30px
  }

  .hero h1 .resposta {
    font-size: 23px
  }

  .faixa-cont,
  .passos .grid,
  .regua-resumo,
  .centrais-grid,
  .rec-grid,
  .rodape-grid {
    grid-template-columns: 1fr
  }

  .meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px
  }

  .vot-header {
    display: none
  }

  .vot-row {
    grid-template-columns: minmax(0, 1fr)
  }

  .hero3 h1,
  .cadastro-cont h2 {
    font-size: 48px
  }

  .geo-card,
  .rec-cont,
  .regua-cont,
  .estado-box {
    box-shadow: 5px 5px 0 var(--ink);
    max-width: calc(100vw - 32px)
  }

  .hero {
    padding-top: 48px;
    padding-bottom: 64px
  }

  .hero .grid,
  .faixa-cont,
  .passos .grid,
  .hero-parl .grid,
  .votacoes-cont,
  .hero3-cont,
  .centrais-grid,
  .rec-cont,
  .cadastro-cont,
  .rodape-grid {
    max-width: 100%;
    width: 100%
  }

  .geo-card,
  .rec-cont,
  .regua-cont,
  .estado-box,
  .step,
  .candidato,
  .form-card {
    min-width: 0
  }

  .estado-row,
  .busca-bar,
  .rec-header {
    align-items: stretch;
    flex-direction: column
  }

  .uf-big {
    font-size: 48px
  }

  .estado-select,
  .busca-input {
    min-width: 0
  }

  .filtro-btn {
    width: 100%
  }

  .lista .item {
    gap: 10px;
    align-items: flex-start;
    flex-direction: column
  }

  .foto-box {
    width: 100%;
    max-width: 220px
  }

  .dados h1 {
    font-size: 48px;
    overflow-wrap: anywhere
  }

  .meta-item strong {
    font-size: 18px
  }

  .selo-destaque {
    max-width: calc(100vw - 32px);
    box-shadow: 5px 5px 0 var(--ink)
  }

  .legenda-bloco {
    grid-template-columns: 1fr
  }

  .col-pos,
  .col-vot {
    min-width: 0
  }

  .data {
    text-align: left
  }

  .regua-labels {
    gap: 16px;
    font-size: 10px
  }

  .footer-brand {
    width: 100%;
    /* min-height: 104px; */
    font-size: 28px;
    line-height: 1.55
  }

  .rodape .marca {
    font-size: 28px;
    overflow-wrap: normal;
    word-break: normal
  }
}

@media (max-width: 420px) {
  .hero h1 {
    font-size: 48px
  }

  .hero h1 .pergunta {
    font-size: 27px
  }

  .hero h1 .resposta {
    font-size: 21px
  }
}

@media (max-width: 360px) {
  .hero h1 {
    font-size: 42px
  }

  .hero h1 .pergunta {
    font-size: 24px
  }

  .hero h1 .resposta {
    font-size: 19px
  }
}
