.layout-armario {
    padding-top: 15px;
    grid-template-columns: repeat(4, 1fr);
}

/* TOPO */
.top-bar {
  margin-bottom: 20px;
}

.select-armario {
  height: 50px;
  font-size: 20px;
  border-radius: 10px;
  padding: 5px 15px;
}

/* TABS DE PLACAS */
.placas-tabs {
  display: flex;
  gap: 15px;
  margin-bottom: 25px;
}

.tab-placa {
  flex: 1;
  text-align: center;
  padding: 15px;
  font-size: 20px;
  border-radius: 12px;
  background: #333;
  color: white;
  text-decoration: none;
}

.tab-placa.ativa {
  background: #0d6efd;
}

#grid-portas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 18px;
  padding: 10px 5px;
}

.card-porta {
  border: none;
  border-radius: 16px;
  padding: 18px 12px;
  min-height: 110px;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  font-size: 18px;
  color: white;
  text-align: center;

  transition: transform 0.08s ease;
}

.card-porta:active {
  transform: scale(0.96);
}

.card-porta .numero {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 6px;
}

.card-porta .status {
  font-size: 16px;
  opacity: 0.9;
}

/* ENUM COLORS */

.card-porta.livre {
  background-color: #14532d;
}

.card-porta.ocupada {
  background-color: #7f1d1d;
}

.card-porta.bloqueada {
  background-color: #78350f;
}

.card-porta.manutencao {
  background-color: #1e3a8a;
}

.card-porta.sensor-aberto {
  box-shadow: 0 0 10px 3px yellow;
}