/* =============================================================================
   public/css/station-parameters-popup.css — Popup de parámetros de estación
   F2R Engineering

   Diseño paralelo al recipes popup (.prm-*) pero más compacto: sin sidebar
   de slots. Sólo design tokens — funciona en light y dark sin overrides.
   ============================================================================= */

/* ── OVERLAY ────────────────────────────────────────────────────────────── */
.spp-popup-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  z-index: var(--z-overlay);
  animation: spp-fade-in var(--transition-base);
}
body.light-mode .spp-popup-overlay { background: rgba(15, 23, 42, 0.4); }
@keyframes spp-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* ── CONTAINER ──────────────────────────────────────────────────────────── */
.spp-popup {
  /* inset+margin:auto centra en el área disponible bajo el header global
   * en lugar de contra el viewport entero — evita solape con el header
   * en pantallas pequeñas o con font-scale alto. */
  position: fixed;
  inset: 90px 30px 30px 30px;
  margin: auto;
  width:      min(900px, calc(100vw - 60px));
  max-width:  min(900px, calc(100vw - 60px));
  max-height: calc(100vh - 120px);
  background: var(--surface-raised);
  border: 1px solid var(--border-base);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  z-index: calc(var(--z-overlay) + 1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: spp-pop-in 0.25s cubic-bezier(0.34, 1.4, 0.64, 1);
}
@keyframes spp-pop-in {
  from { transform: scale(0.92); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}

/* ── HEADER ─────────────────────────────────────────────────────────────── */
.spp-popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  background: var(--surface-overlay);
  border-bottom: 1px solid var(--border-base);
}
.spp-popup-title-block {
  display: flex; flex-direction: column; gap: 2px;
}
.spp-popup-title-lbl {
  font-size: var(--fs-sm);
  letter-spacing: 1.5px;
  color: var(--text-muted);
  text-transform: uppercase;
  font-weight: var(--fw-medium);
}
.spp-popup-title-station {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
}
.spp-popup-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.spp-popup-close {
  background: transparent;
  border: 1px solid var(--border-base);
  color: var(--text-secondary);
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-base), color var(--transition-base);
}
.spp-popup-close:hover { background: var(--surface-elevated); color: var(--text-primary); }

/* ── BODY + TABLE ───────────────────────────────────────────────────────── */
.spp-popup-body {
  padding: var(--space-4) var(--space-5) var(--space-5);
  overflow: auto;
}
.spp-table-wrapper {
  background: var(--surface-base);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.spp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  color: var(--text-primary);
}
.spp-table thead th {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  text-align: left;
  font-weight: var(--fw-medium);
  padding: var(--space-2) var(--space-3);
  background: var(--surface-overlay);
  border-bottom: 1px solid var(--border-subtle);
}
.spp-table tbody td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: middle;
}
.spp-table tbody tr:last-child td { border-bottom: none; }
.spp-table tbody tr:hover { background: var(--surface-overlay); }

.spp-cell-label   { color: var(--text-primary); font-weight: var(--fw-medium); }
/* `display: flex` sobre un <td> rompe las semánticas de table-cell —
   en concreto `vertical-align: middle` deja de aplicarse y el row
   height ya no se propaga al cell. Eso provocaba que el valor + rango
   quedaran arriba mientras el label y el input numérico (en celdas
   vecinas table-cell) se centraban verticalmente — una desalineación
   de media línea visible en todas las filas (peor en BOOL).
   Mantenemos el td como table-cell normal y apilamos value+range con
   `display: block` en sus hijos. */
.spp-cell-actual  {
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  line-height: 1.4;
}
.spp-cell-value   {
  display: block;
  color: var(--text-primary);
  font-weight: var(--fw-medium);
}
.spp-cell-range   {
  display: block;
  margin-top: 2px;
  font-size: var(--fs-xs);
  color: var(--text-muted);
  letter-spacing: 0.5px;
  font-family: var(--font-tech);
}
.spp-cell-actual.is-out-of-range .spp-cell-value {
  color: var(--color-danger-strong, var(--color-danger));
}
.spp-cell-actual.is-out-of-range .spp-cell-range {
  color: var(--color-danger);
}
.spp-table tbody tr.is-out-of-range {
  background: var(--color-danger-soft);
}
.spp-edit-input.is-out-of-range {
  border-color: var(--color-danger);
  background: var(--color-danger-soft);
}
.spp-col-edit     { width: 220px; }
/* La columna "Valor nuevo" sólo tiene sentido en modo edición.
   Cuando la tabla no tiene .is-editing, ocultamos th y tds
   marcadas con .spp-col-edit y la columna colapsa entera. */
