* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
}

a { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ===== Botones ===== */
.boton {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-2);
  min-height: 44px;
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: background var(--t-fast), filter var(--t-fast);
}
.boton--primario { background: var(--color-primary); color: #fff; }
.boton--primario:hover { background: var(--color-primary-hover); text-decoration: none; }
.boton--neutro {
  background: var(--color-surface-2);
  color: var(--color-text);
  border-color: var(--color-border);
}
.boton--bloque { width: 100%; }

/* ===== Campos de formulario ===== */
.campo { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-4); }
.campo__etiqueta { font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .06em; color: var(--color-text-soft); }
.campo__entrada {
  min-height: 44px;
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--fs-base);
}
.campo__entrada:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 1px; }

/* ===== Login ===== */
.login {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: var(--sp-4);
  background: var(--color-surface);
}
.login__tarjeta {
  width: 100%; max-width: 380px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--sp-6);
}
.login__titulo { margin: 0 0 var(--sp-1); font-size: var(--fs-2xl); font-family: var(--font-display); }
.login__sub { margin: 0 0 var(--sp-5); color: var(--color-text-soft); font-size: var(--fs-sm); }
.login__error {
  margin-bottom: var(--sp-4); padding: var(--sp-2) var(--sp-3);
  background: var(--color-ocupado-soft); color: var(--color-ocupado);
  border-radius: var(--radius-md); font-size: var(--fs-sm);
}

/* ===== Estructura de la app ===== */
.app { min-height: 100vh; display: flex; flex-direction: column; }
.barra {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-3) var(--sp-5);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.barra__marca { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-lg); }
.barra__derecha { display: flex; align-items: center; gap: var(--sp-4); }
.barra__usuario { font-size: var(--fs-sm); color: var(--color-text-soft); }
.contenido { flex: 1; padding: var(--sp-6); max-width: 1100px; width: 100%; margin: 0 auto; }

.titulo-seccion { font-family: var(--font-display); font-size: var(--fs-xl); margin: 0 0 var(--sp-4); }

/* ===== Tarjetas ===== */
.tarjeta {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.rejilla-tarjetas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--sp-4);
}

/* ===== Badges de estado ===== */
.badge {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-full);
  font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  text-transform: uppercase; letter-spacing: .04em;
}
.badge--rol { background: var(--color-primary-soft); color: var(--color-primary); }
.badge--disponible { background: var(--color-disponible-soft); color: var(--color-disponible); }
.badge--ocupado    { background: var(--color-ocupado-soft);    color: var(--color-ocupado); }
.badge--pendiente  { background: var(--color-atencion-soft);   color: var(--color-atencion); }
.badge--en-juego   { background: var(--color-info-soft);       color: var(--color-info); }

/* ===== Selector de club ===== */
.selector-club { display: flex; align-items: center; gap: var(--sp-2); }
.selector-club select {
  min-height: 40px; padding: var(--sp-1) var(--sp-3);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg); color: var(--color-text); font-size: var(--fs-sm);
}

@media (max-width: 640px) {
  .contenido { padding: var(--sp-4); }
  .barra { padding: var(--sp-3) var(--sp-4); }
}

