.text-orange {
  color: #ff6600 !important;
}
  main.container {
    max-width: 80% !important;
    min-width: 800px;
    margin-left: auto;
    margin-right: auto;
  }
header {
  background-color: #f5f6fa;
}

header nav a:hover,
header nav a:focus {
  text-decoration: underline;
  color: #ff6600 !important;
}

header img {
  object-fit: cover;
}

header .btn-link {
  font-size: 1.3rem;
}

@media (max-width: 767.98px) {
  header nav {
    display: none; /* Oculta menú en móvil si quieres */
  }
}


/* Botón naranja personalizado */
.btn-orange {
  background-color: #ff6600;
  border-color: #ff6600;
  transition: background-color 0.3s ease;
}

.btn-orange:hover,
.btn-orange:focus {
  background-color: #e65c00;
  border-color: #e65c00;
}

/* Leyenda - cuadrado color o indicador de estado */
.legend-box {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  display: inline-block;
}

#tables-container {
  background-color: #EBECF7;
  border-radius: 12px;
  padding: 2rem 1.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 2.5rem;
  justify-content: start;
  width: 100%;
  margin-top: 2%;
  /* Asegura que el contenido tenga buen espaciado y se parezca a la imagen */
}

/* Mesa base */
.table-card {
  position: relative;
  background: white;
  border-radius: 12px;
  box-shadow: 0 8px 12px rgba(0, 0, 0, 0.05);
  width: 90px;
  height: 90px;
  display: flex;
   flex-direction: column;       /* Apila hijos verticalmente */
  justify-content: center;      /* Centrado vertical */
  align-items: center;          /* Centrado horizontal */
  font-weight: 600;
  font-size: 1rem;
  color: #212529;
  cursor: pointer;
  user-select: none;
  border: 2px solid transparent;
  overflow: visible; /* permitimos que las sillas sobresalgan */
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Mesa grande (cuadrada más grande) */
.table-card.large {
  width: 120px;
  height: 140px;
  font-size: 1.1rem;
}

/* Mesa alargada vertical (tipo T-21) */
.table-card.long-rect {
  width: 120px;
  height: 240px;
  border-radius: 20px;
  font-size: 1.1rem;
}

/* Estados */
.table-card.reservation {
  background-color: #ff3f4d;
  color: white;
  box-shadow: 0 8px 12px rgba(255, 63, 77, 0.4);
}
.table-card.occupied {
  background-color: #227cff;
  color: white;
  box-shadow: 0 8px 12px rgba(34, 124, 255, 0.4);
}
.table-card.billed {
  background-color: #ffdc3f;
  color: #212529;
  box-shadow: 0 8px 12px rgba(255, 220, 63, 0.4);
}
.table-card.selected {
  border-color: #39d353;
  box-shadow: 0 0 12px #39d353;
}

/* Hover */
.table-card:hover {
  border-color: #ff6600;
  box-shadow: 0 0 14px rgba(255, 102, 0, 0.6);
}

/* Silla base: rectángulo pequeño */
.chair {
  position: absolute;
  background: #e6e6e6;
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  transition: background-color 0.3s ease;
}

/* Silla vertical (lados izquierdo y derecho) */
.chair.vertical {
  width: 16px;
  height: 40px;
}

/* Silla horizontal (lados arriba y abajo) */
.chair.horizontal {
  width: 40px;
  height: 16px;
}
/* Mesa Disponible: fondo verde claro con texto oscuro */
.table-card.available {
  background-color: #d1e7dd; /* verde pastel */
  color: #0f5132;
  box-shadow: 0 8px 12px rgba(13, 110, 53, 0.3);
  border: 2px solid #0f5132;
}
/* Mesa Reservada (: distinto rojo para diferenciar de "reservation" si quieres) */
.table-card.reserved {
  background-color: #f8d7da; /* rojo pastel */
  color: #842029;
  box-shadow: 0 8px 12px rgba(114, 28, 36, 0.3);
  border: 2px solid #842029;
}
/* Ajustar tamaño y estilo texto dentro de la mesa */
.table-card > div {
  font-weight: 600;
  font-size: 1rem;
  text-align: center;
}
.table-card > div + div {
  margin-top: 0.25rem; /* espacio entre líneas */
  font-weight: 500;
  font-size: 0.85rem;
  color: #666666; /* texto secundario */
}

w {
  font-size: 0.6rem !important;
  margin-top: 4px;
  font-weight: 500;
  color: #666666;
}

.table-card {
  width: 100%;    /* ocupar todo el ancho de la celda */
  height: 100%;   /* ocupar toda la altura de la fila */
  max-width: 100%;
  max-height: 100%;
}

/* Las mesas grandes y alargadas ocuparán más filas o columnas */

/* Mesa grande (por ejemplo  2 filas de alto) */
.table-card.large {
  grid-row: span 2;
}

/* Mesa alargada (tipo  T-21) ocupando 2 filas */
.table-card.long-rect {
  grid-row: span 2;
}

/* Opcional: si algunas mesas grandes quieres que ocupen más columnas, puedes usar:
.table-card.large {
  grid-column: span 1; 
  grid-row: span 2;
}
*/
/* Posición fija para mesas para que coincidan visualmente */
.table-card[data-seats="1"] { /* T-1 */
  grid-column: 1;
  grid-row: 1;
}
.table-card[data-seats="2"] { /* T-2 */
  grid-column: 1;
  grid-row: 2;
}
.table-card[data-seats="4"] { /* T-5 */
  grid-column: 2;
  grid-row: 1;
}
/* ... Otros según necesites */

#tables-container {
   display: grid;
  grid-template-columns: repeat(7, 1fr); /* 7 columnas en desktop */
  grid-auto-rows: 130px;                 /* altura consistente filas */
  gap: 20px 25px;
  background-color: #EBECF7;
  padding: 2rem 1.5rem;
  border-radius: 12px;
  width: 100%;
}

