/*
 * =====================================================================
 *  CONVENCION RESPONSIVE  (introducida en Fase B del plan responsive)
 *  -----------------------------------------------------------------
 *  Breakpoints unificados:
 *    movil       :  @media (max-width:  767.98px)   [--bp-md - 0.02]
 *    tablet vert :  @media (min-width:  768px) and (max-width: 1023.98px)
 *    >=tablet h. :  @media (min-width: 1024px)
 *    desktop     :  @media (min-width: 1280px)
 *  Reglas nuevas: usar SIEMPRE estos cortes. No anadir mas breakpoints.
 *  Las reglas viejas con 420/480/560/640/700/720/760/900/920/960/1100
 *  se mantienen por compatibilidad y se migran de forma incremental.
 * =====================================================================
 */
:root {
  --bg: #f5f7fa;
  --card: #ffffff;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --text: #0f172a;
  --text-2: #334155;
  --muted: #64748b;
  --accent: #2563eb;
  --accent-h: #1d4ed8;
  --accent-soft: #eff6ff;
  --green: #059669;
  --orange: #ea580c;
  --error: #b91c1c;
  --amber: #b45309;
  --topbar-bg: #1e293b;
  --topbar-bg-2: #0f172a;
  --topbar-text: #f8fafc;
  --topbar-text-muted: #94a3b8;
  --radius: 8px;
  --radius-sm: 6px;
  --shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-strong: 0 4px 12px rgba(15, 23, 42, 0.1);
  --sidebar-w: 240px;
  --topbar-h: 60px;
  --input-border: #cbd5e1;
  /* Sistema de breakpoints (informativo: CSS no permite usar var() en @media,
     pero los listo para que cualquier futura herramienta o calculo los use) */
  --bp-sm: 480px;
  --bp-md: 768px;
  --bp-lg: 1024px;
  --bp-xl: 1280px;
  /* Escala tipografica */
  --fs-xs: 0.75rem;   /* 12px */
  --fs-sm: 0.875rem;  /* 14px */
  --fs-md: 1rem;      /* 16px - evita zoom iOS en inputs */
  --fs-lg: 1.125rem;  /* 18px */
  --fs-xl: 1.25rem;   /* 20px */
  /* Espaciado */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  /* Touch target minimo recomendado por WCAG */
  --touch-min: 44px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", "Segoe UI", system-ui, sans-serif;
  font-size: 14px;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#app {
  min-height: 100vh;
}

/* Evitar login + app visibles a la vez: .shell { display:flex } puede ganar al atributo hidden */
.shell[hidden],
#shell[hidden] {
  display: none !important;
}

#login-panel[hidden] {
  display: none !important;
}

/* Estado de sesión (refuerzo ante cualquier conflicto CSS / navegador) */
#app:not(.is-authenticated) #shell {
  display: none !important;
}

#app.is-authenticated #login-panel {
  display: none !important;
}

#app:not(.is-authenticated) {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 48px 16px 24px;
  box-sizing: border-box;
}

#app.is-authenticated {
  display: block;
}

.card {
  background: var(--card);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

.panel-header h2,
.panel-header h3 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}

.panel-header .panel-header-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.small {
  font-size: 0.82rem;
}

.muted {
  color: var(--muted);
}

.login-card {
  max-width: 420px;
  margin: 72px auto;
  padding: 32px;
}

.app-logo {
  display: block;
  height: auto;
  object-fit: contain;
}

.app-logo--login {
  width: min(280px, 92%);
  max-height: 128px;
  margin: 0 auto 22px;
}

.login-card h1 {
  margin: 0 0 8px;
  font-size: 1.55rem;
  text-align: center;
}

.login-card > .muted {
  text-align: center;
}

.login-subtitle {
  text-align: center;
  margin: 0 0 4px;
  opacity: 0.75;
}

/* V2.2 — Evitar que la card quede cortada en pantallas bajas (móvil landscape, tablets) */
@media (max-height: 700px) {
  .login-card {
    margin-top: 20px;
    margin-bottom: 20px;
  }
}

.login-card form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 20px;
}

label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-2);
}

input[type="text"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="date"],
input[type="email"],
select,
textarea {
  padding: 7px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--input-border);
  font-size: 0.875rem;
  font-family: inherit;
  color: var(--text);
  background: #fff;
  transition: border-color 0.12s ease, box-shadow 0.12s ease;
}

input:hover:not(:focus):not(:disabled),
select:hover:not(:focus),
textarea:hover:not(:focus) {
  border-color: var(--border-strong);
}

/* V1.1 — Focus visible accesible en todos los campos y botones */
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-color: var(--accent);
}

button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

textarea {
  min-height: 88px;
  resize: vertical;
}

.btn {
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.86rem;
  font-family: inherit;
  line-height: 1.3;
  transition: background 0.12s ease, border-color 0.12s ease, color 0.12s ease, box-shadow 0.12s ease;
}

.btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: white;
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.18);
}

.btn.primary:hover {
  background: var(--accent-h);
  border-color: var(--accent-h);
}

.btn.ghost {
  background: #fff;
  border: 1px solid var(--border-strong);
  color: var(--text-2);
}

.btn.ghost:hover {
  background: #f8fafc;
  border-color: var(--accent);
  color: var(--accent-h);
}

.btn.danger {
  background: #fff;
  color: var(--error);
  border: 1px solid #fecaca;
}

.btn.danger:hover {
  background: #fef2f2;
  border-color: #f87171;
}

.btn.full {
  width: 100%;
  margin-top: 12px;
}

.btn-sm {
  padding: 5px 10px;
  font-size: 0.78rem;
  border-radius: 6px;
}

.btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.error {
  color: var(--error);
  font-size: 0.9rem;
  margin-top: 12px;
}

.ok-msg {
  color: var(--green);
  font-size: 0.88rem;
}

.shell-main:has(.kitchen-layout--cook) {
  padding-bottom: 12px;
}

/* ── Shell ERP ─────────────────────────────────────────────────────────── */
.shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.shell-body {
  display: flex;
  flex: 1;
  min-height: 0;
}

/* Topbar oscuro full-width */
.app-topbar {
  height: var(--topbar-h);
  background: linear-gradient(180deg, var(--topbar-bg) 0%, var(--topbar-bg-2) 100%);
  color: var(--topbar-text);
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.25);
}

.app-logo-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  background: #ffffff;
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
  flex-shrink: 0;
}

.app-logo--topbar {
  display: block;
  height: 40px;
  width: auto;
  max-width: 130px;
}

.app-topbar-brand {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  padding-right: 14px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.app-topbar-brand strong {
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--topbar-text);
}

.app-topbar-brand-sub {
  font-size: 0.7rem;
  color: var(--topbar-text-muted);
  letter-spacing: 0.02em;
}

.app-topbar-view {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  min-width: 0;
  flex: 1;
}

.app-topbar-view h1 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--topbar-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topbar-sub {
  margin: 2px 0 0;
  font-size: 0.74rem;
  color: var(--topbar-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-topbar-user {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
}

.user-chip {
  display: inline-block;
  font-size: 0.82rem;
  line-height: 1.2;
  max-width: 160px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--topbar-text);
}

.user-chip:empty {
  display: none;
}

.topbar-icon-btn {
  width: 36px;
  height: 36px;
  border-radius: 6px;
  background: transparent;
  color: var(--topbar-text);
  border: 1px solid transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.topbar-icon-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
}

.topbar-icon-btn:focus-visible {
  outline: 2px solid #93c5fd;
  outline-offset: 2px;
}

.sidebar-toggle-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
}

.sidebar-toggle-icon svg {
  display: block;
}

/* Sidebar plano */
.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: #ffffff;
  border-right: 1px solid var(--border);
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  /* Sticky bajo el topbar: la sidebar no se mueve al hacer scroll del contenido principal. */
  position: sticky;
  top: var(--topbar-h);
  align-self: flex-start;
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto;
  transition:
    width 0.22s ease,
    padding 0.22s ease,
    opacity 0.18s ease,
    border-right-color 0.22s ease;
}

.shell.sidebar-collapsed .sidebar {
  width: 0;
  min-width: 0;
  padding-left: 0;
  padding-right: 0;
  border-right-color: transparent;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .sidebar {
    transition: none;
  }
}

.nav-modules {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1px;
  flex: 1;
  min-height: 0;
  padding-top: 2px;
}

.nav-section-label {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #94a3b8;
  text-transform: uppercase;
  margin: 12px 0 4px;
  padding: 0 10px;
  border-bottom: none;
  width: 100%;
}

.nav-section-label:first-child {
  margin-top: 2px;
}

.nav-spacer {
  flex: 1 1 auto;
  min-height: 8px;
}

.module-inner-tabs {
  margin-bottom: 12px;
}

.nav-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  box-sizing: border-box;
  text-align: left;
  padding: 8px 10px;
  border-radius: 6px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--text-2);
  flex-shrink: 0;
  position: relative;
  transition:
    background 0.12s ease,
    color 0.12s ease;
}

.nav-btn-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: #94a3b8;
  display: flex;
  align-items: center;
  justify-content: center;
}

.nav-btn-icon svg {
  display: block;
  width: 18px;
  height: 18px;
}

.nav-btn-text {
  flex: 1;
  min-width: 0;
}

.nav-btn:hover {
  background: #f1f5f9;
  color: var(--text);
}

.nav-btn:hover .nav-btn-icon {
  color: var(--accent);
}

.nav-btn.active {
  background: var(--accent-soft);
  color: var(--accent-h);
  font-weight: 600;
}

.nav-btn.active::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 3px;
  background: var(--accent);
  border-radius: 0 2px 2px 0;
}

.nav-btn.active .nav-btn-icon {
  color: var(--accent);
}

.nav-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.shell-main {
  flex: 1;
  padding: 18px 22px 36px;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.view-root {
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  min-height: 0;
}

/* ── Hoteles (layout escritorio) ───────────────────────────────────────── */

.hotels-split {
  display: grid;
  grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

@media (max-width: 920px) {
  .hotels-split {
    grid-template-columns: 1fr;
  }
}

.hotels-list-panel {
  padding: 14px;
}

.hotels-toolbar {
  margin-bottom: 10px;
}

.hotel-search-input {
  flex: 1;
  min-width: 0;
}

.filter-select {
  min-width: 140px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--input-border);
  font-size: 0.84rem;
  background: #fff;
  color: var(--text);
}

/* Estados de evento — badge + borde identificativo */
.event-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.2;
  padding: 4px 10px 4px 8px;
  border-radius: 999px;
  border: 1px solid transparent;
  white-space: nowrap;
}

.event-status::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: currentColor;
  opacity: 0.85;
}

.event-status--xs {
  font-size: 0.68rem;
  padding: 2px 8px 2px 6px;
  gap: 4px;
}

.event-status--xs::before {
  width: 6px;
  height: 6px;
}

.event-list-card .event-status {
  margin-top: 6px;
}

.event-status--planificado {
  background: #eef2ff;
  color: #4338ca;
  border-color: #a5b4fc;
}
.event-status--planificado::before {
  background: #6366f1;
}

.event-status--confirmado,
.event-status--en_curso,
.event-status--en_produccion {
  background: #fffbeb;
  color: #b45309;
  border-color: #fcd34d;
}
.event-status--confirmado::before,
.event-status--en_curso::before,
.event-status--en_produccion::before {
  background: #f59e0b;
}

.event-status--finalizado {
  background: #ecfdf5;
  color: #047857;
  border-color: #6ee7b7;
}
.event-status--finalizado::before {
  background: #10b981;
}

.event-status--cancelado {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fca5a5;
}
.event-status--cancelado::before {
  background: #ef4444;
}

/* V1.5 — Transición suave en tarjetas de lista */
.event-list-card {
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.event-list-card:not(.selected):hover {
  background: #f8fafc;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.07);
}

/* Tarjetas de lista: franja lateral por estado */
.event-list-card.event-card-status--planificado {
  border-left: 4px solid #6366f1;
}
.event-list-card.event-card-status--en_produccion,
.event-list-card.event-card-status--confirmado,
.event-list-card.event-card-status--en_curso {
  border-left: 4px solid #f59e0b;
}
.event-list-card.event-card-status--finalizado {
  border-left: 4px solid #10b981;
}
.event-list-card.event-card-status--cancelado {
  border-left: 4px solid #ef4444;
}

.event-status-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 10px 4px;
  border-bottom: 1px solid var(--border);
}

/* Calendario anual de eventos */
.eventos-calendario-root {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.event-cal-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px 20px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

.event-cal-year-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 120px;
}

.event-cal-year-select {
  font-size: 1rem;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
}

.event-cal-legend {
  border-bottom: none;
  padding: 0;
}

.event-cal-year-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}

.event-cal-month {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 10px 10px 12px;
  min-width: 0;
}

.event-cal-month-title {
  margin: 0 0 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #1e3a5f;
  text-align: center;
}

.event-cal-month-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 0.7rem;
}

.event-cal-month-table th {
  padding: 4px 2px;
  text-align: center;
  font-weight: 600;
  color: #64748b;
  border-bottom: 1px solid #e2e8f0;
}

.event-cal-day {
  vertical-align: top;
  height: 52px;
  padding: 2px;
  border: 1px solid #f1f5f9;
  background: #fafbfc;
}

.event-cal-day--empty {
  background: #f8fafc;
  border-color: transparent;
}

.event-cal-day--today {
  background: #eff6ff;
  box-shadow: inset 0 0 0 2px #3b82f6;
}

.event-cal-day--has-events {
  background: #fff;
}

.event-cal-day-num {
  display: block;
  font-size: 0.65rem;
  font-weight: 600;
  color: #64748b;
  line-height: 1.2;
}

.event-cal-day-events {
  max-height: 3.6rem;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 2px;
}

.event-cal-event {
  display: block;
  width: 100%;
  text-align: left;
  padding: 2px 4px;
  font-size: 0.68rem;
  line-height: 1.2;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  color: #fff;
  background: var(--ev-cal-color, #64748b);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.event-cal-more {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  color: #475569;
  text-align: center;
  padding: 1px 2px;
  line-height: 1.2;
}

.event-cal-event:hover {
  filter: brightness(0.92);
}

.event-cal-sin-fecha {
  padding: 12px 14px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

.event-cal-sin-fecha-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.event-cal-event--list {
  width: auto;
  max-width: 280px;
  padding: 4px 10px;
  font-size: 0.8rem;
}

@media (max-width: 720px) {
  .event-cal-year-grid {
    grid-template-columns: 1fr;
  }
}

.event-status-select-wrap {
  border-radius: 8px;
  border: 1px solid var(--border);
  border-left-width: 4px;
  overflow: hidden;
  background: #fff;
}

.event-status-select-wrap.event-status--planificado {
  border-left-color: #6366f1;
  background: #f5f7ff;
}
.event-status-select-wrap.event-status--en_produccion,
.event-status-select-wrap.event-status--confirmado,
.event-status-select-wrap.event-status--en_curso {
  border-left-color: #f59e0b;
  background: #fffbeb;
}
.event-status-select-wrap.event-status--finalizado {
  border-left-color: #10b981;
  background: #f0fdf4;
}
.event-status-select-wrap.event-status--cancelado {
  border-left-color: #ef4444;
  background: #fef2f2;
}

.event-status-select-wrap .event-status-select {
  width: 100%;
  border: none;
  background: transparent;
  font-weight: 600;
  padding: 10px 12px;
}

.event-ficha-summary-chip.event-status {
  border-radius: 999px;
}

.event-list-badge {
  background: linear-gradient(135deg, #7c3aed 0%, #5b21b6 100%);
  color: #fff;
}

.event-form textarea {
  width: 100%;
  margin-top: 6px;
  resize: vertical;
}

/* ── Ficha evento (layout ERP) ─────────────────────────────────────────── */
.event-ficha-form {
  margin: 0;
  height: 100%;
  min-height: 0;
}

.event-ficha-root {
  display: flex;
  flex-direction: column;
  max-height: min(72vh, calc(100vh - 200px));
  min-height: 280px;
  height: 100%;
}

.event-ficha-sticky {
  flex-shrink: 0;
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
  padding: 12px 16px 0;
  z-index: 2;
}

.event-ficha-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 14px 16px 18px;
}

.hidden,
[hidden] {
  display: none !important;
}

.event-ficha-panel.hidden {
  display: none;
}

.event-ficha-toolbar {
  margin-bottom: 0;
  padding-bottom: 10px;
  border-bottom: none;
}

.event-ficha-toolbar-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.event-ficha-meta-line {
  font-weight: 400;
}

.event-ficha-toolbar-actions {
  align-items: center;
}

.event-ficha-autosave-hint {
  font-size: 0.78rem;
  white-space: nowrap;
}

.event-ficha-summary-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  padding: 10px 0 12px;
  border-bottom: 1px solid #f1f5f9;
}

.event-ficha-summary-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  font-size: 0.8rem;
  line-height: 1.2;
  max-width: 100%;
}

.event-ficha-summary-chip--title {
  font-weight: 600;
  color: #0f172a;
  border-radius: 8px;
  max-width: min(100%, 280px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.event-ficha-summary-chip--accent {
  background: #ecfdf5;
  border-color: #a7f3d0;
}

.event-ficha-summary-chip--accent strong {
  color: #047857;
}

.event-ficha-summary-chip--pos strong {
  color: #15803d;
}

.event-ficha-summary-chip--neg strong {
  color: #b91c1c;
}

.event-ficha-summary-chip .muted {
  font-size: 0.72rem;
}

.event-ficha-inner-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 4px;
  overflow-x: auto;
  padding: 0 0 0;
  margin: 0 -4px;
  scrollbar-width: thin;
}

.event-ficha-inner-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  border: none;
  border-bottom: 3px solid transparent;
  background: transparent;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.84rem;
  color: #64748b;
  white-space: nowrap;
  border-radius: 8px 8px 0 0;
  margin-bottom: -1px;
}

.event-ficha-inner-tab:hover:not(:disabled) {
  color: #334155;
  background: #f8fafc;
}

.event-ficha-inner-tab.active {
  color: var(--event-accent, #4f46e5);
  border-bottom-color: var(--event-accent, #4f46e5);
  background: #f8fafc;
}

.event-ficha-inner-tab:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.event-ficha-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #64748b;
}

.event-ficha-inner-tab.active .event-ficha-icon {
  color: var(--event-accent, #4f46e5);
}

.event-ficha-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
}

.event-ficha-section-title span {
  line-height: 1.3;
}

.event-ficha-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.event-ficha-panel-placeholder {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 20px 16px;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
}

.event-ficha-panel-placeholder p {
  margin: 2px 0 0;
  line-height: 1.45;
}

#event-detail-body:has(.event-ficha-root),
#event-detail-body:has(.event-compras-root) {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}

.event-compras-root {
  display: flex;
  flex-direction: column;
  max-height: min(72vh, calc(100vh - 200px));
  min-height: 280px;
  height: 100%;
}

.event-compras-sticky {
  flex-shrink: 0;
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
  padding: 12px 16px 0;
}

.event-compras-toolbar-main {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.event-compras-toolbar-main .menu-erp-breadcrumb {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.event-compras-actions {
  flex-wrap: wrap;
}

.event-compras-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  padding: 10px 0 12px;
  border-bottom: 1px solid #f1f5f9;
}

.event-compras-search {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0 0 12px;
  max-width: 360px;
}

.event-compras-search input {
  width: 100%;
}

.event-compras-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 14px 16px 18px;
}

.event-compras-icon {
  display: inline-flex;
  align-items: center;
  color: #64748b;
  flex-shrink: 0;
}

.event-compras-empty {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 24px 20px;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
  margin: 16px;
}

.event-compras-empty p {
  margin: 4px 0 0;
  line-height: 1.45;
}

#event-compras-table tbody tr[hidden] {
  display: none;
}

.event-ficha-section--card {
  padding: 14px 16px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

.event-ficha-section--muted {
  background: #f8fafc;
}

.event-ficha-section .menu-erp-section-title {
  margin: 0 0 12px;
}

.event-ficha-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.event-ficha-fields--grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px 14px;
}

.event-ficha-fields--contact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 560px) {
  .event-ficha-fields--contact {
    grid-template-columns: 1fr;
  }
}

.event-ficha-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

.event-ficha-field--full {
  grid-column: 1 / -1;
}

.event-ficha-field input,
.event-ficha-field select {
  width: 100%;
  min-width: 0;
  padding: 8px 10px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  font-size: 0.9rem;
  background: #fff;
}

.event-ficha-title-input {
  font-size: 1.05rem;
  font-weight: 600;
  padding: 10px 12px !important;
}

.event-ficha-section--ingresos {
  background: linear-gradient(180deg, #f8fafc 0%, #fff 55%);
}

.event-ficha-ingresos {
  display: grid;
  grid-template-columns: minmax(140px, 200px) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
}

@media (max-width: 720px) {
  .event-ficha-ingresos {
    grid-template-columns: 1fr;
  }
}

.event-ficha-pvp-box {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid #c7d2fe;
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(99, 102, 241, 0.08);
}

.event-ficha-pvp-input {
  font-size: 1.25rem !important;
  font-weight: 600;
  color: #312e81;
}

.event-ficha-kpis-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}

@media (max-width: 900px) {
  .event-ficha-kpis-row {
    grid-template-columns: 1fr;
  }
}

