/* Estilos generales */
body {
  font-family: Arial, sans-serif;
  margin: 0;
  padding: 0;
  text-align: center;
  background-color: rgb(230, 224, 218);
}

h1, h2 {
  margin: 0.5em 0;
  color: #4116f0;
}

/* Contenedor centrado con desplazamiento horizontal */
.table-container {
  width: 100%;
  overflow-x: auto;
  padding: 1rem;
}

/* Tabla con ancho mínimo para evitar colapso */
.table {
  border-collapse: collapse;
  min-width: max-content;
  margin: 0 auto;
}

/* Celdas y encabezados */
.table td, .table th {
  border: 1px solid #ccc;
  padding: 8px 12px;
  white-space: nowrap;
  background-color: #fff;
  text-align: center;
}

.fija-1 {
  position: sticky;
  left: 0;
  background-color: #e0e0e0;
  z-index: 3;
  width: auto; /* ajusta según tu diseño */
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Celdas que acompañan el letrero */
td.semana {
  position: sticky;
  top: 0;
  background-color: #d0f0ff;
  color: #003366;
  font-weight: bold;
  text-align: center;
  z-index: 4;
}

/* Fila fija en la parte superior */
tr.semana td,
tr.semana th {
  position: sticky;
  top: 0;
  background-color: #d0f0ff; /* azul cielo */
  color: #003366; /* azul marino */
  font-weight: bold;
  text-align: left;
  z-index: 4; /* subido para evitar que se esconda detrás de otras celdas */
}

/* Pie de página */
footer {
  margin-top: 2rem;
}

.btn-regresar {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #333;
    color: aqua;
    padding: 10px 20px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

.btn-regresar:hover {
    background-color: #444;
}