.spp-table:not(.is-editing) .spp-col-edit { display: none; }

.spp-table-msg,
.spp-table-error {
  padding: var(--space-5) var(--space-4) !important;
  text-align: center;
  color: var(--text-muted);
}
.spp-table-error { color: var(--color-danger); }

/* ── EDIT INPUTS ────────────────────────────────────────────────────────── */
.spp-edit-input,
.spp-edit-checkbox {
  font-family: var(--font-tech);
}
.spp-edit-input {
  width: 100%;
  background: var(--surface-overlay);
  border: 1px solid var(--border-base);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  color: var(--text-primary);
  font-size: var(--fs-sm);
  transition: border-color var(--transition-base), background var(--transition-base);
}
.spp-edit-input:focus { outline: none; border-color: var(--accent); }
.spp-edit-input.is-saving { border-color: var(--color-warning); }
.spp-edit-input.is-saved  {
  border-color: var(--color-success);
  background: var(--color-success-soft);
}
.spp-edit-input.is-error  {
  border-color: var(--color-danger);
  background: var(--color-danger-soft);
}
.spp-edit-checkbox {
  width: 18px; height: 18px;
  accent-color: var(--accent);
}
.spp-readonly { color: var(--text-muted); font-style: italic; }

/* ── EDIT FOOTER (warning + accept) ─────────────────────────────────────── */
.spp-edit-footer {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-warning-soft);
  border: 1px solid var(--color-warning);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.spp-edit-footer.hidden { display: none; }
.spp-edit-warning {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--text-primary);
  flex: 1 1 auto;
}

/* ── BOTONES ────────────────────────────────────────────────────────────── */
.spp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-base);
  background: var(--surface-overlay);
  color: var(--text-primary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: background var(--transition-base), border-color var(--transition-base), transform var(--transition-base);
}
.spp-btn:hover  { background: var(--surface-elevated); }
.spp-btn:active { transform: scale(0.97); }
.spp-btn[disabled] { opacity: 0.5; cursor: not-allowed; }
/* `.is-blocked` simula `disabled` (atenuado + cursor no-permitido) pero
   deja al botón clickable. Necesario para que el click llegue a
   toggleEditMode y muestre el toast "edición no permitida" cuando
   Cond_Edit es FALSE — un botón realmente `disabled` no dispara eventos. */
.spp-btn.is-blocked { opacity: 0.5; cursor: not-allowed; }
.spp-btn.spp-btn-warning {
  border-color: var(--color-warning-soft);
  color: var(--color-warning);
}
.spp-btn.spp-btn-warning:hover {
  background: var(--color-warning-soft);
  border-color: var(--color-warning);
}
.spp-btn.spp-btn-secondary {
  border-color: var(--border-strong);
  color: var(--text-secondary);
}
.spp-btn.spp-btn-success {
  border-color: var(--color-success-soft);
  color: var(--color-success-strong, var(--color-success));
}
.spp-btn.spp-btn-success:hover {
  background: var(--color-success-soft);
  border-color: var(--color-success);
}

/* ── BOTÓN EN EL PANEL DE PRODUCCIÓN ────────────────────────────────────── */
.prod-station-params-panel { /* hereda layout del .panel base */ }
.prod-station-params-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--surface-overlay);
  border: 1px solid var(--border-base);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--text-primary);
  text-align: left;
  transition: background var(--transition-base), border-color var(--transition-base);
}
.prod-station-params-btn:hover {
  background: var(--surface-elevated);
  border-color: var(--accent);
}
.prod-station-params-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: var(--radius-sm);
  background: var(--surface-base);
  color: var(--accent);
}
.prod-station-params-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.prod-station-params-label {
  font-size: var(--fs-xs);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: var(--fw-medium);
}
.prod-station-params-cta {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  letter-spacing: 0.5px;
  color: var(--accent);
}
.prod-station-params-meta {
  font-size: var(--fs-xs);
  color: var(--text-muted);
}