.event-ficha-kpi-hint {
  display: block;
  margin-top: 4px;
  font-size: 0.68rem;
  color: #94a3b8;
  text-transform: none;
  letter-spacing: 0;
}

.event-ficha-kpi--accent {
  border-color: #a7f3d0;
  background: linear-gradient(180deg, #ecfdf5 0%, #fff 100%);
}

.event-ficha-kpi--accent strong {
  color: #047857;
}

.event-ficha-kpi--pos {
  border-color: #86efac;
  background: #f0fdf4;
}

.event-ficha-kpi--pos strong {
  color: #15803d;
}

.event-ficha-kpi--neg {
  border-color: #fecaca;
  background: #fef2f2;
}

.event-ficha-kpi--neg strong {
  color: #b91c1c;
}

.event-ficha-section .menu-erp-table-wrap {
  margin-top: 0;
}

.event-ficha-section .menu-erp-table thead th {
  background: #f1f5f9;
}

#event-assign-table input,
#event-assign-table select,
#event-ficha-otros-table input {
  width: 100%;
  min-width: 0;
  font-size: 0.85rem;
}

.eventos-inner-tabs {
  margin-bottom: 14px;
}

.eventos-module-body {
  --event-accent: #4f46e5;
  --event-accent-muted: #6366f1;
  --event-accent-fin: #0d9488;
  padding: 0 2px 16px;
}

.eventos-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 10px 14px;
}

.eventos-toolbar.hotels-toolbar {
  margin-bottom: 10px;
}

.event-detail-placeholder {
  padding: 48px 24px;
  text-align: center;
}

.event-detail-placeholder .placeholder-panel {
  font-size: 1.05rem;
  margin: 0 0 8px;
}

.eventos-menu-detail {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.eventos-menu-head .event-status {
  margin-top: 10px;
}

.eventos-menu-slots {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.eventos-menu-slot {
  padding: 14px;
  border: 1px solid var(--border, #e2e8f0);
  background: #fafbfc;
}

.eventos-menu-slot-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
}

.eventos-menu-foot {
  margin: 0;
  padding-top: 8px;
  border-top: 1px solid #e2e8f0;
}

.eventos-menu-table-wrap {
  max-height: calc(100vh - 260px);
  overflow: auto;
}

.eventos-menu-table tfoot .eventos-menu-total-row td {
  border-top: 2px solid #e2e8f0;
  background: #f8fafc;
  padding-top: 10px;
  padding-bottom: 10px;
}

.eventos-menu-editor input[type="text"] {
  width: 100%;
  min-width: 0;
}

.eventos-menu-editor .menu-inp-codigo {
  max-width: 100px;
}

.eventos-menu-editor .menu-inp-ratio {
  max-width: 72px;
  text-align: right;
}

.eventos-menu-editor .menu-row-actions {
  width: 40px;
  text-align: center;
}

.eventos-menu-editor #menu-name {
  width: 100%;
  margin-top: 6px;
}

.menu-mat-cell {
  position: relative;
  min-width: 200px;
}

.menu-mat-suggest {
  position: absolute;
  z-index: 20;
  left: 0;
  right: 0;
  top: 100%;
  margin: 2px 0 0;
  padding: 4px 0;
  list-style: none;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
  max-height: 200px;
  overflow-y: auto;
}

.menu-mat-suggest.hidden {
  display: none;
}

.menu-mat-suggest li {
  padding: 6px 10px;
  cursor: pointer;
  font-size: 0.85rem;
}

.menu-mat-suggest li:hover {
  background: #f1f5f9;
}

.eventos-menu-editor .menu-inp-material {
  width: 100%;
  min-width: 180px;
}

/* Menús — ficha ERP */
.menu-erp-layout .menu-erp-list-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.menu-erp-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.menu-erp-list-title {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
}

.menu-erp-search {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--input-border);
  border-radius: 6px;
  font-size: 0.9rem;
}

.menu-erp-sheet {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 4px 2px 8px;
}

.menu-erp-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e2e8f0;
}

.menu-erp-breadcrumb {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #94a3b8;
}

.menu-erp-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.menu-erp-header {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 20px;
  align-items: start;
  padding: 16px;
  background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

@media (max-width: 640px) {
  .menu-erp-header {
    grid-template-columns: 1fr;
  }
}

.menu-erp-photo {
  width: 140px;
  min-height: 120px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  background: #fff;
}

.menu-erp-photo--zoomable {
  padding: 0;
  cursor: zoom-in;
  font: inherit;
  text-align: left;
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.menu-erp-photo--zoomable:hover,
.menu-erp-photo--zoomable:focus-visible {
  border-color: #94a3b8;
  box-shadow: 0 0 0 2px rgba(30, 58, 95, 0.12);
  outline: none;
}

.menu-erp-photo-zoom-btn {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
  font: inherit;
}

.menu-erp-photo--has-zoom .menu-erp-photo-prev:hover {
  box-shadow: inset 0 0 0 2px rgba(30, 58, 95, 0.08);
}

.menu-erp-photo-img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.menu-erp-photo-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 120px;
  color: #94a3b8;
  font-size: 0.8rem;
  text-align: center;
  padding: 8px;
}

.menu-erp-photo-empty--error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px dashed #fecaca;
  border-radius: 8px;
}

.menu-erp-photo-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
}

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.image-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.82);
}

.image-lightbox-close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}

.image-lightbox-close:hover {
  background: rgba(255, 255, 255, 0.22);
}