/* Ajuste filas para mesas grandes y largas */
.table-card.large {
  grid-row: span 2;
}
.table-card.long-rect {
  grid-row: span 2;
}

/* Ocupa más columnas si quieres en desktop (opcional) */
/* Ejemplo si deseas que mesa alargada ocupe 2 columnas */
/*
.table-card.long-rect {
  grid-column: span 2;
}
*/
.status-text {
  font-size: 0.65rem;    /* Texto un poco más pequeño */
  margin-top: 0.25rem;   /* Espacio arriba */
  font-weight: 600;
  color: #842029;        /* Color rojo oscuro para reservado */
  text-align: center;
  line-height: 1.1;
  user-select: none;
}


/* Mesas ocupe todo el espacio de la celda */
.table-card {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
}

/* --- Responsive --- */

/* En tablets (768px - 991px) */
@media (max-width: 991.98px) {
  #tables-container {
    grid-template-columns: repeat(5, 1fr); /* 5 columnas */
    grid-auto-rows: 110px;
    gap: 15px 20px;
    padding: 1.5rem 1rem;
  }
}

/* En móviles grandes (576px - 767px) */
@media (max-width: 767.98px) {
  #tables-container {
    grid-template-columns: repeat(3, 1fr); /* 3 columnas */
    grid-auto-rows: 100px;
    gap: 15px 15px;
     padding: 1rem;
  }
  .table-card.large,
  .table-card.long-rect {
    grid-row: span 1; /* para evitar que mesas grandes sobresalgan */
     height: 100px !important;
  }
}

/* En móviles pequeños (<576px) */
@media (max-width: 575.98px) {
  #tables-container {
    grid-template-columns: repeat(1, 1fr); /* 1 columna */
    grid-auto-rows: 100px;
    gap: 10px 10px;
    padding: 0.8rem 1rem;
  }
  .table-card.large,
  .table-card.long-rect {
    grid-row: span 1; /* mesas grandes en 1 fila */
    height: 90px !important;

  }
}
