body {
  font-family: Calibri, sans-serif;
  margin: 20px;
  background-color: #fdfcf9;
  color: #333;
}

h1 {
  text-align: center;
  color: #805300;
}

.responsive-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

table {
  border-collapse: collapse;
  width: 100%;
  min-width: 800px;
}

th,
td {
  border: 1px solid #c9b27c;
  padding: 8px;
  text-align: left;
  vertical-align: top;
}

thead th {
  background-color: #cd9c25;
  color: #3b2e00;
  position: sticky;
  top: 0;
  z-index: 2;
}

.categoria-1,
.categoria-3,
.categoria-5 {
  background-color: #fff2cc;
}

.categoria-2,
.categoria-4,
.categoria-6 {
  background-color: #ffffff;
}

.legend {
  margin: 20px 0;
  padding: 10px;
  border: 1px solid #d6c798;
  background-color: #fffbe6;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  overflow-x: auto;
}

.legend table {
  width: 100%;
  border-collapse: collapse;
}

.legend th,
.legend td {
  border: 1px solid #c9b27c;
  padding: 8px;
}

.legend thead th {
  position: sticky;
  top: 0;
  background-color: #e3c78b;
  z-index: 1;
}

.scrollable-table-wrapper {
  max-height: 80vh;
  overflow-y: auto;
  position: relative;
  border: 1px solid #d6c798;
}

.scrollable-table-wrapper table {
  margin: 0;
}