.image-lightbox-figure {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: min(96vw, 1100px);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.image-lightbox-img {
  max-width: 100%;
  max-height: calc(90vh - 40px);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

.image-lightbox-caption {
  margin: 0;
  color: #f8fafc;
  font-size: 0.95rem;
  text-align: center;
}

.menu-erp-title {
  margin: 0 0 12px;
  font-size: 1.35rem;
  font-weight: 600;
  color: #0f172a;
}

.menu-erp-name-input {
  width: 100%;
  margin-top: 4px;
  padding: 10px 12px;
  font-size: 1.1rem;
  font-weight: 500;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
}

.menu-erp-field-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
}

.menu-erp-kpis {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.menu-erp-kpi {
  min-width: 100px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}

.menu-erp-kpi span {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #94a3b8;
}

.menu-erp-kpi strong {
  display: block;
  margin-top: 4px;
  font-size: 1.15rem;
  color: #1e293b;
}

.menu-erp-section {
  padding: 0 2px;
}

.menu-erp-section-title {
  margin: 0 0 10px;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #475569;
}

.menu-erp-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.menu-erp-section-head .menu-erp-section-title {
  margin: 0;
}

.menu-erp-notes-input {
  width: 100%;
  resize: vertical;
  min-height: 88px;
  padding: 10px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1.45;
}

.menu-erp-notes-body {
  margin: 0;
  padding: 12px 14px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  font-size: 0.9rem;
  line-height: 1.5;
  color: #334155;
  white-space: pre-wrap;
}

.menu-erp-table-wrap {
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}

.menu-erp-table thead th {
  background: #f1f5f9;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #64748b;
}

.menu-list-card {
  align-items: center;
}

.menu-list-thumb {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
}

.menu-list-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.menu-erp-detail-panel {
  min-height: 320px;
}

.event-detail-tabs {
  margin-bottom: 14px;
  border-bottom: 1px solid #e2e8f0;
}

.event-kpi--pos strong {
  color: #047857;
}
.event-kpi--neg strong {
  color: #b91c1c;
}

.event-costes-root {
  display: flex;
  flex-direction: column;
  max-height: min(72vh, calc(100vh - 200px));
  min-height: 280px;
}

.event-costes-sticky {
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 3;
  padding-bottom: 8px;
  border-bottom: 1px solid #e2e8f0;
  background: #fff;
}

.event-costes-kpi-grid {
  margin-bottom: 8px;
}

.event-costes-kpi--in strong {
  color: #047857;
}

.event-costes-kpi--out strong {
  color: #b45309;
}

.menu-photo-hint {
  margin: 8px 0 0;
}

.event-costes-hint {
  margin: 8px 0 0;
}

.event-costes-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 14px 0 8px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.event-costes-section {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 12px 14px;
}

.event-costes-section--comida {
  background: linear-gradient(180deg, #f8fafc 0%, #fff 70%);
  border-color: #cbd5e1;
}

.event-costes-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.event-costes-section--bebida .event-costes-section-head h4 {
  color: #92400e;
}
.event-costes-section--personal .event-costes-section-head h4 {
  color: #1e40af;
}
.event-costes-section--sala .event-costes-section-head h4 {
  color: #7c2d12;
}
.event-costes-section--audiovisual .event-costes-section-head h4 {
  color: #5b21b6;
}

.event-costes-chart .eventos-chart-wrap--donut {
  height: 240px;
}

.event-ods-root {
  display: flex;
  flex-direction: column;
  max-height: min(78vh, calc(100vh - 180px));
  min-height: 360px;
}

.event-ods-sticky {
  flex-shrink: 0;
  padding-bottom: 8px;
  border-bottom: 1px solid #e2e8f0;
  background: #fff;
}

.event-ods-toolbar .menu-erp-breadcrumb {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: min(420px, 50vw);
}

.event-ods-status {
  margin: 6px 0 0;
  min-height: 1.2em;
}

.event-ods-preview-wrap {
  flex: 1;
  min-height: 280px;
  margin-top: 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  overflow: hidden;
}

.event-ods-preview-frame {
  display: block;
  width: 100%;
  height: min(70vh, calc(100vh - 220px));
  min-height: 280px;
  border: none;
  background: #fff;
}

#event-detail-body:has(.event-ods-root) {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}

#event-detail-body:has(.event-costes-root) {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}

.event-cierre-panel {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.event-cierre-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 12px 20px;
  margin-bottom: 4px;
}

.event-cierre-pax-chip strong {
  font-size: 1.15rem;
  color: #1e3a5f;
}

.event-cierre-servicios {
  margin: 0;
  padding: 0;
  list-style: none;
  flex: 1;
  min-width: 200px;
}

.event-cierre-servicios li {
  margin: 2px 0;
}

.event-cierre-balances-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.event-cierre-balances-head .menu-erp-section-title {
  margin: 0;
}

.event-cierre-previsto-hint {
  margin: 0 0 8px;
}

.event-cierre-hint {
  margin: 0;
}

.event-cierre-section--card {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 12px 14px;
}

.event-cierre-section--card .menu-erp-section-title {
  margin: 0 0 10px;
}

.event-cierre-notes {
  width: 100%;
  min-height: 88px;
  resize: vertical;
  font-family: inherit;
  font-size: 0.95rem;
  padding: 10px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
}

.event-cierre-notes-readonly {
  margin: 0;
  white-space: pre-wrap;
}

.event-cierre-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px;
}

.event-cierre-photo-card {
  position: relative;
  margin: 0;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  overflow: hidden;
  background: #f8fafc;
}

.event-cierre-photo-card a {
  display: block;
  aspect-ratio: 4 / 3;
}

.event-cierre-photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.event-cierre-photo-rm {
  position: absolute;
  top: 4px;
  right: 4px;
  min-width: 28px;
  padding: 2px 6px !important;
  background: rgba(255, 255, 255, 0.92) !important;
}

.event-cierre-photo-add {
  cursor: pointer;
  margin: 0;
}

.event-cierre-photo-add input {
  display: none;
}

.event-cierre-photo-cap,
.event-cierre-photo-cap-ro {
  display: block;
  width: 100%;
  margin: 0;
  padding: 4px 6px;
  border: none;
  border-top: 1px solid #e2e8f0;
  font-size: 0.78rem;
  background: #ffffff;
  color: #0f172a;
  box-sizing: border-box;
}

.event-cierre-photo-cap:focus {
  outline: 2px solid #2563eb;
  outline-offset: -2px;
}

#event-cierre-save-status {
  display: block;
  margin-top: 4px;
}

.event-costes-table input,
.event-costes-table select {
  width: 100%;
  min-width: 0;
  font-size: 0.85rem;
}

.event-fin-layout {
  display: grid;
  grid-template-columns: 1fr 1fr 280px;
  gap: 16px;
  margin-top: 16px;
  align-items: start;
}

.event-fin-col-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.event-fin-row-readonly td {
  background: #f8fafc;
}

.event-fin-chart-col .eventos-chart-wrap--donut {
  height: 260px;
}

.event-save-status {
  min-width: 5.5rem;
  text-align: right;
  font-size: 0.8rem;
}

.event-save-status--ok {
  color: #15803d;
  font-weight: 600;
}

.event-save-status--warn {
  color: #b91c1c;
  font-weight: 600;
}

#ev-fin-gastos input,
#ev-fin-gastos select,
.event-costes-table input {
  width: 100%;
  min-width: 0;
  font-size: 0.85rem;
}

@media (max-width: 1100px) {
  .event-fin-layout {
    grid-template-columns: 1fr;
  }
  .event-costes-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.menu-precio-fmt {
  margin-left: 2px;
  font-size: 0.78em;
  font-weight: 600;
  color: #64748b;
  white-space: nowrap;
}

.eventos-analytics-root {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.eventos-analytics-toolbar .event-cal-year-label + .event-cal-year-label {
  margin-left: 0;
}

.eventos-analytics-toolbar {
  margin-bottom: 4px;
}

.eventos-analytics-period-badge {
  margin-left: auto;
  font-weight: 600;
}

.eventos-analytics-section-title {
  margin: 0 0 10px;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #475569;
}

.eventos-analytics-section--economy .eventos-analytics-section-title {
  color: #0f766e;
}

.eventos-analytics-section--gastos .eventos-analytics-section-title {
  color: #b45309;
}

.eventos-analytics-gastos-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.eventos-analytics-gastos-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto auto;
  gap: 8px 14px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 8px;
  background: #f8fafc;
  border: 1px solid var(--input-border);
}

.eventos-analytics-gastos-label {
  font-weight: 600;
  color: var(--text);
  font-size: 0.92rem;
}

.eventos-analytics-gastos-amount {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: #0f172a;
}

.eventos-analytics-gastos-pct {
  font-variant-numeric: tabular-nums;
  font-size: 0.85rem;
  color: var(--muted);
  min-width: 56px;
  text-align: right;
}

.eventos-analytics-gastos-bar {
  grid-column: 1 / -1;
  width: 100%;
  height: 6px;
  background: #e2e8f0;
  border-radius: 999px;
  overflow: hidden;
}

.eventos-analytics-gastos-bar-fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #f59e0b, #b45309);
  border-radius: 999px;
  transition: width 0.3s ease;
}

.eventos-analytics-gastos-bar-fill--comida {
  background: linear-gradient(90deg, #f97316, #c2410c);
}
.eventos-analytics-gastos-bar-fill--personal {
  background: linear-gradient(90deg, #8b5cf6, #6d28d9);
}
.eventos-analytics-gastos-bar-fill--bebida {
  background: linear-gradient(90deg, #06b6d4, #0e7490);
}
.eventos-analytics-gastos-bar-fill--sala {
  background: linear-gradient(90deg, #10b981, #047857);
}
.eventos-analytics-gastos-bar-fill--audiovisual {
  background: linear-gradient(90deg, #3b82f6, #1d4ed8);
}
.eventos-analytics-gastos-bar-fill--otro {
  background: linear-gradient(90deg, #94a3b8, #475569);
}

.eventos-analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

.eventos-analytics-kpi {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 12px 14px;
  border-left: 3px solid var(--event-accent-muted, #6366f1);
}

.eventos-analytics-kpi-grid--fin .eventos-analytics-kpi {
  border-left-color: var(--event-accent-fin, #0d9488);
}

.eventos-analytics-kpi-label {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 4px;
}

.eventos-analytics-kpi strong {
  display: block;
  font-size: 1.35rem;
  font-variant-numeric: tabular-nums;
  color: #1e293b;
  line-height: 1.2;
}

.eventos-analytics-kpi-value--pos {
  color: #059669;
}

.eventos-analytics-kpi-value--neg {
  color: #dc2626;
}

.eventos-analytics-hint {
  margin: 8px 0 0;
}

.eventos-analytics-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.eventos-analytics-legend-badge {
  font-size: 0.78rem;
}

.eventos-analytics-charts-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.eventos-analytics-chart-card {
  margin: 0;
  padding: 14px 16px;
}

.eventos-analytics-chart-card--wide {
  grid-column: 1 / -1;
}

.eventos-analytics-chart-title {
  margin: 0 0 10px;
  font-size: 0.85rem;
  font-weight: 600;
  color: #475569;
}

.eventos-analytics-tables-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.eventos-analytics-table-card {
  margin: 0;
  padding: 14px 16px 0;
}

.ev-an-top-event-row {
  cursor: pointer;
}

.ev-an-top-event-row:hover td {
  background: #f1f5f9;
}

.eventos-analytics-kpis .cell strong {
  display: block;
  font-size: 1.5rem;
  margin-top: 4px;
  color: #1e293b;
}

.eventos-chart-wrap {
  position: relative;
  height: 228px;
}

.eventos-chart-wrap--hbar {
  height: 228px;
}

.eventos-chart-wrap--donut {
  height: 228px;
}

.eventos-chart-wrap--wide {
  height: 228px;
}

@media (max-width: 900px) {
  .eventos-analytics-charts-grid,
  .eventos-analytics-tables-grid {
    grid-template-columns: 1fr;
  }

  .eventos-analytics-chart-card--wide {
    grid-column: auto;
  }
}

.materiales-panel .materiales-toolbar {
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.materiales-count {
  margin-left: auto;
}

.materiales-table-wrap {
  max-height: calc(100vh - 200px);
  overflow: auto;
}

.materiales-table .mat-code {
  font-size: 0.85rem;
  background: #f1f5f9;
  padding: 2px 6px;
  border-radius: 4px;
}

.materiales-table .mat-family {
  font-size: 0.82rem;
  color: var(--muted, #64748b);
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mat-import-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.mat-dest-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 4px 14px;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 8px;
}

.mat-dest-chip {
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #475569;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.12s, color 0.12s, border-color 0.12s;
}

.mat-dest-chip:hover {
  background: #f1f5f9;
}

.mat-dest-chip--active,
.mat-dest-chip--active:hover {
  background: #2563eb;
  color: #ffffff;
  border-color: #2563eb;
}

.mat-dest-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
  background: #f1f5f9;
  color: #475569;
}

.mat-dest-badge--BCN {
  background: #ecfeff;
  color: #0e7490;
  border-color: #a5f3fc;
}

.mat-dest-badge--TFE {
  background: #fef3c7;
  color: #92400e;
  border-color: #fde68a;
}

.mat-dest-badge--Teguise {
  background: #ede9fe;
  color: #5b21b6;
  border-color: #ddd6fe;
}

/* ───── Fila clickable de materiales ───── */
.materiales-table tbody tr.mat-row {
  cursor: pointer;
  transition: background-color 0.12s, box-shadow 0.12s;
}

.materiales-table tbody tr.mat-row:hover {
  background-color: #f1f5f9;
}

.materiales-table tbody tr.mat-row:hover .mat-code {
  background: #e2e8f0;
}

/* ───── Modal de evolución de precios ───── */
.mat-evol-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
}

.mat-evol-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 12, 24, 0.66);
  backdrop-filter: blur(2px);
}

.mat-evol-dialog {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  background: #0f1422;
  color: #e6ebf5;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45);
  padding: 22px 26px 26px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.mat-evol-head {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: "meta close" "title close";
  gap: 6px 12px;
  align-items: start;
}

.mat-evol-head-meta {
  grid-area: meta;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  font-size: 0.85rem;
}

.mat-evol-head-meta .mat-code {
  background: rgba(255, 255, 255, 0.07);
  color: #c8d1e6;
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.82rem;
}

.mat-evol-format {
  color: rgba(230, 235, 245, 0.6);
  font-size: 0.8rem;
}

.mat-evol-title {
  grid-area: title;
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: -0.005em;
}

.mat-evol-close {
  grid-area: close;
  align-self: start;
  background: rgba(255, 255, 255, 0.06);
  color: #e6ebf5;
  border: 1px solid rgba(255, 255, 255, 0.08);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.12s, border-color 0.12s;
}

.mat-evol-close:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.18);
}

.mat-evol-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.mat-evol-stat {
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mat-evol-stat-label {
  font-size: 0.75rem;
  color: rgba(230, 235, 245, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.mat-evol-stat-val {
  font-size: 1.15rem;
  font-weight: 600;
  color: #f7f9fd;
}

.mat-evol-stat--primary {
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.18), rgba(124, 92, 255, 0.06));
  border-color: rgba(124, 92, 255, 0.35);
}

.mat-evol-stat--primary .mat-evol-stat-val {
  color: #c1b6ff;
}

.mat-pct--up {
  color: #fb7185;
}

.mat-pct--down {
  color: #4ade80;
}

.mat-pct--flat {
  color: rgba(230, 235, 245, 0.65);
}

.mat-evol-chart {
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  padding: 12px 6px 4px;
}

.mat-spark {
  width: 100%;
  height: 220px;
  display: block;
}

.mat-spark-pt circle {
  fill: #a094ff;
  stroke: #0f1422;
  stroke-width: 1.5;
  transition: r 0.12s;
}

.mat-spark-pt:hover circle {
  r: 5;
}

.mat-evol-table-wrap {
  max-height: 320px;
  overflow-y: auto;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
}

.mat-evol-table {
  width: 100%;
  border-collapse: collapse;
}

.mat-evol-table thead th {
  position: sticky;
  top: 0;
  background: #181f33;
  color: rgba(230, 235, 245, 0.75);
  font-weight: 500;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.mat-evol-table thead th.num {
  text-align: right;
}

.mat-evol-table tbody td {
  padding: 9px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  font-size: 0.92rem;
}

.mat-evol-table tbody tr:last-child td {
  border-bottom: 0;
}

.mat-evol-table tbody td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.mat-evol-table .muted {
  color: rgba(230, 235, 245, 0.55);
  font-style: italic;
}

@media (max-width: 640px) {
  .mat-evol-dialog {
    padding: 16px 16px 20px;
    border-radius: 12px;
  }
  .mat-evol-title {
    font-size: 1.15rem;
  }
  .mat-spark {
    height: 180px;
  }
}

.hotels-list-scroll {
  max-height: calc(100vh - 200px);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-right: 4px;
}

.hotel-list-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  width: 100%;
  text-align: left;
  padding: 11px 11px 11px 9px;
  border-radius: 11px;
  border: 1px solid #e2e8f0;
  background: #fafbfc;
  cursor: pointer;
  font: inherit;
  color: inherit;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.hotel-list-card:hover {
  background: #f1f5f9;
  border-color: #cbd5e1;
}

.hotel-list-card.selected {
  background: linear-gradient(135deg, #eff6ff 0%, #e0f2fe 100%);
  border-color: #93c5fd;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.12);
}

.hotel-list-badge {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 11px;
  background: linear-gradient(145deg, #3b82f6, #1d4ed8);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.02em;
}

.hotel-list-card.selected .hotel-list-badge {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.hotel-list-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.hotel-list-name {
  font-weight: 700;
  font-size: 0.92rem;
}

.hotel-list-stats,
.hotel-list-loc {
  font-size: 0.78rem;
}

.hotels-detail-panel {
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.hotels-detail-panel #event-detail-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.hotel-detail-placeholder {
  padding: 48px 24px;
  text-align: center;
}

.hotel-detail-root {
  display: flex;
  flex-direction: column;
  min-height: 320px;
}

.hotel-detail-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid #e2e8f0;
  background: linear-gradient(180deg, #fafbfc 0%, #fff 100%);
}

.hotel-detail-badge {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(145deg, #2563eb, #1e40af);
  color: #fff;
  font-weight: 800;
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hotel-detail-head-text {
  flex: 1;
  min-width: 0;
}

.hotel-detail-title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.hotel-detail-meta {
  margin: 4px 0 0;
}

.hotel-code-line {
  margin: 6px 0 0;
}

.hotel-tab-bar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 0 8px;
}

.hotel-tab {
  padding: 12px 16px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--muted);
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
  border-radius: 8px 8px 0 0;
}

.hotel-tab:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.7);
}

.hotel-tab.active {
  color: var(--accent-h);
  background: #fff;
  border-bottom-color: var(--accent);
}

.hotel-detail-body {
  padding: 16px 18px 20px;
  flex: 1;
}

.hotel-tab-panel[hidden] {
  display: none !important;
}

.hotel-section-title {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 700;
}

.hotel-dialog-sub {
  margin: 0 0 14px;
}

.hotel-info-edit-card {
  padding: 18px;
}

.hotel-info-readonly {
  padding: 18px;
}

.hotel-notes-readonly {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid #e2e8f0;
}

.hotel-notes-readonly p {
  margin: 6px 0 0;
  line-height: 1.45;
}

.hotel-active-row {
  flex-direction: row !important;
  align-items: center;
  gap: 10px !important;
}

.hotel-subpanel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.hotel-empty-hint {
  padding: 28px 12px;
  text-align: center;
}

.venue-fb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}

.venue-fb-card {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
  border-left-width: 4px;
  border-left-color: #94a3b8;
}

.venue-fb-card.venue-type-restaurante {
  border-left-color: #2563eb;
}
.venue-fb-card.venue-type-bar {
  border-left-color: #8b5cf6;
}
.venue-fb-card.venue-type-snack {
  border-left-color: #f59e0b;
}
.venue-fb-card.venue-type-buffet {
  border-left-color: #10b981;
}
.venue-fb-card.venue-type-salon-de-eventos {
  border-left-color: #ec4899;
}

.venue-fb-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 10px;
}

.venue-fb-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
  line-height: 1;
}

.venue-fb-icon-svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.venue-fb-label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 10px;
}

.venue-fb-label:last-child {
  margin-bottom: 0;
}

.venue-fb-label input,
.venue-fb-label select,
.venue-fb-label textarea {
  font-weight: 500;
  color: var(--text);
}

.venue-fb-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

@media (max-width: 480px) {
  .venue-fb-row2 {
    grid-template-columns: 1fr;
  }
}

.hotel-org-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.hotel-org-count {
  font-weight: 700;
  font-size: 0.92rem;
}

.hotel-org-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.hotel-org-table-wrap {
  margin-bottom: 12px;
}

.hotel-org-table .org-sort {
  width: 4.5rem;
}

.hotel-org-table tr.selected {
  background: #eff6ff;
}

.hotel-org-tree-wrap {
  margin-top: 12px;
  padding: 14px;
  border-radius: 11px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

.hotel-org-svg-wrap {
  width: 100%;
}

.hotel-org-svg-scroll {
  overflow: auto;
  max-height: min(72vh, 580px);
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  background: #ffffff;
}

.hotel-org-svg {
  display: block;
  font-family: "Segoe UI", system-ui, sans-serif;
}

.org-svg-list-fallback {
  margin-top: 12px;
  font-size: 0.88rem;
}

.org-svg-list-fallback summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 8px;
}

.org-svg-list-fallback summary:hover {
  color: var(--text);
}

.hotel-save-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 14px 18px 18px;
  border-top: 1px solid #e2e8f0;
  background: #fafbfc;
}

.hotel-list-empty {
  padding: 28px 12px;
  text-align: center;
}

.toast {
  position: fixed;
  bottom: 22px;
  right: 22px;
  padding: 12px 18px;
  background: #1e293b;
  color: white;
  border-radius: 10px;
  font-size: 0.9rem;
  z-index: 50;
  box-shadow: var(--shadow);
}

/* Layout grids */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 960px) {
  .grid-2 {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }

  .grid-2-wide-left {
    grid-template-columns: 1.15fr 0.85fr;
  }
}

.panel {
  padding: 14px 16px;
}

.panel h2 {
  margin: 0 0 12px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}

.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}

.toolbar-spacer {
  flex: 1;
}

/* Maestro / evolución dentro de Escandallos: solo acciones, sin ruta ni estado Excel */
.esc-prices-actions {
  justify-content: flex-end;
  margin-bottom: 14px;
}

.esc-prices-import-label {
  cursor: pointer;
  margin: 0;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.data-table th,
.data-table td {
  padding: 9px 11px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.data-table th {
  background: #f8fafc;
  font-weight: 600;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.data-table tbody tr {
  cursor: pointer;
  transition: background 0.1s ease;
}

.data-table tbody tr:hover {
  background: #f8fafc;
}

.data-table tbody tr.active {
  background: var(--accent-soft);
}

.data-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Reglas genéricas para cualquier tabla dentro de los wrappers conocidos */
.data-table-wrap > table,
.sub-table-wrap > table,
.menu-erp-table-wrap > table,
.eventos-menu-table-wrap > table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.data-table-wrap > table > thead > tr > th,
.sub-table-wrap > table > thead > tr > th,
.menu-erp-table-wrap > table > thead > tr > th,
.eventos-menu-table-wrap > table > thead > tr > th {
  text-align: left;
  font-weight: 600;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  background: #f8fafc;
  padding: 9px 11px;
  border-bottom: 1px solid var(--border);
}

.data-table-wrap > table > tbody > tr > td,
.sub-table-wrap > table > tbody > tr > td,
.menu-erp-table-wrap > table > tbody > tr > td,
.eventos-menu-table-wrap > table > tbody > tr > td {
  padding: 9px 11px;
  border-bottom: 1px solid var(--border);
  font-variant-numeric: tabular-nums;
}

.data-table-wrap > table > tbody > tr:hover > td,
.sub-table-wrap > table > tbody > tr:hover > td,
.menu-erp-table-wrap > table > tbody > tr:hover > td,
.eventos-menu-table-wrap > table > tbody > tr:hover > td {
  background: #f8fafc;
}

/* ── Chips / badges unificados ─────────────────────────────────────────── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  border: 1px solid var(--border-strong);
  background: #f1f5f9;
  color: var(--muted);
  line-height: 1.4;
  vertical-align: middle;
  letter-spacing: 0.01em;
}

.chip--info {
  background: var(--accent-soft);
  color: #1d4ed8;
  border-color: #bfdbfe;
}

.chip--success {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}

.chip--warning {
  background: #fffbeb;
  color: var(--amber);
  border-color: #fde68a;
}

.chip--danger {
  background: #fef2f2;
  color: var(--error);
  border-color: #fecaca;
}

.chip--violet {
  background: #ede9fe;
  color: #6d28d9;
  border-color: #c4b5fd;
}

.tag-inactive {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted);
  background: #f1f5f9;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: 1px 8px;
  vertical-align: middle;
  margin-left: 4px;
  letter-spacing: 0.01em;
}

.tag-warn {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 700;
  color: #b91c1c;
  background: #fee2e2;
  border: 1px solid #fecaca;
  border-radius: 4px;
  padding: 1px 8px;
  vertical-align: middle;
  margin-left: 6px;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.hotel-list-card--no-dest {
  border-left: 3px solid #ef4444;
}

.hf-destination-empty {
  border-color: #ef4444 !important;
  background: #fef2f2 !important;
}

.hf-destination-warn {
  display: none;
  font-size: 0.78rem;
  color: #b91c1c;
  margin-top: 4px;
  font-weight: 500;
}
.hf-destination-warn.is-visible {
  display: block;
}

.audit-warning-panel {
  border: 1px solid #fecaca;
  background: #fef9f9;
}
.audit-warning-panel .panel-title {
  margin-top: 0;
  color: #b91c1c;
}
.audit-nodest-list {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
@media print {
  body.printing-audit .no-print-soft {
    display: none !important;
  }
}

.role-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 4px;
  padding: 2px 8px;
  vertical-align: middle;
  text-transform: capitalize;
  letter-spacing: 0.02em;
}

.role-badge--admin {
  background: #ede9fe;
  color: #6d28d9;
  border: 1px solid #c4b5fd;
}

.role-badge--user {
  background: #f0f9ff;
  color: #0369a1;
  border: 1px solid #bae6fd;
}

.meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.meta-grid .cell {
  background: #f8fafc;
  padding: 10px;
  border-radius: 10px;
}

.meta-grid .cell span {
  display: block;
  font-size: 0.75rem;
  color: var(--muted);
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pill {
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.85rem;
}

.pill.blue {
  background: var(--accent);
  color: white;
}

.pill.orange {
  background: #fff7ed;
  color: var(--orange);
  border: 1px solid #fed7aa;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.ing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.ing-table th,
.ing-table td {
  padding: 8px 6px;
  border-bottom: 1px solid #e2e8f0;
}

.ing-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.tabs {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border);
}

.tab {
  padding: 9px 14px;
  border: none;
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  font-weight: 500;
  font-size: 0.86rem;
  color: var(--text-2);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.12s ease, border-color 0.12s ease;
}

.tab:not(.active):hover {
  background: transparent;
  color: var(--accent-h);
  border-bottom-color: var(--border-strong);
}

.tab.active {
  background: transparent;
  color: var(--accent-h);
  border-bottom-color: var(--accent);
  font-weight: 600;
}

.search-lite {
  position: relative;
}

.ac-results {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 10;
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  max-height: 220px;
  overflow: auto;
  margin-top: 4px;
  box-shadow: var(--shadow);
}

.ac-item {
  padding: 8px 11px;
  cursor: pointer;
  font-size: 0.85rem;
}

.ac-item:hover {
  background: #eff6ff;
}

.sub-table-wrap {
  overflow-x: auto;
}

.dim {
  color: var(--muted);
  font-size: 0.82rem;
}

.week-grid {
  display: grid;
  gap: 8px;
  font-size: 0.78rem;
}

.week-grid select {
  font-size: 0.78rem;
  padding: 4px 6px;
}

.placeholder-panel {
  padding: 24px;
  text-align: center;
  color: var(--muted);
}

/* ── Org chart tree ── */
.org-tree, .org-tree ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.org-tree {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 12px 0;
}
.org-tree li {
  position: relative;
  padding: 4px 0 4px 28px;
}
.org-tree li::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 0;
  bottom: 50%;
  border-left: 2px solid var(--border);
}
.org-tree li::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 50%;
  width: 14px;
  border-top: 2px solid var(--border);
}
.org-tree > li::before { display: none; }
.org-tree > li::after  { display: none; }
.org-node {
  display: inline-flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 0.83rem;
  min-width: 140px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
.org-node strong { font-size: 0.88rem; color: var(--text); }
.org-node span   { color: var(--muted); font-size: 0.78rem; }

/* ── Pantalla cocina · ficha (corporativo rojo / blanco) ── */
.kitchen-sheet {
  --kitchen-red: #c40000;
  --kitchen-red-dark: #9f0000;
  --kitchen-red-text: #7f1d1d;
  --kitchen-red-soft: #fef2f2;
  --kitchen-red-line: #fecaca;
}
.kitchen-layout {
  display: grid;
  grid-template-columns: minmax(280px, 340px) 1fr;
  gap: 20px;
  align-items: start;
}
/* Vista cocina: menos scroll global — solo lista ingredientes; cabecera siempre visible */
.kitchen-layout--cook {
  align-items: stretch;
  grid-template-columns: minmax(220px, 268px) 1fr;
  gap: 14px;
  flex: 1;
  min-height: 0;
  max-height: calc(100dvh - 88px);
}
.kitchen-layout--cook .kitchen-sidebar {
  padding: 12px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: calc(100dvh - 88px);
  overflow: hidden;
}
.kitchen-layout--cook .kitchen-list-wrap {
  flex: 1;
  min-height: 120px;
  max-height: none;
}
.kitchen-layout--cook .kitchen-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  max-height: calc(100dvh - 88px);
}
.kitchen-layout--cook .kitchen-sheet {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.kitchen-layout--cook .kitchen-hero {
  flex-shrink: 0;
  padding: 12px 16px 14px;
  background: #ffffff;
  color: #0f172a;
  border-bottom: 4px solid var(--kitchen-red);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}
.kitchen-layout--cook .kitchen-hero-copy {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.kitchen-layout--cook .kitchen-hero-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  min-width: 0;
  padding: 4px 8px 4px 0;
}
.kitchen-layout--cook .kitchen-hero-grid {
  gap: 14px 16px;
  grid-template-columns: minmax(200px, 300px) 1fr minmax(100px, 160px);
  align-items: center;
}
.kitchen-layout--cook .kitchen-hero-grid--no-photo {
  grid-template-columns: minmax(200px, 300px) 1fr;
}
.kitchen-layout--cook .kitchen-logo {
  max-height: 96px;
  width: auto;
  max-width: 100%;
  margin: 0;
  padding: 10px 18px;
  background: #fff;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 5px rgba(15, 23, 42, 0.07);
  object-fit: contain;
  filter: none;
}
.kitchen-layout--cook .kitchen-title {
  font-size: 1.22rem;
  margin: 0 0 4px;
  color: var(--kitchen-red-dark);
}
.kitchen-layout--cook .kitchen-meta {
  font-size: 0.8rem;
  margin: 0 0 8px;
  color: #64748b;
  opacity: 1;
}
.kitchen-layout--cook .kitchen-target-portions {
  margin: 0 auto 8px;
  padding: 10px 16px;
  max-width: 320px;
  width: 100%;
  background: var(--kitchen-red-soft);
  border: 2px solid var(--kitchen-red-line);
  border-radius: 14px;
  box-shadow: none;
}
.kitchen-layout--cook .kitchen-target-label {
  font-size: 0.62rem;
  margin-bottom: 4px;
  letter-spacing: 0.08em;
  color: var(--kitchen-red-text);
}
.kitchen-layout--cook .kitchen-target-row {
  justify-content: center;
}
.kitchen-layout--cook .kitchen-target-value {
  font-size: clamp(1.6rem, 3.5vw, 2.35rem);
  color: var(--kitchen-red);
  text-shadow: none;
}
.kitchen-layout--cook .kitchen-target-unit {
  font-size: 1rem;
  color: var(--kitchen-red-dark);
  font-weight: 700;
}
.kitchen-layout--cook .kitchen-badge {
  padding: 8px 14px;
  font-size: 0.8rem;
  text-align: center;
  max-width: 420px;
  margin: 0 auto;
  width: 100%;
  background: var(--kitchen-red);
  color: #fff;
  border-radius: 10px;
}
.kitchen-layout--cook .kitchen-badge strong {
  color: #fff;
}
.kitchen-layout--cook .kitchen-hero-shot {
  min-height: 72px;
  max-height: 120px;
  background: var(--kitchen-red-soft);
  border: 2px solid var(--kitchen-red-line);
}
.kitchen-layout--cook .kitchen-hero-shot img {
  max-height: 120px;
  object-fit: cover;
}
.kitchen-sheet-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.kitchen-layout--cook .kitchen-allergens {
  margin: 8px 12px 0;
  padding: 8px 12px;
  font-size: 0.84rem;
  line-height: 1.35;
  flex-shrink: 0;
  text-align: center;
  background: var(--kitchen-red-soft);
  border: 1px solid var(--kitchen-red-line);
  color: var(--kitchen-red-text);
}
.kitchen-layout--cook .kitchen-allergens strong {
  color: var(--kitchen-red-dark);
}
.kitchen-table-scroll {
  flex: 1;
  min-height: 100px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.kitchen-layout--cook .kitchen-ing-table {
  font-size: 0.82rem;
}
.kitchen-layout--cook .kitchen-ing-table th,
.kitchen-layout--cook .kitchen-ing-table td {
  padding: 7px 9px;
}
.kitchen-layout--cook .kitchen-ing-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  box-shadow: 0 1px 0 #e2e8f0;
  text-align: center;
  vertical-align: bottom;
  background: var(--kitchen-red-soft);
  color: var(--kitchen-red-dark);
  border-bottom: 2px solid var(--kitchen-red-line);
}
.kitchen-layout--cook .kitchen-ing-table tbody td {
  text-align: center;
  vertical-align: middle;
}
.kitchen-layout--cook .kitchen-ing-table .num {
  text-align: center;
}
.kitchen-layout--cook .kitchen-th-sub {
  text-align: center;
}
.kitchen-layout--cook .kitchen-qty-net {
  color: #0f172a;
  font-weight: 700;
}
.kitchen-layout--cook .kitchen-qty-bruta {
  color: var(--kitchen-red-dark);
  font-weight: 800;
}
.kitchen-layout--cook .kitchen-notes {
  margin: 10px 12px 12px;
  flex-shrink: 0;
  text-align: center;
}

@media (max-width: 960px) {
  .kitchen-layout {
    grid-template-columns: 1fr;
  }
  .kitchen-layout--cook {
    max-height: none;
  }
  .kitchen-layout--cook .kitchen-sidebar,
  .kitchen-layout--cook .kitchen-main {
    max-height: none;
  }
}
.kitchen-sidebar {
  padding: 16px;
}
.kitchen-search {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  margin-bottom: 12px;
  font: inherit;
}
.kitchen-list-wrap {
  max-height: min(52vh, 520px);
  overflow: auto;
  margin-bottom: 12px;
}
.kitchen-pick-table {
  font-size: 0.88rem;
}
.kitchen-portions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
}
.kitchen-portions-row input[type="number"] {
  width: 88px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-top: 6px;
  font: inherit;
}
.kitchen-main {
  min-width: 0;
}
.kitchen-sheet {
  padding: 0;
  overflow: hidden;
}
.kitchen-hero {
  background: #ffffff;
  color: #0f172a;
  padding: 22px 26px 26px;
  border-bottom: 4px solid var(--kitchen-red, #c40000);
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
}
.kitchen-hero-grid {
  display: grid;
  grid-template-columns: minmax(180px, 280px) 1fr minmax(140px, 240px);
  gap: 24px;
  align-items: center;
}
@media (max-width: 720px) {
  .kitchen-hero-grid {
    grid-template-columns: 1fr;
    justify-items: center;
  }
  .kitchen-hero-brand {
    width: 100%;
    padding-right: 0;
  }
  .kitchen-hero-shot {
    justify-self: center;
    max-width: 280px;
  }
}
.kitchen-hero-grid--no-photo {
  grid-template-columns: minmax(180px, 280px) 1fr;
}
.kitchen-hero-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  min-width: 0;
  padding: 4px 12px 4px 0;
}
.kitchen-hero-copy {
  min-width: 0;
}
.kitchen-hero-brand .kitchen-logo {
  margin: 0;
}
.kitchen-logo {
  display: block;
  width: min(280px, 100%);
  max-height: 88px;
  height: auto;
  object-fit: contain;
  margin: 0 0 14px;
  padding: 8px 14px;
  background: #fff;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 5px rgba(15, 23, 42, 0.07);
  filter: none;
}
.kitchen-hero-shot {
  border-radius: 14px;
  overflow: hidden;
  background: var(--kitchen-red-soft, #fef2f2);
  border: 2px solid var(--kitchen-red-line, #fecaca);
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
}
.kitchen-hero-shot img {
  width: 100%;
  height: 100%;
  max-height: 220px;
  object-fit: cover;
  display: block;
}
.kitchen-title {
  margin: 0 0 8px;
  font-size: 1.65rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--kitchen-red-dark, #9f0000);
}
.kitchen-meta {
  margin: 0 0 10px;
  font-size: 0.95rem;
  color: #64748b;
  opacity: 1;
}
.kitchen-target-portions {
  margin: 4px 0 18px;
  padding: 18px 20px;
  background: var(--kitchen-red-soft, #fef2f2);
  border-radius: 14px;
  border: 2px solid var(--kitchen-red-line, #fecaca);
  box-shadow: none;
}
.kitchen-target-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kitchen-red-text, #7f1d1d);
  margin-bottom: 10px;
}
.kitchen-target-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px 14px;
}
.kitchen-target-value {
  font-size: clamp(2.75rem, 6vw, 4rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--kitchen-red, #c40000);
  text-shadow: none;
}
.kitchen-target-unit {
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--kitchen-red-dark, #9f0000);
}
.kitchen-badge {
  background: var(--kitchen-red, #c40000);
  color: #fff;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 0.95rem;
  line-height: 1.45;
}
.kitchen-badge strong {
  color: #fff;
}
.kitchen-allergens {
  margin: 16px 24px;
  padding: 14px 18px;
  background: var(--kitchen-red-soft, #fef2f2);
  border: 1px solid var(--kitchen-red-line, #fecaca);
  border-radius: 12px;
  color: var(--kitchen-red-text, #7f1d1d);
  font-size: 0.92rem;
  line-height: 1.45;
}
.kitchen-allergens strong {
  color: var(--kitchen-red-dark, #9f0000);
}
.kitchen-ing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.kitchen-ing-table th,
.kitchen-ing-table td {
  padding: 12px 16px;
  border-bottom: 1px solid #e2e8f0;
}
.kitchen-ing-table thead th {
  background: #f8fafc;
  font-weight: 700;
  text-align: left;
  color: #475569;
}
.kitchen-th-sub {
  display: block;
  font-weight: 600;
  font-size: 0.68rem;
  color: #64748b;
  margin-top: 4px;
  line-height: 1.25;
  text-transform: none;
  letter-spacing: 0;
}
.kitchen-ing-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.kitchen-qty-net {
  font-weight: 600;
  color: #0f172a;
}
.kitchen-qty-bruta {
  font-weight: 700;
  color: var(--kitchen-red-dark, #9f0000);
}
.kitchen-notes {
  margin: 12px 12px 16px;
  padding: 12px 14px;
  background: var(--kitchen-red-soft, #fef2f2);
  border-radius: 12px;
  border: 1px solid var(--kitchen-red-line, #fecaca);
}
.kitchen-notes-body {
  margin-top: 8px;
  white-space: pre-wrap;
  line-height: 1.5;
}
.kitchen-placeholder {
  padding: 48px 24px;
  text-align: center;
}

/* ── Panel Costes (estilo informe Alexandre / resumen Excel) ──────────── */
.costes-view {
  --costes-red: #c00000;
  --costes-green: #2d5939;
  --costes-navy: #002060;
  max-width: 1280px;
  margin: 0 auto;
  padding-bottom: 32px;
}

.costes-hero {
  background: #ffffff;
  border: 1px solid #dbeafe;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px 24px 16px;
  margin-bottom: 18px;
}

/* Cabecera tipo hoja RESUMEN: logo + franja verde corporativa */
.costes-report-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 3px solid var(--costes-green);
}

.costes-brand-logo {
  width: 148px;
  height: auto;
  max-height: 58px;
  object-fit: contain;
  flex-shrink: 0;
}

.costes-report-banner-spacer {
  width: 148px;
  flex-shrink: 0;
}

.costes-hero-titles {
  flex: 1;
  text-align: center;
  min-width: 0;
}

.costes-report-hotel {
  margin: 0 0 4px;
  font-size: 0.94rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.01em;
}

.costes-report-main-title {
  margin: 0;
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--costes-navy);
  text-transform: uppercase;
}

.costes-report-kicker {
  margin: 8px 0 0;
  font-size: 0.8rem;
  font-weight: 500;
  color: #707784;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.costes-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
  padding-top: 4px;
}

.costes-pill {
  appearance: none;
  border: 1px solid #cdd6e8;
  background: #fff;
  color: var(--costes-navy);
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, box-shadow 0.15s, color 0.15s;
}

.costes-pill:hover {
  border-color: var(--costes-green);
  background: rgba(45, 89, 57, 0.06);
  color: var(--costes-green);
}

.costes-pill.is-active {
  background: var(--costes-red);
  color: #fff;
  border-color: var(--costes-red);
  box-shadow: 0 4px 14px rgba(192, 0, 0, 0.28);
}

.costes-pill[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}

.costes-sheet-subline {
  margin: 0 0 14px;
  line-height: 1.5;
  font-size: 0.82rem;
  color: var(--costes-navy);
  opacity: 0.85;
}

.costes-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.costes-kpi {
  background: linear-gradient(180deg, #ffffff 0%, #fafbfc 100%);
  border-radius: var(--radius);
  border: 1px solid #dbeafe;
  border-left: 3px solid var(--costes-green);
  padding: 14px 16px;
  box-shadow: 0 4px 16px rgba(0, 32, 96, 0.05);
}

.costes-kpi-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--costes-navy);
  margin-bottom: 6px;
}

.costes-kpi-value {
  font-size: 1.35rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: #1e293b;
  line-height: 1.2;
}

/* Coste medio M.P.+P.C: mismo protagonismo que fila Total en Excel */
.costes-kpi[data-kpi-key="avg_mp_pc"] .costes-kpi-value:not(.is-gap-pos):not(.is-gap-neg) {
  color: var(--costes-red);
}

.costes-kpi[data-kpi-key="avg_mp_pc"] {
  border-left-color: var(--costes-red);
}

.costes-kpi-value.is-gap-pos {
  color: #b45309;
}

.costes-kpi-value.is-gap-neg {
  color: var(--costes-green);
}

.costes-kpi-hint {
  margin-top: 8px;
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1.35;
}

.costes-chart-card {
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid #dbeafe;
  border-top: 3px solid var(--costes-green);
  padding: 16px 18px 12px;
  margin-bottom: 18px;
  box-shadow: 0 4px 16px rgba(0, 32, 96, 0.06);
}

.costes-chart-card h3 {
  margin: 0 0 12px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--costes-navy);
  letter-spacing: 0.02em;
}

.costes-chart-wrap {
  position: relative;
  height: 240px;
}

.costes-detail-card {
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid #dbeafe;
  border-left: 4px solid var(--costes-red);
  padding: 16px 18px 20px;
  box-shadow: 0 4px 16px rgba(0, 32, 96, 0.05);
}

.costes-detail-card summary {
  cursor: pointer;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--costes-navy);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.costes-detail-card summary::-webkit-details-marker {
  display: none;
}

.costes-detail-hint {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--muted);
}

.costes-table-wrap {
  margin-top: 14px;
  border-radius: 8px;
  overflow: auto;
  max-height: 480px;
  border: 1px solid #94a3b8;
  background: #ffffff;
}

.costes-table-wrap table.costes-sheet-table,
.costes-table-wrap table {
  margin: 0;
  min-width: max(100%, 760px);
  border-collapse: separate;
  border-spacing: 0;
  table-layout: auto;
}

/* Tabla tipo informe: tipografía de cifras y rejilla ordenada */
.costes-table-wrap .data-table.costes-sheet-table,
.costes-table-wrap .costes-sheet-table.data-table {
  font-size: 0.8125rem;
  line-height: 1.4;
}

.costes-table-wrap .costes-sheet-table thead th,
.costes-table-wrap .costes-sheet-table tbody td {
  border-right: 1px solid #d1dae6;
  border-bottom: 1px solid #d1dae6;
  vertical-align: middle;
}

.costes-table-wrap .costes-sheet-table thead th:last-child,
.costes-table-wrap .costes-sheet-table tbody td:last-child {
  border-right: none;
}

.costes-table-wrap .costes-sheet-table tbody tr:last-child td {
  border-bottom: none;
}

.costes-table-wrap .costes-sheet-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 11px 10px;
  background: linear-gradient(180deg, #f0f5fb 0%, #e8eef6 100%);
  color: var(--costes-navy);
  font-weight: 800;
  font-size: 0.6875rem;
  font-family: inherit;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
  box-shadow: inset 0 -3px 0 var(--costes-green);
}

.costes-table-wrap .costes-sheet-table thead th:first-child {
  text-align: left;
  padding-left: 14px;
  min-width: 14rem;
}

.costes-table-wrap .costes-sheet-table thead th.num {
  text-align: right;
  padding-right: 12px;
  min-width: 4.35rem;
}

.costes-table-wrap .costes-sheet-table thead th:last-child.num {
  font-weight: 800;
  color: var(--costes-red);
}

.costes-table-wrap .costes-sheet-table tbody td {
  padding: 8px 10px;
}

.costes-table-wrap .costes-sheet-table tbody td:first-child {
  text-align: left;
  padding-left: 14px;
  padding-right: 14px;
  font-weight: 600;
  color: #0f172a;
  overflow-wrap: anywhere;
  word-break: normal;
}

.costes-table-wrap .costes-sheet-table tbody td.num {
  padding-left: 8px;
  padding-right: 12px;
  text-align: right;
  font-weight: 500;
  color: #1e293b;
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum", "lnum";
  letter-spacing: 0.015em;
  white-space: nowrap;
}

.costes-table-wrap .costes-sheet-table tbody tr {
  cursor: default;
}

/* Filas alternas (no totales / diff / ppt / bloque por servicio) */
.costes-table-wrap .costes-sheet-table tbody tr.costes-row:nth-child(even):not(.costes-row--total):not(.costes-row--diff):not(.costes-row--budget_meta):not(.costes-row--unit_cost) td {
  background: rgba(248, 250, 252, 0.95);
}

.costes-table-wrap
  .costes-sheet-table
  tbody
  tr.costes-row:hover:not(.costes-row--total):not(.costes-row--diff):not(.costes-row--budget_meta):not(
    .costes-row--unit_cost
  )
  td {
  background: rgba(0, 32, 96, 0.055) !important;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta:hover td {
  filter: brightness(0.98);
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_cost:hover td {
  background: rgba(30, 64, 175, 0.08) !important;
}

.costes-table-wrap .costes-sheet-table thead th:first-child,
.costes-table-wrap .costes-sheet-table tbody td:first-child {
  border-left: 1px solid #d1dae6;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--stays td:first-child {
  border-left: 4px solid var(--costes-green);
  padding-left: 10px;
}

/* ── Bloque costes por servicio (restaurante · desayuno) ───────────────── */
.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_cost td {
  vertical-align: middle;
  border-color: #c9d4e8 !important;
  background: linear-gradient(90deg, rgba(30, 64, 175, 0.07) 0%, rgba(248, 250, 252, 0.97) 48%) !important;
  font-variant-numeric: tabular-nums lining-nums;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_cost td:first-child {
  padding: 11px 12px;
  padding-left: 12px !important;
  border-left: 5px solid #1e40af !important;
  font-weight: 700;
  color: #0f2244;
  line-height: 1.42;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_block_start td {
  box-shadow: inset 0 3px 0 0 #2563eb;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_block_end td {
  box-shadow: inset 0 -2px 0 0 rgba(37, 99, 235, 0.45);
  padding-bottom: 13px !important;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--unit_cost td.num {
  font-weight: 700;
  color: #152b45;
  font-size: 0.825rem;
  letter-spacing: 0.02em;
}

/* ── Filas Presupuesto (ppto): muy visibles frente al resto del informe ─ */
.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td {
  vertical-align: middle;
  padding-top: 13px;
  padding-bottom: 12px;
  border-color: #d1dee8 !important;
  color: #1a2744;
  font-weight: 600;
  font-variant-numeric: tabular-nums lining-nums;
  box-shadow: inset 0 3px 0 0 var(--costes-navy);
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td:first-child {
  position: relative;
  font-weight: 800;
  color: #102a57;
  font-size: 0.84rem;
  background: linear-gradient(180deg, #e2ebf5 0%, #eef2f7 40%) !important;
  border-left: 5px solid var(--costes-navy) !important;
  padding: 12px 14px 12px 12px;
  line-height: 1.35;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td:first-child::before {
  content: "Presupuesto · referencia";
  display: table;
  margin-bottom: 5px;
  width: max-content;
  max-width: 100%;
  font-size: 0.615rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: var(--costes-navy);
  padding: 3px 7px;
  border-radius: 4px;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td:nth-child(2) {
  background: linear-gradient(180deg, #e8f0f9 0%, #eef2f7 45%) !important;
  font-weight: 700;
}

/* Meses y anual: franjas + cifras muy legibles (ppto = referencia económica) */
.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td:nth-child(n + 3):nth-child(odd) {
  background: linear-gradient(180deg, #fdfefe 0%, #ffffff 55%) !important;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td:nth-child(n + 3):nth-child(even) {
  background: linear-gradient(180deg, #f2f6fb 0%, #f0f4f8 55%) !important;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td.num {
  color: var(--costes-navy);
  font-weight: 800;
  font-size: 0.8375rem;
  letter-spacing: 0.02em;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--budget_meta td.num:last-child {
  background: linear-gradient(180deg, #e8eef8 0%, #dee8f4 100%) !important;
  color: #001a4d;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--total td {
  font-weight: 800;
  color: var(--costes-red);
  background: rgba(192, 0, 0, 0.09);
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--total td.num {
  font-weight: 800;
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--diff td {
  font-weight: 700;
  color: #0f172a;
  background: rgba(45, 89, 57, 0.08);
}

.costes-table-wrap .costes-sheet-table tbody tr.costes-row--diff td.num {
  font-weight: 800;
}

/* Fallback si la tabla no tiene la clase nueva */
.costes-table-wrap .data-table:not(.costes-sheet-table) th,
.costes-table-wrap .data-table:not(.costes-sheet-table) td {
  border: 1px solid #c5cdd8;
}
.costes-table-wrap .costes-sheet-table tbody tr.costes-row--diff td.num.costes-num--pos {
  color: var(--costes-red) !important;
  font-weight: 800;
}

/* Verde visible sobre el fondo de la fila (no solo forestry oscuro). */
.costes-table-wrap .costes-sheet-table tbody tr.costes-row--diff td.num.costes-num--neg {
  color: #067647 !important;
  font-weight: 800;
}

.costes-footnote {
  margin-top: 18px;
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.5;
  padding: 12px 14px;
  background: rgba(100, 116, 139, 0.07);
  border-radius: 10px;
  border: 1px dashed #cbd5e1;
}

@media print {
  #sidebar,
  .sidebar-toggle,
  #btn-sidebar-toggle,
  #btn-logout,
  #toast,
  .no-print {
    display: none !important;
  }
  .shell-main {
    margin: 0 !important;
    padding: 12px !important;
  }
  .kitchen-sidebar {
    display: none !important;
  }
  .kitchen-layout {
    display: block !important;
  }
  .kitchen-main {
    width: 100% !important;
  }
  .kitchen-sheet {
    box-shadow: none !important;
    border: 1px solid #ccc !important;
  }
  .kitchen-layout--cook {
    max-height: none !important;
  }
  .kitchen-layout--cook .kitchen-sidebar,
  .kitchen-layout--cook .kitchen-main {
    max-height: none !important;
  }
  .kitchen-table-scroll {
    overflow: visible !important;
  }
  .kitchen-hero {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}
.corp-filter-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted, #64748b);
}
.corp-type-tab {
  border: 1px solid var(--border, #e2e8f0);
  background: var(--surface, #fff);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.8rem;
  cursor: pointer;
}
.corp-type-tab.active {
  border-color: var(--accent, #2563eb);
  color: var(--accent, #2563eb);
  background: rgba(37, 99, 235, 0.08);
}
.corp-hotel-chip {
  text-align: left;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 6px;
  padding: 6px 8px;
  font-size: 0.85rem;
  cursor: pointer;
  color: var(--text, #0f172a);
}
.corp-hotel-chip:hover {
  background: rgba(15, 23, 42, 0.04);
}
.corp-hotel-chip.active {
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.25);
  font-weight: 600;
}
.corp-hotel-pick {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  padding: 4px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  cursor: pointer;
  user-select: none;
  transition: all 0.12s ease;
}
.corp-hotel-pick input {
  margin: 0;
  accent-color: var(--accent, #2563eb);
}
.corp-hotel-pick:hover {
  border-color: var(--accent, #2563eb);
}
.corp-hotel-pick.active {
  background: rgba(37, 99, 235, 0.08);
  border-color: var(--accent, #2563eb);
  color: var(--accent, #2563eb);
  font-weight: 600;
}
.menu-erp-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.menu-erp-section-head-actions {
  display: flex;
  gap: 8px;
}
@media print {
  .menu-erp-toolbar,
  .menu-erp-photo-actions { display: none !important; }
}

/* ---- Toggle segmentado (Activas | Todas) ---- */
.seg-toggle {
  display: inline-flex;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 6px;
  overflow: hidden;
}
.seg-btn {
  background: #fff;
  border: 0;
  padding: 4px 12px;
  font-size: 0.82rem;
  cursor: pointer;
  color: var(--muted, #64748b);
}
.seg-btn + .seg-btn {
  border-left: 1px solid var(--border, #e2e8f0);
}
.seg-btn:hover {
  background: var(--surface-2, #f8fafc);
}
.seg-btn.active {
  background: var(--accent, #2563eb);
  color: #fff;
}

.panel-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Módulo Pantallas (placeholder) */
.pantallas-empty {
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
}
.pantallas-empty-title {
  margin: 0 0 4px 0;
}

.compras-empty {
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  text-align: center;
}
.compras-empty-icon {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: rgba(37, 99, 235, 0.08);
  color: var(--accent, #2563eb);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
}
.compras-empty-title {
  margin: 0;
  font-size: 1.5rem;
}
.compras-empty-tag {
  display: inline-block;
  margin: 0;
  padding: 4px 12px;
  background: rgba(234, 179, 8, 0.18);
  color: #a16207;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.compras-empty-desc {
  max-width: 520px;
  margin: 6px 0 0;
  line-height: 1.5;
}

/* ───────────────────────────────────────────────────────────────────────────
 * RESPONSIVE: móvil + tablet + PWA standalone
 * ───────────────────────────────────────────────────────────────────────────
 * Estrategia:
 *  - Sidebar visible en desktop (>=900px); en móvil/tablet se convierte en
 *    cajón deslizable fijo con backdrop. La clase .sidebar-open la añade el JS.
 *  - Topbar fija para no perder el botón de menú al scrollear.
 *  - Tablas de datos siempre con scroll horizontal en su contenedor.
 *  - Safe-area-insets (notch iOS) en login, sidebar y shell-main.
 */
.sidebar-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.5);
  z-index: 60;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.sidebar-backdrop[hidden] {
  display: none !important;
}
.sidebar-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

@supports (padding: max(0px)) {
  #app:not(.is-authenticated) {
    padding-top: max(48px, env(safe-area-inset-top));
    padding-bottom: max(24px, env(safe-area-inset-bottom));
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
  .shell-main {
    padding-left: max(18px, env(safe-area-inset-left));
    padding-right: max(18px, env(safe-area-inset-right));
    padding-bottom: max(40px, env(safe-area-inset-bottom));
  }
}

/* iOS evita auto-zoom en inputs solo si fuente >=16px */
@media (max-width: 900px) {
  input[type="text"],
  input[type="password"],
  input[type="search"],
  input[type="number"],
  input[type="date"],
  input[type="email"],
  select,
  textarea {
    font-size: 16px;
    padding: 9px 11px;
  }
  .btn,
  .nav-btn {
    min-height: 44px;
  }
  .app-topbar {
    padding: 0 10px;
    gap: 10px;
  }
  .app-logo-badge {
    padding: 3px 7px;
  }
  .app-logo--topbar {
    height: 30px;
    max-width: 90px;
  }
  .app-topbar-brand {
    padding-right: 0;
    border-right: none;
  }
  .app-topbar-brand strong {
    font-size: 0.85rem;
  }
  .app-topbar-brand-sub {
    display: none;
  }
  .app-topbar-view h1 {
    font-size: 0.88rem;
  }
  .topbar-sub {
    display: none;
  }
  .shell-main {
    padding: 12px 12px 24px;
  }
  .view-root {
    gap: 10px;
  }
  /* (overflow-x movido a regla permanente al final de la hoja para que
     tambien funcione en desktop cuando una tabla es mas ancha que su card) */
  .module-inner-tabs,
  .tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  .module-inner-tabs .tab,
  .tabs .tab {
    flex-shrink: 0;
  }
  .eventos-subtabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  .eventos-subtab {
    flex-shrink: 0;
  }
  .hotels-split,
  .eventos-split,
  .grid-2,
  .grid-2-wide-left {
    grid-template-columns: 1fr !important;
  }
  .form-grid {
    grid-template-columns: 1fr;
  }
  .hotel-list-card,
  .event-list-card,
  .menu-list-card {
    padding: 12px;
  }
  /* Toolbar genérica: que apile en móvil */
  .toolbar,
  .hotels-toolbar,
  .eventos-toolbar {
    flex-wrap: wrap;
    gap: 8px;
  }
  .filter-select,
  .hotel-search-input {
    width: 100%;
    min-width: 0;
  }
  /* Sidebar como cajón bajo el topbar */
  .sidebar {
    position: fixed;
    top: var(--topbar-h);
    left: 0;
    bottom: 0;
    width: min(78vw, 300px);
    max-width: 300px;
    height: calc(100vh - var(--topbar-h));
    margin: 0;
    border-radius: 0;
    border-right: 1px solid var(--border);
    z-index: 70;
    transform: translateX(-100%);
    transition: transform 0.22s ease;
    padding: 12px 8px;
    padding-bottom: max(18px, env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.18);
  }
  .shell.sidebar-open .sidebar {
    transform: translateX(0);
  }
  .shell-main {
    margin-left: 0 !important;
  }
  /* En móvil ignoramos el colapsado de desktop (cajón siempre oculto por defecto) */
  .shell.sidebar-collapsed .sidebar {
    width: min(78vw, 300px);
    padding: 12px 8px;
    border-right: 1px solid var(--border);
    opacity: 1;
    pointer-events: auto;
    overflow-y: auto;
  }
  .sidebar-backdrop {
    top: var(--topbar-h);
  }
}

@media (max-width: 560px) {
  .login-card {
    margin: 24px auto;
    padding: 22px;
  }
  .app-logo--login {
    max-height: 96px;
    margin-bottom: 14px;
  }
  .login-card h1 {
    font-size: 1.3rem;
  }
  .app-topbar-view h1 {
    font-size: 0.85rem;
  }
  .hotels-list-card .hotel-list-stats,
  .hotels-list-card .hotel-list-loc {
    font-size: 0.72rem;
  }
}

/* ===================================================================
 *  Módulo Menús (v2): lista + detalle matriz categoría × día + import
 * =================================================================== */
.menus-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 16px;
  align-items: stretch;
}
.menus-list-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 160px);
  overflow: hidden;
}
.menus-filters {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.menus-filters .filter-input,
.menus-filters .filter-select {
  padding: 6px 10px;
  font-size: 0.9rem;
}
.menus-list-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
  padding-right: 4px;
}
.menus-list-empty {
  padding: 24px 12px;
  text-align: center;
  font-style: italic;
}
.menus-list-card {
  text-align: left;
  background: var(--card, #fff);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 10px 12px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: inherit;
  transition: border-color 0.12s, box-shadow 0.12s, transform 0.06s;
}
.menus-list-card:hover {
  border-color: var(--accent, #2563eb);
  box-shadow: 0 4px 10px rgba(37, 99, 235, 0.08);
}
.menus-list-card.selected {
  border-color: var(--accent, #2563eb);
  background: rgba(37, 99, 235, 0.05);
  box-shadow: 0 4px 10px rgba(37, 99, 235, 0.12);
}
.menus-list-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.menus-list-card-date {
  font-size: 0.7rem;
  color: var(--muted, #64748b);
}
.menus-list-card-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--text, #0f172a);
  line-height: 1.25;
}
.menus-list-card-meta {
  font-size: 0.75rem;
}
.menus-list-card-hotels {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.menu-hotel-chip {
  display: inline-block;
  background: rgba(100, 116, 139, 0.1);
  color: var(--text-2, #475569);
  border: 1px solid rgba(100, 116, 139, 0.2);
  border-radius: 999px;
  padding: 1px 8px;
  font-size: 0.72rem;
  font-weight: 600;
}
.menu-hotel-chip em {
  font-style: normal;
  color: var(--muted, #64748b);
  font-weight: 500;
  margin-left: 4px;
}
.menu-hotel-chip--more {
  background: rgba(100, 116, 139, 0.15);
  cursor: help;
}

.menu-kind-badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 2px 10px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475569;
}
.menu-kind-desayuno { background: #fef3c7; color: #92400e; }
.menu-kind-almuerzo { background: #dbeafe; color: #1e3a8a; }
.menu-kind-cena     { background: #ede9fe; color: #5b21b6; }
.menu-kind-postres  { background: #fce7f3; color: #9d174d; }
.menu-kind-personal { background: #d1fae5; color: #065f46; }
.menu-kind-otro     { background: #f1f5f9; color: #475569; }

.menus-detail-panel {
  min-height: 400px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.menus-detail-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--muted, #64748b);
}
.menus-detail-empty h3 {
  margin: 0 0 8px;
  font-weight: 600;
  color: var(--text, #0f172a);
}

.menu-detail-toolbar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--border, #e2e8f0);
}
.menu-sheet {
  background: #fff;
  border-radius: 8px;
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.menu-sheet-header {
  text-align: center;
}
.menu-sheet-kind {
  margin-bottom: 6px;
}
.menu-sheet-title {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
  color: var(--text, #0f172a);
  letter-spacing: 0.02em;
}
.menu-sheet-subtitle {
  font-size: 0.95rem;
  color: var(--muted, #64748b);
  margin-top: 4px;
}
.menu-sheet-name {
  font-size: 0.8rem;
  margin-top: 6px;
}
.menu-sheet-hotels {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(37, 99, 235, 0.05);
  border-radius: 8px;
  font-size: 0.85rem;
}
.menu-sheet-notes {
  font-size: 0.85rem;
  padding: 10px 12px;
  background: rgba(245, 158, 11, 0.08);
  border-left: 3px solid rgba(245, 158, 11, 0.5);
  border-radius: 4px;
}

.menu-matrix-block {
  border-radius: 8px;
  border: 1px solid var(--border, #e2e8f0);
  background: #fff;
  padding: 10px;
}
.menu-matrix-themes-info {
  font-size: 0.78rem;
  color: var(--muted, #64748b);
  margin-bottom: 6px;
}
.menu-themes-pill {
  background: #fef3c7;
  color: #92400e;
  border-radius: 999px;
  padding: 2px 10px;
  font-weight: 600;
}
.menu-matrix-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x pan-y;
  overscroll-behavior-x: contain;
  max-width: 100%;
}
.menu-matrix-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.menu-matrix-table th,
.menu-matrix-table td {
  border: 1px solid var(--border, #e2e8f0);
  padding: 6px 8px;
  vertical-align: top;
}
.menu-matrix-th-cat {
  text-align: left;
  background: var(--surface-2, #f8fafc);
  font-weight: 700;
  width: 0;
}
.menu-matrix-th-day {
  text-align: center;
  background: var(--surface-2, #f8fafc);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.78rem;
  min-width: 130px;
}
.menu-matrix-day-name {
  color: var(--text, #0f172a);
}
.menu-matrix-day-theme {
  display: block;
  font-size: 0.7rem;
  font-weight: 600;
  color: #92400e;
  margin-top: 2px;
  text-transform: none;
  letter-spacing: 0;
}
.menu-matrix-th-actions {
  width: 50px;
  background: var(--surface-2, #f8fafc);
}

.menu-matrix-cat-row td {
  background: rgba(37, 99, 235, 0.06);
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #1e3a8a;
}
.menu-matrix-cat-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}
.menu-matrix-cat-cell .menu-cat-input {
  flex: 1;
  font-weight: 700;
  text-transform: uppercase;
  background: transparent;
  border: 1px dashed transparent;
  padding: 4px 6px;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
}
.menu-matrix-cat-cell .menu-cat-input:focus {
  border-color: rgba(37, 99, 235, 0.4);
  background: #fff;
}

.menu-matrix-cell {
  font-size: 0.85rem;
  line-height: 1.35;
}
.menu-matrix-cell-spacer {
  background: var(--surface-2, #f8fafc);
  width: 0;
  padding: 0;
}
.menu-matrix-cell-actions {
  width: 50px;
  text-align: center;
}
.menu-cell-input {
  width: 100%;
  border: 1px solid transparent;
  background: transparent;
  font-family: inherit;
  font-size: 0.85rem;
  padding: 4px 6px;
  border-radius: 4px;
  resize: vertical;
  min-height: 28px;
  line-height: 1.3;
}
.menu-cell-input:focus {
  border-color: var(--accent, #2563eb);
  background: #fff;
}
.menu-theme-input {
  width: 100%;
  margin-top: 4px;
  border: 1px solid var(--border, #cbd5e1);
  background: #fff;
  padding: 2px 4px;
  font-size: 0.72rem;
  font-weight: 500;
  border-radius: 4px;
  text-align: center;
  text-transform: none;
  letter-spacing: 0;
}
.menu-block-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  margin-top: 6px;
}

.menu-edit-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
  margin-bottom: 16px;
}
.menu-edit-meta {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.menu-edit-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--muted, #64748b);
}
.menu-edit-label input,
.menu-edit-label select,
.menu-edit-label textarea {
  font-size: 0.9rem;
  padding: 6px 10px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 6px;
  font-family: inherit;
}
.menu-edit-hotels {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  max-height: 280px;
  overflow-y: auto;
}
.menu-edit-hotels-head {
  font-size: 0.85rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.menu-edit-hotels-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.85rem;
}
.menu-hotel-pick-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 6px;
  border-radius: 4px;
  cursor: pointer;
}
.menu-hotel-pick-row:hover {
  background: var(--surface-2, #f1f5f9);
}
.menu-hotel-pick-name {
  flex: 1;
}
.menu-hotel-pick-dest {
  font-size: 0.7rem;
  color: var(--muted, #64748b);
  font-weight: 600;
}

/* Modal de importación de Excel */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 16px;
}
.modal-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.25);
  width: 100%;
  max-width: 720px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.modal-head h3 {
  margin: 0;
  font-size: 1rem;
}
.modal-close {
  background: transparent;
  border: 0;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--muted, #64748b);
  padding: 0 6px;
  line-height: 1;
}
.modal-body {
  padding: 16px 18px;
  overflow-y: auto;
  flex: 1;
}
.modal-footer {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 12px 18px;
  border-top: 1px solid var(--border, #e2e8f0);
}
.modal-help {
  margin: 0 0 10px;
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--muted, #64748b);
}

.menu-import-modal { max-width: 760px; }
.menu-import-items {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.menu-import-item {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.menu-import-item-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.menu-import-include-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 0.85rem;
}
.menu-import-item-grid {
  display: grid;
  grid-template-columns: 1fr 180px;
  gap: 10px;
}
.menu-import-hotels-block summary {
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
}
.menu-import-hotels-list {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.85rem;
  max-height: 220px;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 6px;
}

@media (max-width: 1100px) {
  .menus-layout {
    grid-template-columns: 1fr;
  }
  .menus-list-panel {
    max-height: 380px;
  }
}
@media (max-width: 760px) {
  .menu-edit-grid {
    grid-template-columns: 1fr;
  }
  .menu-import-item-grid {
    grid-template-columns: 1fr;
  }
}

/* ===================================================================
 *  Módulo Auditorías
 * =================================================================== */
.audit-inner-tabs {
  margin-bottom: 12px;
}
.audit-module-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.audit-layout {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  width: 100%;
}
.audit-list-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: calc(100vh - 220px);
  overflow: hidden;
}
.audit-filters {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
}
.audit-filters .filter-select {
  padding: 6px 10px;
  font-size: 0.85rem;
  min-width: 0;
}
.audit-list-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
  padding-right: 4px;
}
.audit-list-card {
  position: relative;
}
.audit-list-card-foot {
  margin-top: 4px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.audit-list-score {
  font-weight: 800;
  font-size: 1.05rem;
}
.audit-list-progress {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--accent, #2563eb);
  background: rgba(37, 99, 235, 0.08);
  padding: 2px 8px;
  border-radius: 999px;
}

.audit-status-badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  background: #f1f5f9;
  color: #475569;
}
.audit-status-progress { background: rgba(245, 158, 11, 0.15); color: #92400e; }
.audit-status-completed { background: rgba(16, 185, 129, 0.15); color: #065f46; }
.audit-status-discarded { background: rgba(100, 116, 139, 0.15); color: #475569; }

.audit-score-good { color: #047857; }
.audit-score-mid  { color: #b45309; }
.audit-score-bad  { color: #b91c1c; }
.audit-score-na   { color: var(--muted, #64748b); }

.audit-detail-panel {
  min-height: 400px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.audit-detail {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.audit-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border, #e2e8f0);
}
.audit-header > div:first-child {
  flex: 1 1 0;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-header-title {
  margin: 0 0 4px;
  font-size: 1.2rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-header-sub {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
}
.audit-header-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.audit-progress {
  display: flex;
  align-items: center;
  gap: 12px;
}
.audit-progress-bar {
  flex: 1;
  height: 8px;
  background: var(--surface-2, #f1f5f9);
  border-radius: 999px;
  overflow: hidden;
}
.audit-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent, #2563eb), #4f46e5);
  transition: width 0.3s ease;
}
.audit-progress-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--muted, #64748b);
}

/* ============== Auditoria EN CURSO: header sticky + grupos categoria ============== */
.audit-sticky-top {
  position: sticky;
  top: 0;
  z-index: 5;
  background: var(--card, #ffffff);
  padding-top: 4px;
  padding-bottom: 12px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.audit-header-info {
  flex: 1 1 0;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-header-menu {
  margin-top: 4px;
  font-size: 0.8rem;
  color: var(--text, #0f172a);
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.35;
}
.audit-progress-wrap {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.audit-progress-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-weight: 700;
}
.audit-progress-count {
  font-size: 0.95rem;
  color: var(--text, #0f172a);
}
.audit-progress-pct {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--accent, #2563eb);
  letter-spacing: -0.02em;
}
.audit-progress-wrap .audit-progress-bar {
  height: 10px;
}

.audit-cat-groups {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 14px;
  container-type: inline-size;
  container-name: audit-q-list;
}
.audit-cat-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.audit-cat-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  background: linear-gradient(90deg, rgba(37,99,235,0.08), rgba(37,99,235,0.0));
  border-left: 3px solid var(--accent, #2563eb);
  border-radius: 4px;
}
.audit-cat-group.is-done .audit-cat-head {
  background: linear-gradient(90deg, rgba(16,185,129,0.10), rgba(16,185,129,0.0));
  border-left-color: #10b981;
}
.audit-cat-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text, #0f172a);
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-cat-progress {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--muted, #64748b);
  flex-shrink: 0;
}
.audit-cat-group.is-done .audit-cat-progress {
  color: #047857;
}
.audit-cat-done-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: #10b981;
  color: white;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 800;
}
.audit-cat-questions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.audit-questions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  container-type: inline-size;
  container-name: audit-q-list;
}
/* Layout SIEMPRE apilado: número+texto arriba, botones debajo.
   Evita cualquier superposición cuando el panel detalle es estrecho. */
.audit-question-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  background: #fff;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
.audit-question-card:hover {
  box-shadow: 0 1px 6px rgba(0,0,0,0.05);
}
.audit-question-card.audit-pending {
  border-left: 4px solid var(--accent, #2563eb);
}
.audit-question-card.audit-answered {
  background: rgba(241, 245, 249, 0.5);
}
.audit-question-card.audit-answered-yes { border-left: 4px solid #10b981; }
.audit-question-card.audit-answered-no  { border-left: 4px solid #ef4444; }
.audit-question-card.audit-answered-na  { border-left: 4px solid #94a3b8; }
.audit-q-num {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: var(--accent, #2563eb);
  background: rgba(37, 99, 235, 0.08);
  border-radius: 50%;
  font-size: 0.78rem;
}
.audit-question-card.audit-answered-yes .audit-q-num {
  color: #047857;
  background: rgba(16,185,129,0.12);
}
.audit-question-card.audit-answered-no .audit-q-num {
  color: #b91c1c;
  background: rgba(239,68,68,0.12);
}
.audit-question-card.audit-answered-na .audit-q-num {
  color: #64748b;
  background: rgba(148,163,184,0.18);
}
.audit-q-body {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.audit-q-cat {
  display: block;
  width: 100%;
  min-width: 0;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-q-text {
  display: block;
  width: 100%;
  min-width: 0;
  font-size: 0.88rem;
  line-height: 1.3;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-q-text strong {
  display: inline;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.audit-q-answers {
  flex: 0 0 auto;
  display: flex;
  gap: 4px;
}
.audit-answer-btn {
  border: 1.5px solid var(--border, #e2e8f0);
  background: #fff;
  color: var(--text, #0f172a);
  border-radius: 6px;
  font-weight: 700;
  padding: 5px 8px;
  cursor: pointer;
  font-size: 0.72rem;
  font-family: inherit;
  letter-spacing: 0.04em;
  transition: all 0.12s;
  flex: 0 0 auto;
  min-width: 38px;
  line-height: 1;
}
.audit-answer-btn:hover:not(:disabled) {
  transform: translateY(-1px);
}
.audit-answer-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
/* Tenues por defecto: color semantico pero suave (asi se distingue a 1ª vista) */
.audit-answer-yes { color: #047857; border-color: rgba(16,185,129,0.35); }
.audit-answer-no  { color: #b91c1c; border-color: rgba(239,68,68,0.35); }
.audit-answer-na  { color: #475569; border-color: rgba(148,163,184,0.45); }
/* Hover: fondo tenue del color */
.audit-answer-yes:hover:not(:disabled) { background: rgba(16, 185, 129, 0.10); border-color: #10b981; }
.audit-answer-no:hover:not(:disabled)  { background: rgba(239, 68, 68, 0.10); border-color: #ef4444; }
.audit-answer-na:hover:not(:disabled)  { background: rgba(148, 163, 184, 0.15); border-color: #94a3b8; }
/* Seleccionado: lleno con color vivo */
.audit-answer-yes.is-active { background: #10b981; color: #fff; border-color: #047857; box-shadow: 0 2px 6px rgba(16,185,129,0.30); }
.audit-answer-no.is-active  { background: #ef4444; color: #fff; border-color: #b91c1c; box-shadow: 0 2px 6px rgba(239,68,68,0.30); }
.audit-answer-na.is-active  { background: #94a3b8; color: #fff; border-color: #64748b; box-shadow: 0 2px 6px rgba(148,163,184,0.30); }

/* Las cards de pregunta SIEMPRE en una sola línea (num + texto + botones).
   En pantallas muy estrechas el flex permite que los botones bajen via wrap
   solo si realmente no caben. */
@media (max-width: 420px) {
  .audit-q-answers {
    flex-wrap: wrap;
  }
}

.audit-footer-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  background: var(--surface-2, #f8fafc);
  border-radius: 8px;
  position: sticky;
  bottom: 0;
}
.btn-lg { padding: 10px 24px; font-size: 0.95rem; font-weight: 700; }

/* --- Auditoría completada --- */
.audit-score-card {
  padding: 28px 20px;
  background: linear-gradient(135deg, #fff 0%, var(--surface-2, #f8fafc) 100%);
  border: 2px solid var(--border, #e2e8f0);
  border-radius: 12px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}
.audit-score-card.audit-score-good { border-color: #10b981; background: linear-gradient(135deg, #fff, #ecfdf5); }
.audit-score-card.audit-score-mid  { border-color: #f59e0b; background: linear-gradient(135deg, #fff, #fffbeb); }
.audit-score-card.audit-score-bad  { border-color: #ef4444; background: linear-gradient(135deg, #fff, #fef2f2); }
.audit-score-big {
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
}
.audit-score-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--muted, #64748b);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.audit-score-counts {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 0.9rem;
  font-weight: 600;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
}
.audit-count-yes { color: #047857; }
.audit-count-no  { color: #b91c1c; }
.audit-count-na  { color: #64748b; }

.audit-result-cats {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.audit-result-cat {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  padding: 10px 12px;
}
.audit-result-cat-title {
  margin: 0 0 8px;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted, #64748b);
  font-weight: 700;
}
.audit-result-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.audit-result-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 0.88rem;
  align-items: center;
}
.audit-result-yes { background: rgba(16, 185, 129, 0.08); }
.audit-result-no  { background: rgba(239, 68, 68, 0.08); }
.audit-result-na  { background: rgba(148, 163, 184, 0.1); }
.audit-result-answer {
  font-weight: 800;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.7);
}
.audit-result-yes .audit-result-answer { color: #047857; }
.audit-result-no  .audit-result-answer { color: #b91c1c; }
.audit-result-na  .audit-result-answer { color: #64748b; }

/* --- Modal nueva auditoría --- */
.audit-new-modal .modal-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.audit-new-modal .menu-edit-label {
  width: 100%;
}

/* --- Análisis --- */
/* ── Banner de contexto en análisis ── */
.audit-context-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 0.88rem;
  border: 1px solid;
}
.audit-context-banner--menu {
  background: rgba(59, 130, 246, 0.07);
  border-color: rgba(59, 130, 246, 0.25);
  color: #1e40af;
}
.audit-context-banner--buffet {
  background: rgba(251, 146, 60, 0.08);
  border-color: rgba(251, 146, 60, 0.3);
  color: #9a3412;
}
.audit-context-icon { font-size: 1.1rem; }
.audit-context-desc {
  font-size: 0.78rem;
  opacity: 0.8;
  margin-left: 2px;
}
@media (max-width: 500px) {
  .audit-context-desc { display: none; }
}

/* ── Audit type toggle (analytics) ── */
.audit-analytics-type-toggle {
  display: flex;
  gap: 6px;
  padding: 4px;
  background: var(--bg-card, #f8fafc);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  width: fit-content;
}
.audit-type-tab {
  padding: 7px 18px;
  border: none;
  border-radius: 7px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  background: transparent;
  color: var(--muted, #64748b);
  transition: background 0.15s, color 0.15s;
}
.audit-type-tab.is-active {
  background: var(--primary, #3b82f6);
  color: #fff;
}

/* ── Buffet closure badge ── */
.audit-type-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.buffet-badge {
  background: rgba(251, 146, 60, 0.15);
  color: #c2410c;
  border: 1px solid rgba(251, 146, 60, 0.35);
}

/* ── Badges de tipo en tarjeta de lista ── */
.audit-type-pill {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 99px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.audit-type-pill--buffet {
  background: rgba(251, 146, 60, 0.13);
  color: #c2410c;
  border: 1px solid rgba(251, 146, 60, 0.3);
}
.audit-type-pill--menu {
  background: rgba(59, 130, 246, 0.1);
  color: #1d4ed8;
  border: 1px solid rgba(59, 130, 246, 0.25);
}

/* ── Sección de foto en tarjeta buffet ── */
.audit-photo-section {
  padding: 8px 12px 10px;
  border-top: 1px solid var(--border, #e2e8f0);
  margin-top: 2px;
}
.audit-photo-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  border: 1.5px dashed var(--border, #cbd5e1);
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted, #64748b);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  width: 100%;
  justify-content: center;
}
.audit-photo-add-btn:hover {
  border-color: var(--primary, #3b82f6);
  color: var(--primary, #3b82f6);
  background: rgba(59, 130, 246, 0.04);
}
.audit-photo-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.audit-photo-thumb {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--border, #e2e8f0);
  flex-shrink: 0;
}
.audit-photo-thumb-sm {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 5px;
  border: 1px solid var(--border, #e2e8f0);
}
.audit-photo-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: center;
}
.audit-photo-time {
  font-size: 0.78rem;
  color: var(--muted, #64748b);
}
.audit-photo-change-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--primary, #3b82f6);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 5px;
  border: 1px solid rgba(59, 130, 246, 0.3);
  width: fit-content;
}
.audit-photo-change-btn:hover {
  background: rgba(59, 130, 246, 0.06);
}
.audit-photo-delete-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 6px;
  background: rgba(239, 68, 68, 0.08);
  color: #ef4444;
  font-size: 0.8rem;
  cursor: pointer;
  flex-shrink: 0;
}
.audit-photo-delete-btn:hover {
  background: rgba(239, 68, 68, 0.18);
}
.audit-result-photo {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  grid-column: 1 / -1;
}
.audit-result-row {
  flex-wrap: wrap;
}
.audit-question-buffet .audit-answer-no {
  background: rgba(251, 146, 60, 0.12);
  color: #c2410c;
  border-color: rgba(251, 146, 60, 0.4);
}
.audit-question-buffet .audit-answer-no.is-active {
  background: #ea580c;
  color: #fff;
  border-color: #ea580c;
}

.audit-analytics-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.audit-analytics-filters {
  display: flex;
  gap: 14px;
  align-items: flex-end;
  padding: 12px 14px;
}
.audit-analytics-filters .filter-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted, #64748b);
}
.audit-analytics-filters .filter-select {
  padding: 6px 10px;
  font-size: 0.9rem;
}
.audit-empty-analytics {
  padding: 60px 20px;
  text-align: center;
  font-style: italic;
}
.audit-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
}
.audit-kpi {
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.audit-kpi-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
}
.audit-kpi-value {
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1;
}
.audit-kpi-value-mini {
  font-size: 0.9rem;
  font-weight: 600;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.audit-kpi.small .audit-kpi-value { display: none; }

.audit-analytics-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.audit-analytics-grid .panel-title {
  margin-top: 0;
  font-size: 1rem;
}

.audit-bar {
  display: inline-block;
  vertical-align: middle;
  width: 90px;
  height: 6px;
  background: var(--surface-2, #f1f5f9);
  border-radius: 999px;
  overflow: hidden;
  margin-right: 6px;
}
.audit-bar-fill {
  height: 100%;
  transition: width 0.3s ease;
}
.audit-bar-fill.audit-score-good { background: #10b981; }
.audit-bar-fill.audit-score-mid  { background: #f59e0b; }
.audit-bar-fill.audit-score-bad  { background: #ef4444; }
.audit-bar-fill.audit-score-na   { background: #94a3b8; }
.audit-bar-label {
  font-weight: 700;
  font-size: 0.85rem;
}

.audit-rank-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.audit-rank-row {
  display: grid;
  grid-template-columns: 36px 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 0.9rem;
}
.audit-rank-row:nth-child(odd) { background: rgba(241, 245, 249, 0.5); }
.audit-rank-pos {
  font-weight: 800;
  color: var(--muted, #64748b);
  font-size: 1.05rem;
  text-align: center;
}
.audit-rank-name { font-weight: 600; }
.audit-rank-dest { white-space: nowrap; }
.audit-rank-score { font-weight: 800; font-size: 0.95rem; }
.audit-rank-count { grid-column: 2 / -1; font-size: 0.72rem; }

.audit-report-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 4px 4px 0;
}
.audit-report-header h2 {
  margin: 0 0 4px;
  font-size: 1.2rem;
}
.audit-report-header p { margin: 0; }
.audit-report-subtitle {
  margin: 0 0 6px !important;
  font-size: 0.95rem;
  font-weight: 600;
  color: #0f172a;
}
.audit-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 4px 0;
}
.audit-filter-chip {
  display: inline-flex;
  align-items: center;
  font-size: 0.78rem;
  color: var(--muted, #64748b);
  background: #f1f5f9;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 999px;
  padding: 2px 10px;
}
.audit-filter-chip strong {
  color: #0f172a;
  margin-left: 4px;
}
.audit-analytics-filters {
  flex-wrap: wrap;
}
.audit-an-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}
.audit-evo-panel { padding: 16px; }
.audit-evo-panel .panel-title { margin-top: 0; }
.audit-evo-chart-wrap {
  position: relative;
  width: 100%;
  height: 280px;
}
.audit-evo-table-wrap {
  margin-top: 10px;
}
.audit-evo-table-wrap summary {
  cursor: pointer;
  padding: 4px 0;
}

@media (max-width: 1100px) {
  .audit-layout { grid-template-columns: 1fr; }
  .audit-list-panel { max-height: 380px; }
  .audit-analytics-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .audit-filters { grid-template-columns: 1fr; }
  .audit-header { flex-direction: column; }
}

/* ──────────────────────────────────────────────────────────
 * Impresión / PDF del menú activo
 * ────────────────────────────────────────────────────────── */
@media print {
  @page {
    size: A4 landscape;
    margin: 12mm 10mm;
  }
  body.menu-print-mode .shell-sidebar,
  body.menu-print-mode .sidebar,
  body.menu-print-mode .app-topbar,
  body.menu-print-mode .menus-list-panel,
  body.menu-print-mode .no-print,
  body.menu-print-mode .menu-detail-toolbar,
  body.menu-print-mode .toast,
  body.menu-print-mode .sidebar-backdrop {
    display: none !important;
  }
  body.menu-print-mode .shell-main,
  body.menu-print-mode .menus-layout,
  body.menu-print-mode .menus-detail-panel {
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    background: #fff !important;
  }
  body.menu-print-mode .menus-layout {
    display: block;
  }
  .menu-sheet {
    page-break-inside: auto;
    border: 0;
    padding: 0;
  }
  .menu-matrix-block {
    page-break-inside: auto;
    border: 0;
    padding: 0;
  }
  .menu-matrix-table-wrap {
    overflow: visible;
  }
  .menu-matrix-table {
    font-size: 0.72rem;
  }
  .menu-matrix-table th,
  .menu-matrix-table td {
    padding: 3px 5px;
  }
  .menu-matrix-th-day {
    min-width: 0;
  }
}

/* ──────────────────────────────────────────────────────────
 * Impresión / PDF del informe de auditorías
 * ────────────────────────────────────────────────────────── */
@media print {
  body.printing-audit .shell-sidebar,
  body.printing-audit .sidebar,
  body.printing-audit .app-topbar,
  body.printing-audit .module-tabs,
  body.printing-audit .no-print,
  body.printing-audit .audit-analytics-filters,
  body.printing-audit .toast,
  body.printing-audit .sidebar-backdrop,
  body.printing-audit .shell-topbar,
  body.printing-audit .breadcrumbs {
    display: none !important;
  }
  body.printing-audit {
    background: #fff !important;
  }
  body.printing-audit .shell-main,
  body.printing-audit .module-content,
  body.printing-audit .audit-analytics-wrap,
  body.printing-audit .audit-analytics-body {
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    box-shadow: none !important;
  }
  body.printing-audit .card.panel {
    border: 1px solid #e2e8f0 !important;
    box-shadow: none !important;
    page-break-inside: avoid;
    break-inside: avoid;
  }
  body.printing-audit .audit-analytics-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  body.printing-audit .audit-evo-chart-wrap {
    height: 200px;
  }
  body.printing-audit .audit-evo-table-wrap[open] summary {
    display: none;
  }
  body.printing-audit .audit-kpi {
    box-shadow: none;
  }
  body.printing-audit .data-table {
    font-size: 0.72rem;
  }
  body.printing-audit .data-table th,
  body.printing-audit .data-table td {
    padding: 3px 5px;
  }
  body.printing-audit .audit-report-header h2 {
    font-size: 1.05rem;
  }
  body.printing-audit .audit-report-subtitle {
    font-size: 0.85rem;
  }
  body.printing-audit .audit-filter-chips {
    margin: 2px 0 6px;
  }
  body.printing-audit .audit-filter-chip {
    border: 1px solid #cbd5e1 !important;
    background: #f8fafc !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    font-size: 0.72rem;
  }
  body.printing-audit .audit-evo-table-wrap {
    page-break-inside: avoid;
  }
  /* Forzar fondos de barras también en impresión */
  body.printing-audit .audit-bar,
  body.printing-audit .audit-bar-fill {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

/* V4.4 — Sombra lateral indicadora de scroll horizontal en tablas */
.sub-table-wrap,
.data-table-wrap,
.menu-erp-table-wrap,
.eventos-menu-table-wrap {
  background:
    linear-gradient(to right, var(--card) 20px, transparent) left / 20px 100% no-repeat local,
    linear-gradient(to left,  var(--card) 20px, transparent) right / 20px 100% no-repeat local,
    linear-gradient(to right, rgba(15, 23, 42, 0.07), transparent) left / 8px 100% no-repeat scroll,
    linear-gradient(to left,  rgba(15, 23, 42, 0.07), transparent) right / 8px 100% no-repeat scroll;
}

/* Modo PWA standalone: oculta cualquier resto de barra de browser visual */
@media (display-mode: standalone) {
  body {
    background: var(--bg);
  }
  /* Espacio extra para la barra de estado iOS */
  .shell-main {
    padding-top: env(safe-area-inset-top);
  }
}

/* ─── Configuración → Parámetros ─── */
.config-module-body {
  display: block;
  padding-top: 4px;
}
.config-params-grid {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.config-section {
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.config-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.config-section-title {
  margin: 0 0 4px;
  font-size: 1.05rem;
  font-weight: 600;
}
.config-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px 18px;
}
.config-form-grid label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.9rem;
  font-weight: 500;
}
.config-form-grid label input[type="number"],
.config-form-grid label input[type="text"],
.config-form-grid label input[type="email"],
.config-form-grid label input[type="tel"],
.config-form-grid label input[type="url"] {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-input, var(--card));
  font-size: 0.95rem;
}
.config-form-grid label .small {
  font-weight: 400;
}

/* ============== Configuracion > Empresa (branding) ============== */
.config-empresa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 980px) {
  .config-empresa-grid {
    grid-template-columns: 1.4fr 1fr;
  }
}
.branding-preview {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border-radius: 8px;
  background: var(--bg-soft, rgba(0,0,0,0.03));
  border: 1px solid var(--border);
  margin-bottom: 16px;
}
.branding-preview-logo {
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  border-radius: 8px;
  padding: 6px;
  border: 1px solid var(--border);
  overflow: hidden;
}
.branding-preview-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.branding-preview-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.branding-preview-info strong {
  font-size: 16px;
  color: var(--text, #1f2937);
}
.branding-color-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.branding-color-row input[type="color"] {
  width: 42px;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0;
  background: transparent;
  cursor: pointer;
}
.branding-color-row input[type="text"] {
  flex: 1;
  font-family: monospace;
  font-size: 0.9rem;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-input, var(--card));
}
.branding-logo-upload {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}
.branding-logo-current {
  width: 180px;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  border: 1px dashed var(--border);
  border-radius: 8px;
  padding: 8px;
  overflow: hidden;
}
.branding-logo-current img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.branding-logo-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
  min-width: 220px;
}
.branding-logo-actions .btn-ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
}
.config-section-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border-top: 1px solid var(--border);
  padding-top: 12px;
  margin-top: 4px;
}
.config-system-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--bg-soft, rgba(0, 0, 0, 0.03));
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 0.92rem;
}
.config-system-info strong {
  font-weight: 600;
  margin-right: 4px;
}
.btn.warn {
  background: #e2a13a;
  color: #fff;
  border-color: #c98a26;
}
.btn.warn:hover {
  background: #c98a26;
}

.autosave-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 500;
  min-height: 18px;
  padding: 2px 8px;
  border-radius: 999px;
  transition: opacity 0.25s ease, background 0.2s ease, color 0.2s ease;
  color: transparent;
}
.autosave-indicator:empty {
  background: transparent;
  padding: 0;
}
.autosave-indicator.is-saving {
  background: rgba(60, 130, 230, 0.12);
  color: #2563eb;
}
.autosave-indicator.is-saved {
  background: rgba(40, 170, 90, 0.12);
  color: #16a34a;
}
.autosave-indicator.is-error {
  background: rgba(220, 60, 60, 0.12);
  color: #dc2626;
}
.autosave-indicator.is-saving::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid currentColor;
  border-right-color: transparent;
  animation: autosave-spin 0.7s linear infinite;
}
.autosave-indicator.is-saved::before {
  content: "✓";
  font-weight: 700;
}
.autosave-indicator.is-error::before {
  content: "!";
  font-weight: 700;
}
@keyframes autosave-spin {
  to { transform: rotate(360deg); }
}

/* =====================================================================
   Módulo Usuarios v2 + Topbar avatar + Mi perfil + reset password modal
   ===================================================================== */

/* Topbar: chip de usuario con avatar + caret */
.user-chip-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 4px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: var(--topbar-text);
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.2;
  transition: background-color 0.12s ease, border-color 0.12s ease;
}
.user-chip-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.22);
}
.user-chip-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.user-chip-btn[aria-expanded="true"] {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.3);
}
.user-chip-btn .user-chip {
  background: transparent;
  border: 0;
  padding: 0;
  color: inherit;
}
.user-chip-caret {
  opacity: 0.7;
  margin-left: 2px;
}
.topbar-icon-btn--logout-fallback {
  display: none !important;
}

/* Avatar de iniciales */
.user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: 999px;
  background: #6366f1;
  text-transform: uppercase;
  flex-shrink: 0;
  user-select: none;
}
.user-avatar--sm { width: 28px; height: 28px; font-size: 0.72rem; }
.user-avatar--md { width: 40px; height: 40px; font-size: 0.95rem; }
.user-avatar--lg { width: 52px; height: 52px; font-size: 1.15rem; }
.user-avatar--xl { width: 64px; height: 64px; font-size: 1.4rem; }

/* Menú desplegable del usuario */
.user-menu {
  position: absolute;
  top: 100%;
  right: 14px;
  margin-top: 6px;
  min-width: 240px;
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.18);
  padding: 6px;
  z-index: 1000;
  animation: usermenu-pop 0.14s ease-out;
}
@keyframes usermenu-pop {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.user-menu-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 8px 12px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  margin-bottom: 6px;
}
.user-menu-head-meta {
  min-width: 0;
}
.user-menu-head-name {
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--text, #0f172a);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 180px;
}
.user-menu-head-sub {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.user-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 8px 10px;
  border: 0;
  background: transparent;
  color: var(--text, #0f172a);
  font: inherit;
  font-size: 0.86rem;
  border-radius: 6px;
  cursor: pointer;
  text-align: left;
}
.user-menu-item:hover { background: rgba(15, 23, 42, 0.06); }
.user-menu-item svg { flex-shrink: 0; opacity: 0.75; }
.user-menu-item--danger { color: #b91c1c; }
.user-menu-item--danger:hover { background: rgba(220, 38, 38, 0.08); }
.user-menu-item--danger svg { opacity: 0.8; }
.user-menu-sep {
  height: 1px;
  background: var(--border, #e5e7eb);
  margin: 4px 0;
}

/* Modal "Mi perfil" / Reset password */
.myprofile-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.myprofile-modal[hidden] { display: none; }
.myprofile-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
}
.myprofile-card {
  position: relative;
  background: #fff;
  border-radius: 12px;
  width: min(640px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.25);
  overflow: hidden;
}
.myprofile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.myprofile-head h2 { margin: 0; font-size: 1.05rem; }
.myprofile-close {
  background: transparent;
  border: 0;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--muted, #64748b);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
}
.myprofile-close:hover { background: rgba(15, 23, 42, 0.06); color: var(--text, #0f172a); }
.myprofile-tabs {
  display: flex;
  gap: 4px;
  padding: 8px 16px 0;
  border-bottom: 1px solid var(--border, #e5e7eb);
  background: #f8fafc;
}
.myprofile-tab {
  background: transparent;
  border: 0;
  padding: 8px 14px;
  font: inherit;
  font-size: 0.85rem;
  color: var(--muted, #64748b);
  cursor: pointer;
  border-radius: 6px 6px 0 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.myprofile-tab:hover { color: var(--text, #0f172a); }
.myprofile-tab.is-active {
  color: var(--text, #0f172a);
  border-bottom-color: var(--primary, #2563eb);
  background: #fff;
  font-weight: 600;
}
.myprofile-body {
  padding: 20px;
  overflow-y: auto;
}
.myprofile-section { margin-bottom: 4px; }
.myprofile-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border, #e5e7eb);
}
body.modal-open { overflow: hidden; }

/* Password field reusable */
.password-field {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
}
.password-field input {
  flex: 1;
  border: 0 !important;
  outline: none;
  padding: 8px 10px;
  background: transparent;
  font: inherit;
}
.password-field input:focus { outline: none; }
.password-field-toggle {
  border: 0;
  background: #f1f5f9;
  padding: 0 12px;
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--muted, #64748b);
}
.password-field-toggle:hover { background: #e2e8f0; color: var(--text, #0f172a); }
.password-strength {
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.password-strength-bar {
  position: relative;
  width: 120px;
  height: 6px;
  background: #e2e8f0;
  border-radius: 999px;
  overflow: hidden;
}
.password-strength[data-score="0"] .password-strength-bar { background: linear-gradient(to right, #ef4444 0 20%, #e2e8f0 20%); }
.password-strength[data-score="1"] .password-strength-bar { background: linear-gradient(to right, #f97316 0 40%, #e2e8f0 40%); }
.password-strength[data-score="2"] .password-strength-bar { background: linear-gradient(to right, #eab308 0 60%, #e2e8f0 60%); }
.password-strength[data-score="3"] .password-strength-bar { background: linear-gradient(to right, #22c55e 0 80%, #e2e8f0 80%); }
.password-strength[data-score="4"] .password-strength-bar { background: #16a34a; }
.password-strength-label { white-space: nowrap; }
.muted.small.ok { color: #16a34a; }
.muted.small.error { color: #b91c1c; }

/* Layout principal del módulo Usuarios */
.users-layout {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(420px, 1.4fr);
  gap: 16px;
  align-items: stretch;
}
@media (max-width: 1100px) {
  .users-layout { grid-template-columns: 1fr; }
}
.users-list-panel { padding: 16px; }
.users-detail-panel { padding: 18px 20px; }

.users-toolbar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.users-toolbar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.users-toolbar-row--top { justify-content: space-between; }
.users-toolbar-search {
  flex: 1;
  min-width: 200px;
  position: relative;
}
.users-toolbar-search input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 8px;
  background: #f8fafc;
  font: inherit;
}
.users-toolbar-search input:focus {
  background: #fff;
  border-color: var(--primary, #2563eb);
  outline: none;
}
.users-filter {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.78rem;
}
.users-filter select {
  padding: 4px 8px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 6px;
  background: #fff;
}
.users-count { margin-left: auto; }

/* Lista de usuarios (cards) */
.users-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 70vh;
  overflow-y: auto;
}
.user-list-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.12s, border-color 0.12s;
  font: inherit;
  color: inherit;
}
.user-list-card:hover { background: rgba(37, 99, 235, 0.05); }
.user-list-card--active {
  background: rgba(37, 99, 235, 0.1) !important;
  border-color: var(--primary, #2563eb);
}
.user-list-card--inactive { opacity: 0.65; }
.user-list-card-body { min-width: 0; flex: 1; }
.user-list-card-line1 {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--text, #0f172a);
}
.user-list-card-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.user-list-card-line2 {
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.user-list-card-line3 {
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.user-list-card-last { color: var(--muted, #64748b); }
.badge-you {
  display: inline-block;
  font-size: 0.65rem;
  padding: 1px 6px;
  background: rgba(37, 99, 235, 0.15);
  color: var(--primary, #2563eb);
  border-radius: 999px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Panel de detalle */
.user-detail-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  margin-bottom: 18px;
}
.user-detail-head-meta { flex: 1; min-width: 0; }
.user-detail-name {
  margin: 0;
  font-size: 1.15rem;
  display: flex;
  align-items: center;
  gap: 8px;
}
.user-detail-head-sub {
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.user-detail-head-meta-extra { margin-top: 6px; }
.user-detail-head-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.user-section {
  margin-bottom: 18px;
}
.user-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  gap: 10px;
  flex-wrap: wrap;
}
.user-section-head h3 {
  margin: 0;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted, #64748b);
}
.user-section-head--collapsible {
  cursor: pointer;
  user-select: none;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  padding: 8px 12px;
  background: #f8fafc;
  margin-bottom: 0;
}
.user-section-collapse {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 1rem;
  color: var(--muted, #64748b);
}
.user-section-head--collapsible[aria-expanded="true"] .user-section-collapse,
.user-section-head--collapsible .user-section-collapse[aria-expanded="true"] {
  transform: rotate(180deg);
}

/* Permisos por módulo */
.perm-presets {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.perm-presets .btn.small {
  padding: 4px 10px;
  font-size: 0.75rem;
}
.perm-section-group { margin-bottom: 14px; }
.perm-section-title {
  margin: 0 0 6px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted, #64748b);
}
.data-table--perms td.t-center,
.data-table--perms th.t-center { text-align: center; }
.data-table--perms td { padding: 6px 10px; }
.perm-tag {
  display: inline-block;
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
}
.perm-tag--view { background: rgba(37, 99, 235, 0.12); color: var(--primary, #2563eb); }
.perm-tag--edit { background: rgba(22, 163, 74, 0.14); color: #15803d; }

/* Bitácora */
.user-audit-log { margin-top: 10px; }
.user-audit-log .data-table th,
.user-audit-log .data-table td {
  font-size: 0.78rem;
  padding: 6px 8px;
}
.audit-action {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  background: rgba(15, 23, 42, 0.08);
  color: var(--text, #0f172a);
}
.audit-action--login { background: rgba(34, 197, 94, 0.15); color: #15803d; }
.audit-action--create_user { background: rgba(59, 130, 246, 0.15); color: #1d4ed8; }
.audit-action--update_user,
.audit-action--update_profile,
.audit-action--update_perms { background: rgba(234, 179, 8, 0.18); color: #a16207; }
.audit-action--delete_user { background: rgba(239, 68, 68, 0.15); color: #b91c1c; }
.audit-action--reset_password,
.audit-action--change_password { background: rgba(168, 85, 247, 0.15); color: #6d28d9; }
.audit-log-detail {
  display: inline-block;
  max-width: 360px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.74rem;
  color: var(--muted, #64748b);
  background: transparent;
}

.user-detail-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border, #e5e7eb);
}

.checkbox-line {
  display: flex;
  flex-direction: row !important;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}

.info-banner {
  padding: 10px 14px;
  border-radius: 8px;
  background: rgba(37, 99, 235, 0.08);
  color: var(--primary, #2563eb);
  border: 1px solid rgba(37, 99, 235, 0.18);
  font-size: 0.85rem;
}

/* Placeholder con icono */
.placeholder-panel--center { display: flex; flex-direction: column; align-items: center; }
.placeholder-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(37, 99, 235, 0.08);
  color: var(--primary, #2563eb);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Reset password modal box */
.reset-pw-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: #0f172a;
  color: #f8fafc;
  border-radius: 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
.reset-pw-value {
  flex: 1;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
  font-family: inherit;
  background: transparent;
  word-break: break-all;
}
.reset-pw-box .btn { background: #fff; color: #0f172a; }

/* Móvil: ajustar el chip de usuario y el menú */
@media (max-width: 900px) {
  .user-chip-btn .user-chip { display: none; }
  .user-chip-btn .user-chip-caret { display: none; }
  .user-chip-btn { padding: 4px; }
  .user-menu { right: 8px; }
  .users-list { max-height: none; }
  .users-toolbar-row--top { flex-direction: column; align-items: stretch; }
}

/* =====================================================================
   Fichas técnicas v2
   ===================================================================== */

.fichas-layout {
  display: grid;
  grid-template-columns: minmax(340px, 1fr) minmax(520px, 1.6fr);
  gap: 16px;
  align-items: stretch;
}
@media (max-width: 1100px) {
  .fichas-layout { grid-template-columns: 1fr; }
}
.fichas-list-panel { padding: 16px; }
.fichas-detail-panel { padding: 18px 22px; }

/* Toolbar */
.fichas-toolbar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.fichas-toolbar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.fichas-toolbar-row--top { justify-content: space-between; }
.fichas-toolbar-search { flex: 1; min-width: 220px; position: relative; }
.fichas-toolbar-search input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 8px;
  background: #f8fafc;
  font: inherit;
}
.fichas-toolbar-search input:focus {
  background: #fff;
  border-color: var(--primary, #2563eb);
  outline: none;
}
.fichas-filter {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.78rem;
}
.fichas-filter select {
  padding: 4px 8px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 6px;
  background: #fff;
}
.fichas-count { margin-left: auto; }

/* Lista (cards) */
.fichas-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 72vh;
  overflow-y: auto;
}
.ficha-card {
  display: flex;
  gap: 12px;
  padding: 10px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.12s, border-color 0.12s;
  font: inherit;
  color: inherit;
  align-items: center;
}
.ficha-card:hover { background: rgba(37, 99, 235, 0.05); }
.ficha-card--active {
  background: rgba(37, 99, 235, 0.1) !important;
  border-color: var(--primary, #2563eb);
}
.ficha-card--inactive { opacity: 0.65; }
.ficha-card-thumb {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 10px;
  background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.ficha-card-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ficha-card-thumb-ph {
  font-size: 1.6rem;
  color: rgba(255, 255, 255, 0.65);
}
.ficha-card-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ficha-card-head {
  display: flex;
  gap: 8px;
  align-items: center;
}
.ficha-card-name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--text, #0f172a);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ficha-card-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: baseline;
}
.ficha-card-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.72rem;
  color: var(--muted, #64748b);
}
.ficha-card-cat {
  padding: 1px 6px;
  background: rgba(37, 99, 235, 0.1);
  color: var(--primary, #2563eb);
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
}
.ficha-card-portions { font-size: 0.72rem; }
.ficha-card-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
  margin-top: 2px;
}
.ficha-card-bottom-right {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.ficha-card-cost {
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--text, #0f172a);
}
.ficha-card-hotel-badge {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 1px 6px;
  background: rgba(15, 23, 42, 0.08);
  border-radius: 999px;
  color: var(--text, #0f172a);
}

/* Allergen chips (lista + detalle) */
.ficha-allergen-chips {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 3px;
}
.ficha-allergen-chips--lg {
  gap: 6px;
  margin-top: 2px;
}
.ficha-alg-chip {
  display: inline-block;
  font-size: 0.66rem;
  font-weight: 600;
  padding: 1px 7px;
  background: rgba(234, 88, 12, 0.12);
  color: #c2410c;
  border-radius: 999px;
  white-space: nowrap;
}
.ficha-alg-chip--lg { font-size: 0.78rem; padding: 4px 10px; }
.ficha-alg-chip--more { background: rgba(15,23,42,0.08); color: var(--muted, #64748b); }

/* Detalle: cabecera */
.ficha-detail-head {
  display: flex;
  gap: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  margin-bottom: 18px;
  align-items: flex-start;
}
.ficha-detail-photo {
  flex-shrink: 0;
  width: 160px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ficha-detail-photo img,
.ficha-detail-photo-ph {
  width: 160px;
  height: 160px;
  object-fit: cover;
  border-radius: 12px;
  background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
  color: rgba(255, 255, 255, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ficha-photo--zoomable {
  cursor: zoom-in;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.ficha-photo--zoomable:hover {
  transform: scale(1.02);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.18);
}

/* Pestañas comida/bebida en módulo Fichas técnicas */
.fichas-kind-tabs {
  display: flex;
  gap: 6px;
  padding: 4px;
  background: rgba(148, 163, 184, 0.12);
  border-radius: 10px;
  margin-bottom: 12px;
  width: max-content;
}
.fichas-kind-tab {
  appearance: none;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 7px 16px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--muted, #64748b);
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.fichas-kind-tab:hover {
  color: var(--text, #0f172a);
}
.fichas-kind-tab.is-active {
  background: var(--card-bg, #fff);
  color: var(--accent, #2563eb);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
}
.fichas-kind-tab-icon {
  font-size: 1.05rem;
  line-height: 1;
}

/* Badge del tipo en la cabecera de la ficha */
.ficha-kind-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.ficha-kind-badge--comida {
  background: rgba(16, 185, 129, 0.15);
  color: #047857;
}
.ficha-kind-badge--bebida {
  background: rgba(59, 130, 246, 0.18);
  color: #1d4ed8;
}
.ficha-detail-photo-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ficha-detail-head-meta { flex: 1; min-width: 0; }
.ficha-detail-name { margin: 0; font-size: 1.25rem; line-height: 1.2; }
.ficha-detail-head-chips {
  margin-top: 8px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ficha-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.78rem;
  font-weight: 500;
  padding: 3px 10px;
  background: rgba(15, 23, 42, 0.07);
  color: var(--text, #0f172a);
  border-radius: 999px;
}
.ficha-chip--code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background: rgba(37, 99, 235, 0.1);
  color: var(--primary, #2563eb);
}
.ficha-chip--cost {
  background: rgba(22, 163, 74, 0.13);
  color: #15803d;
  font-weight: 700;
}
.ficha-detail-head-actions {
  margin-top: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Secciones */
.ficha-section { margin-bottom: 22px; }
.ficha-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  gap: 10px;
  flex-wrap: wrap;
}
.ficha-section-head h3 {
  margin: 0;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted, #64748b);
}
.ficha-section textarea {
  width: 100%;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 6px;
  padding: 8px 10px;
  font: inherit;
  font-size: 0.88rem;
  resize: vertical;
}
.ficha-section textarea:focus {
  outline: none;
  border-color: var(--primary, #2563eb);
}

/* Hoteles asignados */
.ficha-hotels-box {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ficha-hotel-group {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 10px 12px 12px;
  background: var(--surface-soft, #f8fafc);
}
.ficha-hotel-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.ficha-hotel-group-name {
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text, #0f172a);
}
.ficha-hotel-all {
  border: 1px solid var(--border, #cbd5e1);
  background: #fff;
  color: var(--primary, #2563eb);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.ficha-hotel-all:hover {
  background: var(--primary, #2563eb);
  color: #fff;
  border-color: var(--primary, #2563eb);
}
.ficha-hotel-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ficha-hotel-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 999px;
  background: #fff;
  font-size: 0.82rem;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}
.ficha-hotel-chip input { display: none; }
.ficha-hotel-chip:hover { border-color: var(--primary, #2563eb); }
.ficha-hotel-chip--on {
  background: var(--primary, #2563eb);
  border-color: var(--primary, #2563eb);
  color: #fff;
  box-shadow: 0 2px 6px rgba(37, 99, 235, 0.2);
}
.ficha-hotel-chip--on:hover { background: #1d4ed8; border-color: #1d4ed8; }
.ficha-hotel-chip input:disabled + span { opacity: 0.7; }

/* Ingredientes */
.ficha-ing-search {
  position: relative;
  margin-bottom: 10px;
  max-width: 480px;
}
.ficha-ing-search input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 8px;
  background: #fff;
  font: inherit;
}
.ficha-ing-search input:focus {
  outline: none;
  border-color: var(--primary, #2563eb);
}
.ficha-ing-hits {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  max-height: 320px;
  overflow-y: auto;
  z-index: 10;
  margin-top: 4px;
}
.ficha-ing-hit {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  border: 0;
  background: transparent;
  padding: 8px 12px;
  font: inherit;
  font-size: 0.85rem;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid var(--border, #f1f5f9);
}
.ficha-ing-hit:hover { background: rgba(37, 99, 235, 0.08); }
.ficha-ing-hit--empty { cursor: default; color: var(--muted, #64748b); }
.ficha-ing-hit--empty:hover { background: transparent; }

/* Badge de destino en cada resultado del buscador */
.ficha-ing-hit-dest {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 18px;
  padding: 0 6px;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  border-radius: 4px;
  margin-right: 8px;
  flex-shrink: 0;
}
.ficha-ing-hit-dest--TFE { background: #fed7aa; color: #9a3412; }
.ficha-ing-hit-dest--Teguise { background: #ddd6fe; color: #5b21b6; }
.ficha-ing-hit-dest--BCN { background: #bfdbfe; color: #1e40af; }
.ficha-ing-hit-dest--neutral { background: #e2e8f0; color: #475569; min-width: 18px; padding: 0; }
.ficha-ing-hit-label { flex: 1 1 0; min-width: 0; text-align: left; overflow-wrap: anywhere; }

.ficha-ing-table-wrap { overflow-x: auto; }
.ficha-ing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.ficha-ing-table thead th {
  text-align: left;
  background: #f8fafc;
  padding: 8px 10px;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted, #64748b);
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.ficha-ing-table th.num,
.ficha-ing-table td.num { text-align: right; }
.ficha-ing-table tbody td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border, #f1f5f9);
  vertical-align: middle;
}
.ficha-ing-table input[type="number"] {
  padding: 4px 6px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 5px;
  text-align: right;
  font: inherit;
  font-size: 0.85rem;
}
.ficha-ing-table input[type="number"]:focus {
  outline: none;
  border-color: var(--primary, #2563eb);
}
.ficha-ing-name { font-weight: 500; }

/* Columna de formato (unidad) */
.ficha-ing-table th.ficha-ing-unit-col,
.ficha-ing-table td.ficha-ing-unit-col {
  text-align: center;
  width: 1%;
  white-space: nowrap;
}
.ficha-ing-unit-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  background: #e0f2fe;
  color: #0369a1;
  border: 1px solid #bae6fd;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: lowercase;
  min-width: 28px;
  text-align: center;
}

.ficha-totals-bar {
  margin-top: 12px;
  padding: 12px 14px;
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  color: #f8fafc;
  border-radius: 10px;
  display: grid;
  gap: 4px;
}
.ficha-totals-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  opacity: 0.85;
}
.ficha-totals-row--main {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.18);
  font-size: 1rem;
  opacity: 1;
  font-weight: 700;
}
.ficha-totals-row strong { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

/* =================================================================
 *  Módulo Producción
 * ================================================================= */
.prod-shell { padding: 0; overflow: hidden; }
.prod-tabs {
  display: flex;
  gap: 4px;
  padding: 12px 14px 0;
  border-bottom: 1px solid var(--border, #e5e7eb);
  overflow-x: auto;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  flex-wrap: wrap;
}
.prod-tab {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 10px 16px 12px;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  border-radius: 8px 8px 0 0;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--muted, #64748b);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.prod-tab:hover {
  background: rgba(37, 99, 235, 0.06);
  color: var(--primary, #2563eb);
}
.prod-tab.active {
  background: #fff;
  color: var(--primary, #2563eb);
  border-bottom-color: var(--primary, #2563eb);
}
.prod-tab-dest {
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--muted, #94a3b8);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.prod-body { padding: 18px 22px 22px; }
.prod-empty {
  padding: 40px 20px;
  text-align: center;
  background: #f8fafc;
  border: 1px dashed var(--border, #cbd5e1);
  border-radius: 12px;
}

.prod-svc-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.prod-svc-bar-label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted, #64748b);
  font-weight: 600;
}
.prod-svc-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.prod-svc-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border: 1px solid var(--border, #cbd5e1);
  border-radius: 999px;
  background: #fff;
  font-size: 0.85rem;
  color: var(--text, #0f172a);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}
.prod-svc-chip:hover { border-color: var(--primary, #2563eb); }
.prod-svc-chip.active {
  background: var(--primary, #2563eb);
  border-color: var(--primary, #2563eb);
  color: #fff;
  box-shadow: 0 2px 6px rgba(37, 99, 235, 0.2);
}
.prod-svc-name { font-weight: 600; }
.prod-svc-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  padding: 0 6px;
  height: 18px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  color: inherit;
  font-size: 0.7rem;
  font-weight: 700;
}
.prod-svc-chip.active .prod-svc-count {
  background: rgba(255, 255, 255, 0.25);
  color: #fff;
}

.prod-summary {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.prod-summary-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid var(--border, #e2e8f0);
  background: #f8fafc;
  font-size: 0.82rem;
}
.prod-summary-pill--ok {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #065f46;
}
.prod-summary-pill--ko {
  background: #fef2f2;
  border-color: #fecaca;
  color: #991b1b;
}
.prod-summary-pill--info {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1e40af;
}
.prod-summary-num { font-weight: 700; font-size: 0.95rem; }
.prod-summary-lbl { font-weight: 500; }

.prod-menu-block {
  margin-bottom: 22px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 12px;
  overflow: hidden;
}
.prod-menu-head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 12px 16px;
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
  color: #f8fafc;
  flex-wrap: wrap;
}
.prod-menu-head h3 {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.prod-menu-head .muted { color: #cbd5e1; }

.prod-table-wrap { overflow-x: auto; }
.prod-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.prod-table thead th {
  text-align: left;
  background: #f8fafc;
  padding: 9px 12px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted, #64748b);
  border-bottom: 1px solid var(--border, #e5e7eb);
  white-space: nowrap;
}
.prod-table tbody td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--border, #f1f5f9);
  vertical-align: middle;
}
.prod-row-ok td { background: rgba(16, 185, 129, 0.03); }
.prod-row-ko td { background: transparent; }
.prod-cell-day {
  font-weight: 600;
  color: var(--text, #0f172a);
  white-space: nowrap;
  width: 1%;
}
.prod-cell-cat {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted, #64748b);
  white-space: nowrap;
}
.prod-cell-text { color: var(--text, #0f172a); }
.prod-cell-ficha { color: #0f172a; }
.prod-ficha-name { font-weight: 500; }
.prod-ficha-code {
  display: inline-block;
  padding: 2px 8px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e40af;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 700;
}
.prod-match-score {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  background: #fef3c7;
  color: #92400e;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
}
.prod-nomatch {
  color: #b45309;
  font-style: italic;
  font-size: 0.82rem;
}

/* Detalle: acciones */
.ficha-detail-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid var(--border, #e5e7eb);
}

/* PDF / impresión */
@media print {
  @page { size: A4 portrait; margin: 12mm; }
  body.ficha-pdf-mode .app-topbar,
  body.ficha-pdf-mode .sidebar,
  body.ficha-pdf-mode #sidebar-backdrop,
  body.ficha-pdf-mode .toast,
  body.ficha-pdf-mode .fichas-list-panel,
  body.ficha-pdf-mode .fichas-toolbar,
  body.ficha-pdf-mode .ficha-detail-head-actions,
  body.ficha-pdf-mode .ficha-detail-actions,
  body.ficha-pdf-mode .ficha-ing-search,
  body.ficha-pdf-mode .ficha-detail-photo-actions {
    display: none !important;
  }
  body.ficha-pdf-mode .fichas-layout {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  body.ficha-pdf-mode .shell,
  body.ficha-pdf-mode .shell-body,
  body.ficha-pdf-mode .shell-main,
  body.ficha-pdf-mode .view-root {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    height: auto !important;
  }
  body.ficha-pdf-mode .fichas-detail-panel {
    box-shadow: none !important;
    border: 0 !important;
    padding: 0 !important;
  }
  body.ficha-pdf-mode .ficha-totals-bar {
    background: #0f172a !important;
    color: #f8fafc !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  body.ficha-pdf-mode .ficha-alg-chip,
  body.ficha-pdf-mode .ficha-chip {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  body.ficha-pdf-mode .ficha-section {
    page-break-inside: avoid;
  }
}

/* Móvil */
@media (max-width: 700px) {
  .ficha-detail-head { flex-direction: column; }
  .ficha-detail-photo,
  .ficha-detail-photo img,
  .ficha-detail-photo-ph { width: 100%; height: auto; max-height: 220px; }
  .ficha-totals-bar { font-size: 0.78rem; }
}

/* =============================================================
 *  FASE A - Arreglos responsive globales (alto impacto, riesgo bajo)
 *  Doc: https://internal/responsive-mobile-tablet
 *  Estas reglas se aplican en todos los tamanos salvo que diga lo
 *  contrario. Se mantienen al final para sobreescribir cualquier
 *  regla previa sin riesgo.
 * ============================================================= */

/* A1 - Wrappers de tabla con scroll horizontal SIEMPRE que sea necesario
   (antes solo se aplicaba en <900px, lo que rompia tablas anchas en desktop). */
.sub-table-wrap,
.data-table-wrap,
.menu-erp-table-wrap,
.eventos-menu-table-wrap,
.materiales-table-wrap,
.mat-evol-table-wrap,
.hotel-org-table-wrap,
.costes-table-wrap,
.menu-matrix-table-wrap,
.audit-evo-table-wrap,
.ficha-ing-table-wrap,
.prod-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

/* A1b - tablas largas pueden seguir haciendo overflow horizontal, pero el
   contenedor NO debe forzar un min-width que provoque scroll cuando no hace falta. */
.data-table-wrap > table,
.sub-table-wrap > table,
.menu-erp-table-wrap > table,
.eventos-menu-table-wrap > table {
  max-width: 100%;
}

/* A2 - Evitar el zoom forzado de iOS al hacer focus en inputs (<=tablet vertical).
   Cubre los tipos modernos que faltaban (tel, url) y subimos el corte a 1024px
   (tablets verticales). Mantenemos la version del @media 900 para no romper nada. */
@media (max-width: 1024px) {
  input[type="text"],
  input[type="password"],
  input[type="search"],
  input[type="number"],
  input[type="date"],
  input[type="email"],
  input[type="tel"],
  input[type="url"],
  input:not([type]),
  select,
  textarea {
    font-size: 16px;
  }
}

/* A3 - Modales fullscreen en movil (<=640px). Aplica a todos los modales/dialogos
   del sistema sin tener que tocar cada uno individualmente. */
@media (max-width: 640px) {
  /* Overlay - quitar padding para que el dialog ocupe toda la pantalla */
  .modal-overlay,
  .mat-evol-overlay {
    padding: 0 !important;
    align-items: stretch !important;
    justify-content: stretch !important;
  }

  /* Cards/dialogs - ocupar 100% del viewport con scroll interno */
  .modal-card,
  .mat-evol-dialog,
  .myprofile-modal,
  .audit-new-modal .modal-card,
  .menu-import-modal {
    width: 100vw !important;
    max-width: none !important;
    height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding-top: max(14px, env(safe-area-inset-top)) !important;
    padding-bottom: max(14px, env(safe-area-inset-bottom)) !important;
  }

  /* Lightbox de imagenes: dejar mas espacio al pulgar */
  .image-lightbox-close {
    top: max(16px, env(safe-area-inset-top));
    right: 16px;
    width: 44px;
    height: 44px;
  }

  /* Bloques internos del modal que solian ir en grid lado-a-lado */
  .menu-import-item-grid {
    grid-template-columns: 1fr !important;
  }
}

/* A4 - Toolbars que NO estaban contempladas: forzar flex-wrap + gap en movil */
@media (max-width: 900px) {
  .event-cal-toolbar,
  .event-ficha-toolbar,
  .event-ficha-toolbar-main,
  .event-ficha-toolbar-actions,
  .event-compras-toolbar-main,
  .menu-erp-toolbar,
  .menu-erp-toolbar-actions,
  .event-ods-toolbar,
  .eventos-analytics-toolbar,
  .hotel-org-toolbar,
  .menu-detail-toolbar,
  .users-toolbar,
  .users-toolbar-row,
  .fichas-toolbar,
  .fichas-toolbar-row {
    flex-wrap: wrap;
    gap: 8px;
  }
}

/* A4b - Touch targets minimos en movil para todos los botones interactivos */
@media (max-width: 900px) {
  .btn,
  .nav-btn,
  .topbar-icon-btn,
  .modal-close,
  .user-chip-btn,
  .icon-btn,
  .chip-action,
  .tab,
  .module-inner-tab,
  .eventos-subtab {
    min-height: 44px;
  }
  /* Pero NO inflar checkboxes/radios */
  input[type="checkbox"],
  input[type="radio"] {
    min-height: 0;
  }
}

/* A4c - Evitar overflow horizontal global causado por modulos antiguos
 *
 * IMPORTANTE: usamos `overflow-x: clip` y NO `overflow-x: hidden`.
 *
 * `hidden` crea un nuevo contexto de scroll que cancela los `position: sticky`
 * descendientes y, en iOS, llega a bloquear el scroll horizontal de los
 * wrappers internos con `overflow-x: auto` (matriz de menus, ingredientes
 * de fichas, costes...). `clip` recorta visualmente pero no convierte al
 * elemento en un scroll container, asi que la sticky/scroll de los hijos
 * sigue funcionando como debe.
 *
 * Safari < 16 ignora `clip`; alli el body queda con `visible` y los scrolls
 * internos funcionan igual. */
html, body {
  overflow-x: clip;
}
/* min-width: 0 en paneles que viven dentro de grids/flex: sin esto el
 * contenido interno fuerza al padre a crecer y rompe el layout. */
.shell-main,
.shell-content,
.module-root,
.event-ficha-root,
.menus-detail-panel,
.fichas-detail-panel,
.audit-detail-panel,
.users-detail-panel,
.materiales-detail-panel,
.menu-matrix-block,
.hotels-detail-panel {
  min-width: 0;
}

/* =============================================================
 *  FASE C - Refactor responsive por modulos criticos
 *  Receta: tabla->cards en movil, layouts en stack, KPIs apilados,
 *  charts a ancho 100%. Usa breakpoints unificados de Fase B.
 * ============================================================= */

/* ─────────────────────────────────────────────
 * C1 - MATERIALES en movil: tabla -> cards
 * ───────────────────────────────────────────── */
@media (max-width: 767.98px) {
  /* Quitar el max-height (en movil no tiene sentido el doble scroll vertical) */
  .materiales-table-wrap {
    max-height: none;
    overflow: visible;
  }
  /* Tabla a bloques */
  .materiales-table { display: block; }
  .materiales-table thead { display: none; }
  .materiales-table tbody { display: block; }
  .materiales-table tbody tr.mat-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-areas:
      "code   badge   cost"
      "family family  family"
      "name   name    name"
      "format format  format";
    column-gap: 10px;
    row-gap: 4px;
    padding: 12px;
    margin: 0 0 8px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--card);
    box-shadow: var(--shadow);
    /* Reset estilos de fila de tabla */
    border-collapse: separate;
  }
  .materiales-table tbody tr.mat-row:hover {
    background: var(--accent-soft);
  }
  .materiales-table tbody tr.mat-row > td {
    display: block;
    padding: 0;
    border: 0;
    background: transparent;
  }
  /* Mapeo posicional: 1=destino, 2=codigo, 3=familia, 4=nombre, 5=coste, 6=formato */
  .materiales-table tbody tr.mat-row > td:nth-child(1) { grid-area: badge; align-self: center; }
  .materiales-table tbody tr.mat-row > td:nth-child(2) { grid-area: code;  align-self: center; }
  .materiales-table tbody tr.mat-row > td:nth-child(3) {
    grid-area: family;
    font-size: 0.78rem;
    color: var(--muted);
  }
  .materiales-table tbody tr.mat-row > td:nth-child(3)::before {
    content: "Familia: ";
    font-weight: 600;
  }
  .materiales-table tbody tr.mat-row > td:nth-child(4) {
    grid-area: name;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--text);
  }
  .materiales-table tbody tr.mat-row > td:nth-child(5) {
    grid-area: cost;
    text-align: right;
    font-weight: 700;
    color: var(--text);
  }
  .materiales-table tbody tr.mat-row > td:nth-child(6) {
    grid-area: format;
    font-size: 0.78rem;
    color: var(--muted);
  }
  .materiales-table tbody tr.mat-row > td:nth-child(6)::before {
    content: "Formato: ";
    font-weight: 600;
  }
  /* Empty state ocupa el ancho entero */
  .materiales-table tbody tr td[colspan] {
    display: block;
    grid-template-columns: 1fr;
    padding: 18px;
    text-align: center;
  }
  /* Toolbar de materiales en stack */
  .materiales-panel .materiales-toolbar > * { width: 100%; }
  .materiales-count { margin-left: 0; order: -1; }
  .mat-import-actions { flex-wrap: wrap; }
  .mat-import-actions > * { flex: 1 1 calc(50% - 4px); text-align: center; }
}

/* C1b - Modal de evolucion de precios mejor adaptado al movil */
@media (max-width: 767.98px) {
  .mat-evol-dialog {
    padding: 16px;
    gap: 14px;
  }
  .mat-evol-head {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "title close"
      "meta  meta";
  }
  .mat-evol-stats { grid-template-columns: 1fr 1fr !important; }
  .mat-evol-spark { height: 180px !important; }
}

/* ─────────────────────────────────────────────
 * C2 - FICHAS TECNICAS detalle en movil
 * ───────────────────────────────────────────── */
@media (max-width: 767.98px) {
  /* Layout en columna apilada */
  .ficha-detail-head {
    flex-direction: column;
    gap: 12px;
  }
  .ficha-detail-photo,
  .ficha-detail-photo img,
  .ficha-detail-photo-ph {
    width: 100%;
    height: auto;
    max-height: 240px;
  }
  .ficha-detail-name { font-size: 1.1rem; }
  .ficha-detail-head-chips { gap: 6px; }

  /* Acciones de cabecera: scroll horizontal en vez de wrap para no ocupar
     vertical exagerado */
  .ficha-detail-head-actions {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 6px;
    padding-bottom: 2px;
  }
  .ficha-detail-head-actions > * { flex-shrink: 0; }
  .ficha-detail-actions {
    flex-wrap: wrap;
    gap: 8px;
  }
  .ficha-detail-actions > * { flex: 1 1 calc(50% - 4px); }

  /* Tabla de ingredientes en movil: NO la rompemos a cards (las columnas
     son cruciales y no se etiquetan desde JS). Dejamos scroll horizontal
     con la primera columna sticky para que el nombre del articulo quede
     visible mientras el usuario navega lateralmente. */
  .ficha-ing-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x pan-y;
    overscroll-behavior-x: contain;
    max-width: 100%;
  }
  .ficha-ing-table {
    font-size: 0.78rem;
    min-width: 540px;
  }
  .ficha-ing-table thead th,
  .ficha-ing-table tbody td {
    padding: 6px 8px;
    white-space: nowrap;
  }
  .ficha-ing-table thead th:first-child,
  .ficha-ing-table tbody td:first-child {
    position: sticky;
    left: 0;
    background: var(--card);
    z-index: 1;
    box-shadow: 2px 0 4px rgba(0,0,0,0.04);
    max-width: 160px;
    white-space: normal;
  }
  .ficha-ing-table input[type="number"] {
    width: 70px;
    min-width: 0;
  }

  /* Totales: sticky abajo para que sean siempre visibles */
  .ficha-totals-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    position: sticky;
    bottom: env(safe-area-inset-bottom, 0);
    z-index: 5;
    background: var(--card);
    border-top: 1px solid var(--border);
  }
  .ficha-totals-row {
    width: 100%;
    justify-content: space-between;
  }
}

/* ─────────────────────────────────────────────
 * C3 - EVENTOS Costes/Balance + AUDITORIAS Analytics en movil
 * ───────────────────────────────────────────── */
@media (max-width: 1023.98px) {
  /* KPIs grid auto-fit 2col en tablet, 1col en movil */
  .eventos-analytics-kpis {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  }
}
@media (max-width: 767.98px) {
  /* Charts a ancho completo, altura compacta para que no obligue a scroll */
  .eventos-chart-wrap,
  .eventos-chart-wrap--hbar,
  .eventos-chart-wrap--donut,
  .eventos-chart-wrap--wide {
    height: 200px !important;
  }
  /* KPIs en 2 columnas para que no queden gigantes */
  .eventos-analytics-kpis {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  .eventos-analytics-kpis .cell strong { font-size: 1.15rem !important; }

  /* Costes sheet: dejamos scroll horizontal (cards no tienen sentido por la
     estructura mes-por-columna). Reducimos padding interno. */
  .costes-table-wrap .costes-sheet-table thead th,
  .costes-table-wrap .costes-sheet-table tbody td {
    padding: 6px 8px !important;
    font-size: 0.78rem !important;
  }
  /* Pestanas Costes/Balance: KPIs apilados */
  .eventos-analytics-tables-grid {
    grid-template-columns: 1fr !important;
  }
}

/* =============================================================
 *  FASE C+ - Iteracion 2 (Menus, Auditorias, refinos Fichas)
 *  Despues del primer deploy el usuario reporto problemas
 *  persistentes en Fichas y Menus. Estos fixes atacan los
 *  defectos restantes especificos por modulo.
 * ============================================================= */

/* ─────────────────────────────────────────────
 * Menus - lista + ficha + matriz dia x categoria
 * ───────────────────────────────────────────── */
@media (max-width: 767.98px) {
  /* La lista no debe quedar limitada a 380px en movil */
  .menus-list-panel {
    max-height: 50vh !important;
  }
  .menus-list-body {
    padding-right: 0;
  }
  /* Filtros en stack ya vienen flex-column. Solo asegurar gap aire */
  .menus-filters { gap: 10px; }

  /* Toolbar del detalle: stack vertical y boton principal full-width */
  .menu-detail-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .menu-detail-toolbar > * { width: 100%; }

  /* Cabecera de la ficha de menu */
  .menu-sheet { padding: 14px 12px; }
  .menu-sheet-title { font-size: 1.1rem; }
  .menu-sheet-subtitle { font-size: 0.85rem; }

  /* Matriz dia x categoria: scroll horizontal indispensable, pero reducimos
     min-width de columnas para que en pantalla pequena el scroll sea menor. */
  .menu-matrix-block { padding: 6px; }
  .menu-matrix-table th,
  .menu-matrix-table td {
    padding: 4px 6px;
    font-size: 0.78rem;
  }
  .menu-matrix-th-day {
    min-width: 100px;
    font-size: 0.7rem;
  }
  .menu-cell-input {
    font-size: 0.78rem;
    min-height: 32px;
    padding: 4px;
  }
  /* Sticky SOLO en los headers de categoria (th). El td:first-child de las
     filas de categoria es un <td colspan> que abarca todas las columnas y
     romperia el scroll horizontal en iOS. */
  .menu-matrix-table th.menu-matrix-th-cat {
    position: sticky;
    left: 0;
    z-index: 2;
    background: #f8fafc;
    box-shadow: 2px 0 4px rgba(0,0,0,0.04);
  }
  .menus-list-card-meta { font-size: 0.72rem; }
  .menus-list-card-hotels { gap: 3px; }
  .menu-hotel-chip { font-size: 0.68rem; padding: 1px 6px; }
}

/* ─────────────────────────────────────────────
 * Fichas tecnicas - refinos de padding y lista
 * ───────────────────────────────────────────── */
@media (max-width: 767.98px) {
  /* Padding reducido para no perder area util */
  .fichas-list-panel { padding: 10px; }
  .fichas-detail-panel { padding: 12px 12px; }

  /* Lista de fichas: ocupar la altura natural en lugar de 72vh
     (en movil 72vh es enorme). */
  .fichas-list { max-height: none; }

  /* Cards de ficha en la lista */
  .ficha-card {
    padding: 8px;
    gap: 10px;
    border: 1px solid var(--border);
  }
  .ficha-card-thumb { width: 56px !important; height: 56px !important; }
  .ficha-card-name { font-size: 0.92rem; line-height: 1.2; }
  .ficha-card-meta { font-size: 0.72rem; }
  .ficha-card-cost { font-size: 0.85rem; }
  .ficha-card-hotel-badge { font-size: 0.65rem; padding: 1px 5px; }

  /* Toolbar fichas: stack con buscador a 100% */
  .fichas-toolbar-search { width: 100%; min-width: 0; }
  .fichas-count { margin-left: 0; }

  /* Detalle: hoteles asignados box mas compacto */
  .ficha-hotels-box { padding: 8px; gap: 8px; }
  .ficha-hotel-group { padding: 8px; }
  .ficha-hotel-chips { gap: 4px; }
  .ficha-hotel-chip { padding: 4px 8px; font-size: 0.78rem; }

  /* Buscador de ingredientes */
  .ficha-ing-search { position: relative; }
  .ficha-ing-hits { width: 100%; max-height: 50vh; }

  /* Tabla totales: menos padding */
  .ficha-totals-bar { padding: 8px 10px; font-size: 0.78rem; }
}

/* ─────────────────────────────────────────────
 * Auditorias - layout 2col -> 1col, filtros 1col
 * ───────────────────────────────────────────── */
@media (max-width: 1023.98px) {
  .audit-layout {
    grid-template-columns: 1fr !important;
  }
  .audit-list-panel {
    max-height: 45vh;
  }
}
@media (max-width: 767.98px) {
  .audit-filters {
    grid-template-columns: 1fr !important;
  }
  .audit-list-panel {
    max-height: 50vh;
  }
}

/* ─────────────────────────────────────────────
 * Fix: hotels-toolbar de eventos en 2 filas en movil
 * ───────────────────────────────────────────── */
@media (max-width: 767.98px) {
  .hotels-toolbar > * { flex: 1 1 calc(50% - 4px); min-width: 0; }
  .hotels-toolbar input[type="search"],
  .hotels-toolbar input[type="text"] {
    flex: 1 1 100%;
  }
}


/* =============================================================
 *  FASE D - Refinos finales tras feedback "se ve cortado"
 *  Foco: eliminar limites artificiales de altura/anchura que
 *  estrangulan modulos en pantallas pequenas, y consolidar
 *  responsive en tablet (768-1023.98px) + iOS safe-area.
 * ============================================================= */

/* D1 - Bajar a tablet TODOS los grids analiticos de 2col -> 1col */
@media (max-width: 1023.98px) {
  .eventos-analytics-charts-grid,
  .eventos-analytics-tables-grid,
  .audit-analytics-grid {
    grid-template-columns: 1fr !important;
  }
}

/* D2 - Quitar max-height inflexibles en las raices de las pestanas
 * de evento. En movil el `min(72vh, calc(100vh - 200px))` deja una
 * franja minuscula que obliga a triple scroll (pagina + ficha + tabla).
 * Dejamos crecer al contenido y que el scroll sea solo el de pagina. */
@media (max-width: 1023.98px) {
  .event-ficha-root,
  .event-compras-root,
  .event-costes-root,
  .event-ods-root,
  .event-cierre-panel,
  .eventos-menu-table-wrap,
  .materiales-table-wrap,
  .hotels-list-scroll {
    max-height: none !important;
    height: auto !important;
  }
}

/* D3 - Tabs de hotel (Datos/Org/Costes...): scroll horizontal con
 * pildoras intactas en lugar de aplastarse o cortarse. */
@media (max-width: 1023.98px) {
  .hotel-tab-bar {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .hotel-tab {
    flex-shrink: 0;
    min-height: 44px;
    padding: 10px 14px;
    white-space: nowrap;
  }
}

/* D4 - Tabs internas de ficha de evento: idem scroll horizontal.
 * (Datos, Compras, Costes, Balance, ODS, Analytics...) */
@media (max-width: 1023.98px) {
  .event-ficha-inner-tabs,
  .module-tabs,
  .menu-detail-tabs {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .event-ficha-inner-tab,
  .module-tabs > *,
  .menu-detail-tabs > * {
    flex-shrink: 0;
    white-space: nowrap;
  }
}

/* D5 - Modales fullscreen con 100dvh/100dvw (mejor que 100vh en iOS:
 * descuenta automaticamente la barra de URL dinamica). Mantenemos
 * 100vh como fallback. */
@media (max-width: 640px) {
  .modal-card,
  .modal-content,
  .modal-container,
  .mat-evol-dialog,
  .myprofile-card,
  .ficha-print-dialog,
  .menu-print-dialog,
  .audit-print-dialog,
  .form-dialog {
    width: 100vw;
    width: 100dvw;
    height: 100vh;
    height: 100dvh;
    max-width: 100vw;
    max-width: 100dvw;
    max-height: 100vh;
    max-height: 100dvh;
  }
}

/* D6 - Topbar: respetar safe-area de iOS (notch + bordes redondeados) */
@media (max-width: 900px) {
  .app-topbar,
  .shell-topbar {
    padding-top: env(safe-area-inset-top, 0);
    padding-left: max(12px, env(safe-area-inset-left));
    padding-right: max(12px, env(safe-area-inset-right));
  }
  .topbar-icon-btn,
  .shell-topbar button {
    min-width: 44px;
    min-height: 44px;
  }
}

/* D7 - Anti-zoom iOS: cualquier input editable debajo de 16px provoca
 * que iOS Safari haga zoom al enfocarlo. Forzamos 16px en todos los
 * inputs especiales que pude haber dejado mas pequenos. */
@media (max-width: 1024.98px) {
  .menu-cell-input,
  .menu-theme-input,
  .menu-cat-input,
  .ficha-ing-table input,
  .costes-sheet-table input,
  .audit-detail input,
  .audit-detail textarea,
  .audit-detail select,
  .prod-table input {
    font-size: 16px !important;
  }
}

/* D8 - Calendario de eventos: celdas con altura razonable en movil para
 * que entren al menos titulo + 2 eventos + "+N mas" sin scroll interno. */
@media (max-width: 767.98px) {
  .event-cal-day {
    min-height: 64px;
    height: auto;
  }
  .event-cal-day-events {
    overflow: hidden;
  }
  .event-cal-event {
    font-size: 0.68rem;
    padding: 1px 4px;
  }
  .event-cal-day-num {
    font-size: 0.78rem;
  }
}

/* D9 - Stop a tablas que se desbordan sin envolver: tablas anchas que NO
 * estan dentro de un `*-table-wrap` aun deben mostrar scroll en movil. */
@media (max-width: 767.98px) {
  table:not(.materiales-table):not(.ficha-ing-table) {
    max-width: 100%;
  }
}

/* D10 - Garantizar que los inputs/selects/textareas no se desbordan del
 * card que los contiene (causa frecuente de "se ve cortado a la derecha"). */
@media (max-width: 767.98px) {
  input:not([type="checkbox"]):not([type="radio"]),
  select,
  textarea {
    max-width: 100%;
    box-sizing: border-box;
  }
}


