main {
  padding: 15px;
  overflow: visible;
}

.grids {
  overflow-x: auto;
  height: 500px;
}

.grid-container {
  display: grid;
  grid-template-columns: repeat(19, 45px);
  grid-template-rows: repeat(7, 45px);
  gap: 5px;
  margin: 0 0;
}

.secundario {
  grid-template-columns: repeat(14, 45px);
  grid-template-rows: repeat(2, 45px);
  margin-top: 20px;
}

.elemento {
  color: var(--color-contrast);
  border: 1px solid #000;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  padding: 5px;
  transition: transform 0.2s ease-in-out, opacity 0.3s;
  cursor: pointer;
  border-radius: var(--border-radius-padrao);
}

.elemento:hover {
  transform: scale(1.05);
}

.legenda {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 20px;
}

.legenda-item {
  padding: 10px;
  margin: 5px;
  border-radius: 5px;
  color: var(--color-005);
  border: #000 1px solid;
}

body[data-theme="rantool-original"] .legenda-item {
  color: var(--color-007);
}

.metal-alcalino {
  background-color: #baba8655;
}
.metal-alcalinoterroso {
  background-color: #add8e655;
}
.metal-transicao {
  background-color: #98ff9855;
}
.metal-pos-transicao {
  background-color: #e6e6fa55;
}
.semimetal {
  background-color: #ffdab955;
}
.ametal {
  background-color: #e6ccff55;
}
.gas-nobre {
  background-color: #7ba6d155;
}
.lantanideo {
  background-color: #ae8ad155;
}
.actinideo {
  background-color: #d49cd455;
}
.desconhecido {
  background-color: #99999955;
}

.popup {
  max-width: calc(100% - 60px);
  width: 400px;
  position: fixed;
  top: -50vh;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--color-006);
  border: 1px solid var(--color-007);
  padding: 20px;
  border-radius: 10px;
  z-index: 10;
  height: fit-content;
  transition: 0.2s;
}

.popupopen {
  opacity: 1;
  top: 50%;
  transition: 0.2s;
}

.popup h1 {
  text-transform: capitalize;
}

.popup-content {
  position: relative;
  height: fit-content;
}

.fechar {
  position: absolute;
  top: 10px;
  right: 10px;
  cursor: pointer;
  font-size: 40px;
  font-weight: bold;
  color: var(--color-contrast);
}

body[data-theme="rantool-original"] .fechar {
  color: var(--color-001);
}

.text-popup {
  font-weight: 100;
  display: flex;
  padding: 10px;
  text-align: left;
}

@media screen and (max-width: 600px) {
  .elemento {
    font-size: 0.6em;
  }
}