/* ===== Configuración (área admin) ===== */
.rejilla-config {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--sp-5);
}
.config__titulo { margin: 0 0 var(--sp-4); font-size: var(--fs-lg); font-family: var(--font-display); }
.lista { list-style: none; margin: 0 0 var(--sp-4); padding: 0; }
.lista__fila {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--color-border);
}
.lista__nombre { font-weight: var(--fw-medium); }
.lista__meta { color: var(--color-text-mute); font-weight: var(--fw-regular); font-size: var(--fs-sm); }
.lista__acciones { display: inline-flex; align-items: center; gap: var(--sp-2); }
.boton--mini { min-height: 32px; padding: var(--sp-1) var(--sp-3); font-size: var(--fs-xs); }
.form-linea { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.form-linea .campo__entrada { flex: 1; min-width: 120px; }
.vacio { color: var(--color-text-mute); font-size: var(--fs-sm); margin: 0 0 var(--sp-4); }

/* ===== Pestañas de configuración ===== */
.pestanas { display: flex; gap: var(--sp-1); border-bottom: 1px solid var(--color-border); margin-bottom: var(--sp-5); }
.pestana {
  background: transparent; border: none; cursor: pointer;
  padding: var(--sp-3) var(--sp-4);
  color: var(--color-text-soft);
  font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .06em;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.pestana:hover { color: var(--color-text); }
.pestana--activa { color: var(--color-primary); border-bottom-color: var(--color-primary); }

/* ===== Formularios de configuración ===== */
.tarjeta--form { max-width: 560px; }
.rejilla-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.campo-check { display: flex; align-items: center; gap: var(--sp-2); margin: var(--sp-2) 0 var(--sp-4); font-size: var(--fs-sm); color: var(--color-text-soft); cursor: pointer; }
.form-acciones { display: flex; justify-content: flex-end; }
.aviso-ok {
  background: var(--color-disponible-soft); color: var(--color-disponible);
  border: 1px solid var(--color-disponible);
  padding: var(--sp-2) var(--sp-3); border-radius: var(--radius-md);
  font-size: var(--fs-sm); margin-bottom: var(--sp-4);
}
@media (max-width: 560px) { .rejilla-2 { grid-template-columns: 1fr; } }

/* ============================================================
   Cuadrante del club — pantalla completa (Nexion)
   Menú lateral fino + rejilla pistas×franjas ocupando el resto
   ============================================================ */
.cuadrante-app {
  display: flex;
  height: 100vh;
  overflow: hidden;
  background: var(--color-bg);
  color: var(--color-text);
}

/* ===== Menú lateral ===== */
.lateral {
  width: 208px;
  flex: 0 0 208px;
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
}
.lateral__marca {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-lg);
  padding: var(--sp-4) var(--sp-4) var(--sp-3);
  border-bottom: 1px solid var(--color-border);
}
.lateral__menu { padding: var(--sp-3) var(--sp-2); display: flex; flex-direction: column; gap: 2px; }
.lateral__pie {
  margin-top: auto;
  padding: var(--sp-3) var(--sp-2);
  border-top: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: var(--sp-1);
}
.lateral__club { font-size: var(--fs-sm); font-weight: var(--fw-medium); padding: 0 var(--sp-2); }
.lateral__persona { font-size: var(--fs-xs); color: var(--color-text-soft); padding: 0 var(--sp-2) var(--sp-2); }
.selector-club-lat select {
  width: 100%; background: var(--color-surface-2); color: var(--color-text);
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  padding: var(--sp-1) var(--sp-2); font-size: var(--fs-sm); margin-bottom: var(--sp-1);
}

.menu-item {
  display: block; text-decoration: none;
  color: var(--color-text-soft);
  font-family: var(--font-mono); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .06em;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--radius-sm);
  transition: background var(--t-fast), color var(--t-fast);
}
.menu-item:hover { background: var(--color-surface-2); color: var(--color-text); }
.menu-item--activo { background: var(--color-primary-soft); color: var(--color-primary-hover); }
.menu-item--inerte { opacity: .45; cursor: default; }
.menu-item--inerte:hover { background: transparent; color: var(--color-text-soft); }
.menu-item--pie { padding: var(--sp-2) var(--sp-2); }

/* ===== Columna principal ===== */
.principal { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-2) var(--sp-4);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
}
.nav-dia { display: flex; align-items: center; gap: var(--sp-2); }
.nav-dia__flecha {
  text-decoration: none; color: var(--color-text);
  background: var(--color-surface-2); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: var(--fs-lg); line-height: 1;
}
.nav-dia__flecha:hover { border-color: var(--color-primary); color: var(--color-primary-hover); }
.nav-dia__fecha { font-family: var(--font-mono); font-size: var(--fs-sm); min-width: 92px; text-align: center; }
.nav-dia__hoy {
  text-decoration: none; font-family: var(--font-mono); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--color-primary-hover); padding: var(--sp-1) var(--sp-2);
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
}

.botones-puntuales { display: flex; gap: var(--sp-2); }
.boton-pico {
  background: var(--color-surface-2); color: var(--color-text-soft);
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .06em; cursor: pointer;
}
.boton-pico:hover { border-color: var(--color-primary); color: var(--color-text); }

/* ===== Área de rejilla ===== */
.area-rejilla { flex: 1; overflow: auto; padding: var(--sp-3); }
.aviso-rejilla {
  margin: var(--sp-6) auto; max-width: 520px; text-align: center;
  color: var(--color-text-soft); font-size: var(--fs-sm);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--sp-5);
}
.aviso-rejilla a { color: var(--color-primary-hover); margin-left: var(--sp-2); }

/* La rejilla en sí: una cuadrícula CSS. Cabeceras sticky arriba, horas sticky a la izquierda. */
.rejilla {
  display: grid;
  gap: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-width: max-content;
}
.rejilla__esquina {
  position: sticky; top: 0; left: 0; z-index: 3;
  background: var(--color-surface-2);
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.rejilla__cabecera {
  position: sticky; top: 0; z-index: 2;
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border-2);
  padding: var(--sp-2) var(--sp-3);
  font-family: var(--font-mono); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .05em;
  text-align: center; white-space: nowrap;
}
.rejilla__hora {
  position: sticky; left: 0; z-index: 1;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  border-top: 1px solid var(--color-border-2);
  padding: 0 var(--sp-2);
  font-family: var(--font-mono); font-size: 0.66rem; color: var(--color-text-mute);
  display: flex; align-items: center; justify-content: flex-end;
  height: 26px;
}
.rejilla__hora--punto { color: var(--color-text-soft); border-top-color: var(--color-border); }
.rejilla__celda {
  border-top: 1px solid var(--color-border-2);
  border-right: 1px solid var(--color-border-2);
  height: 26px;
  transition: background var(--t-fast);
}
.rejilla__celda--punto { border-top-color: var(--color-border); }
.rejilla__celda:hover { background: var(--color-primary-soft); cursor: pointer; }
