/* =========================================================
   /css/novios.css — ZONA NOVIOS (LIMPIO + PREMIUM)
   - Sin duplicados
   - Responsive estable
   - No afecta al resto del sitio (scoped a body.page-novios)
========================================================= */

body.page-novios{
  /* Tokens */
  --nv-ink: rgba(20,20,20,.92);
  --nv-muted: rgba(20,20,20,.62);
  --nv-stroke: rgba(46,46,46,.10);

  --nv-accent: rgba(184,110,136,.95);
  --nv-accent-soft: rgba(232,184,198,.22);

  --nv-bg-card: rgba(255,255,255,.74);
  --nv-bg-card-2: rgba(255,255,255,.86);
  --nv-bg-input: rgba(255,255,255,.90);

  --nv-shadow: 0 18px 60px rgba(0,0,0,.10);
  --nv-shadow-soft: 0 10px 24px rgba(0,0,0,.08);

  --nv-radius-lg: 24px;
  --nv-radius-md: 16px;
  --nv-radius-sm: 14px;

  --nv-h: 44px; /* altura uniforme inputs/botones */

  /* Tipos */
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
  color: var(--nv-ink);

  /* Fondo */
  background:
    radial-gradient(1200px 700px at 18% 12%, rgba(232,184,198,.16), transparent 55%),
    radial-gradient(900px 650px at 82% 34%, rgba(240,212,154,.14), transparent 58%),
    linear-gradient(180deg, rgba(255,252,249,.98), rgba(250,246,241,.98));
}

/* Utilidad */
body.page-novios .nv-muted{ color: var(--nv-muted); }

/* Contenedor */
body.page-novios .nv-wrap{
  max-width: 1120px;
  margin: 0 auto;
  padding: 18px 14px 44px;
}

/* Topbar */
body.page-novios .nv-topbar{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: end;
}
@media (max-width: 860px){
  body.page-novios .nv-topbar{ grid-template-columns: 1fr; align-items: start; }
}

/* Título */
body.page-novios .nv-title{
  font-family: "Fraunces", serif;
  font-weight: 900;
  letter-spacing: -0.6px;
  line-height: 1.02;
  margin: 0;
  font-size: clamp(36px, 5.5vw, 62px);
  text-shadow: 0 1px 0 rgba(255,255,255,.55);
}
body.page-novios .nv-sub{
  font-size: 14px;
  letter-spacing: .2px;
  opacity: .75;
}

/* H2 */
body.page-novios h2{
  font-family: "Fraunces", serif !important;
  font-weight: 900 !important;
  letter-spacing: -0.3px;
  line-height: 1.06;
  margin: 0;
  font-size: 30px;
  overflow-wrap: anywhere;
}

/* Tiny */
body.page-novios .tiny{
  font-size: 13px;
  line-height: 1.35;
  color: var(--nv-muted);
  letter-spacing: .15px;
}

/* Grid 2 secciones */
body.page-novios .nv-grid{
  display: grid;
  gap: 16px;
  margin-top: 18px;
}
@media (min-width: 980px){
  body.page-novios .nv-grid{
    grid-template-columns: 1.15fr .85fr;
    align-items: start;
  }
}

/* Cards (scoped) */
body.page-novios .nv-card,
body.page-novios .card.tip.wash.wash-soft{
  border-radius: var(--nv-radius-lg) !important;
  background: var(--nv-bg-card) !important;
  border: 1px solid var(--nv-stroke) !important;
  box-shadow: var(--nv-shadow) !important;
  backdrop-filter: blur(10px);
  overflow: hidden;
}
body.page-novios .nv-card{ padding: 18px !important; }

/* List container */
body.page-novios .nv-list{
  display: grid;
  gap: 14px;
}

/* Row helpers (para el HTML que te pasé) */
body.page-novios .nv-row{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  min-width: 0;
}
body.page-novios .nv-row-between{ justify-content: space-between; }
body.page-novios .nv-row-right{ justify-content: flex-end; }
body.page-novios .nv-grow{ flex: 1 1 auto; min-width: 220px; }

/* KPIs */
body.page-novios .nv-kpis{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media (max-width: 860px){
  body.page-novios .nv-kpis{ justify-content: flex-start; }
}
body.page-novios .nv-kpi{
  border-radius: 16px;
  padding: 10px 12px;
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(46,46,46,.10);
  box-shadow: var(--nv-shadow-soft);
  min-width: 120px;
  min-height: 62px;
  display: grid;
  align-content: center;
}
body.page-novios .nv-kpi strong{
  font-family: "Fraunces", serif;
  font-size: 20px;
  line-height: 1;
  letter-spacing: -0.2px;
}

/* Inputs / Selects */
body.page-novios .nv-input,
body.page-novios select.nv-input,
body.page-novios input.nv-input{
  height: var(--nv-h) !important;
  border-radius: var(--nv-radius-md) !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(46,46,46,.16) !important;
  background: var(--nv-bg-input) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  font-family: inherit;
  font-size: 15px;
  line-height: 1.2;
  min-width: 0;
}
body.page-novios .nv-input::placeholder{ color: rgba(20,20,20,.38); }
body.page-novios .nv-input:focus{
  outline: none !important;
  border-color: rgba(184,110,136,.42) !important;
  box-shadow: 0 0 0 4px var(--nv-accent-soft), inset 0 1px 0 rgba(255,255,255,.85) !important;
}

/* Botones */
body.page-novios .btn{
  height: var(--nv-h) !important;
  border-radius: var(--nv-radius-md) !important;
  padding: 0 14px !important;
  font-family: inherit;
  font-weight: 700 !important;
  letter-spacing: .2px;
  min-width: 0;
  transition: transform .14s ease, box-shadow .14s ease, filter .14s ease;
}
body.page-novios .btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
body.page-novios .btn:active{ transform: translateY(0px); }

body.page-novios .btn.ghost{
  background: rgba(255,255,255,.55) !important;
  border: 1px solid rgba(46,46,46,.12) !important;
}
body.page-novios .btn.primary{
  border: 1px solid rgba(184,110,136,.28) !important;
  background: linear-gradient(135deg, rgba(255,255,255,.86), rgba(232,184,198,.55)) !important;
  box-shadow: 0 14px 32px rgba(0,0,0,.12) !important;
}

/* Select Mesa ancho cómodo */
body.page-novios .nv-select-mesa{ width: min(380px, 100%); }

/* Chips (no cortan) */
body.page-novios .chip{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(46,46,46,.10);
  font-size: 12.5px;
  line-height: 1.2;

  white-space: normal;     /* ✅ permite salto */
  overflow: visible;       /* ✅ sin recorte */
  text-overflow: clip;
  max-width: 100%;
  word-break: break-word;
}
body.page-novios a.chip{ text-decoration: none; }

/* Línea de chips dentro de tarjetas */
body.page-novios .nv-chipline{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

/* Tarjetitas internas (reco-item) */
body.page-novios .reco-item{
  border-radius: 18px;
  border: 1px solid rgba(46,46,46,.10);
  background: rgba(255,255,255,.66);
  box-shadow: none;
  overflow: hidden;
}

/* Estados mesas */
body.page-novios .mesa-free{
  border-color: rgba(40,120,80,.28) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(40,120,80,.08)) !important;
}
body.page-novios .mesa-full{
  border-color: rgba(160,60,60,.28) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(160,60,60,.08)) !important;
}

/* Checkbox “solo Sí” */
body.page-novios #onlyYes{
  width: 18px;
  height: 18px;
  accent-color: rgba(184,110,136,.85);
}

/* Fila crear mesa: SIN overflow (única definición) */
body.page-novios .nv-mesas-row{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  align-items: center !important;
}
body.page-novios .nv-mesas-row > *{ min-width: 0 !important; }

body.page-novios #mesaNombre{
  flex: 1 1 360px !important;
  width: auto !important;
}
body.page-novios #mesaCap{
  flex: 0 1 120px !important;
  width: 120px !important;
  max-width: 140px !important;
}
body.page-novios #createMesaBtn{
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  max-width: 100% !important;
}
@media (max-width: 560px){
  body.page-novios #mesaNombre{ flex-basis: 100% !important; }
  body.page-novios #mesaCap{ flex-basis: 140px !important; width: 140px !important; }
  body.page-novios #createMesaBtn{ width: 100% !important; }
}

/* Responsive: header invitado (select + actualizar apilado) */
@media (max-width: 700px){
  body.page-novios #mesaSelect{ width: 100% !important; }
  body.page-novios #reloadBtn{ width: 100%; }
}

/* =========================================================
   MODALES (PIN + PLANO)
========================================================= */
body.page-novios .nv-modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(10,10,10,.45);
  z-index: 9999;
}
body.page-novios .nv-modal.is-on{ display:flex; }
body.page-novios .nv-modal.open{ display:flex; }

body.page-novios .nv-modal-card{
  width: min(560px, 100%);
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.92);
  box-shadow: 0 30px 90px rgba(0,0,0,.28);
  overflow: hidden;
}
body.page-novios .nv-modal-card-wide{
  width: min(1100px, 94vw);
  max-width: 1100px;
}

body.page-novios .nv-modal-head{ padding: 18px 18px 0; }
body.page-novios .nv-modal-body{ padding: 16px 18px 18px; }

body.page-novios .nv-modal-title{
  font-family: "Fraunces", serif !important;
  font-weight: 900;
  letter-spacing: -0.2px;
  margin: 0;
}

body.page-novios .nv-modal-actions{
  padding: 0 18px 18px;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
body.page-novios .nv-modal-actions-between{
  justify-content: space-between;
  align-items: center;
}

@supports (backdrop-filter: blur(10px)){
  body.page-novios .nv-modal{ backdrop-filter: blur(6px); }
}

@media (max-width: 560px){
  body.page-novios .nv-modal-card{ border-radius: 18px; }
  body.page-novios .nv-modal-actions{ justify-content: stretch; }
  body.page-novios .nv-modal-actions .btn{ width: 100%; }
}
/* =========================================================
   EDITOR PLANO — ÚNICO LAYOUT (2 barras + canvas FULL)
   No afecta al resto del sitio. Solo al modal #planModal.
========================================================= */

body.page-novios.nv-plan-open{
  overflow: hidden; /* evita scroll del fondo con el modal abierto */
}

/* Modal grande y alto real */
body.page-novios #planModal .nv-modal-card-wide{
  width: min(1400px, 98vw) !important;
  max-width: 1400px !important;
  height: 94vh !important;
  display: grid !important;
  grid-template-rows: auto 1fr auto !important; /* head | body | actions */
  overflow: hidden !important;
}

/* Cuerpo: columna => barras arriba + editor abajo */
body.page-novios #planModal .nv-modal-body{
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;

  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

/* =========================
   2 FILAS DE ICONOS (TOP)
========================= */
body.page-novios #planModal .plan-topbars{
  flex: 0 0 auto !important;
  display: grid !important;
  gap: 8px !important;
  min-width: 0 !important;
}

body.page-novios #planModal .plan-bar{
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: nowrap !important;

  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;

  padding: 8px !important;
  border: 1px solid rgba(46,46,46,.10) !important;
  background: rgba(255,255,255,.72) !important;
  border-radius: 16px !important;

  scrollbar-width: none;
}
body.page-novios #planModal .plan-bar::-webkit-scrollbar{ display:none; }

body.page-novios #planModal .plan-bar-left{
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
}
body.page-novios #planModal .plan-bar-right{
  margin-left: auto !important;
  min-width: 0 !important;
}

/* Botones icono compactos */
body.page-novios #planModal .plan-ico,
body.page-novios #planModal .plan-mini{
  height: 40px !important;
  width: 40px !important;
  min-width: 40px !important;
  padding: 0 !important;

  border-radius: 14px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

/* Separadores verticales */
body.page-novios #planModal .plan-sep{
  width: 1px !important;
  height: 26px !important;
  background: rgba(0,0,0,.10) !important;
  border-radius: 999px !important;
  flex: 0 0 auto !important;
}

/* Select objetos compacto */
body.page-novios #planModal .plan-obj-select{
  height: 40px !important;
  border-radius: 14px !important;
  padding: 8px 10px !important;
  width: 210px !important;
  flex: 0 0 auto !important;
}

/* =========================
   EDITOR (CANVAS FULL)
========================= */
body.page-novios #planModal .plan-stage{
  flex: 1 1 auto !important;
  width: 100% !important;
  min-height: 0 !important;

  /* ANULA grids antiguos a 2 columnas */
  display: block !important;
}

/* Wrap del canvas: ocupa TODO el alto disponible */
body.page-novios #planModal .plan-wrap{
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;

  border: 1px solid rgba(46,46,46,.10) !important;
  background: rgba(255,255,255,.92) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
}

/* Canvas: estira dentro del contenedor */
body.page-novios #planModal #planCanvas{
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

/* El tip/hint fuera */
body.page-novios #planModal .plan-hint{
  display: none !important;
}

/* Responsive */
@media (max-width: 860px){
  body.page-novios #planModal .nv-modal-card-wide{
    height: 96vh !important;
  }
  body.page-novios #planModal .plan-obj-select{
    width: 180px !important;
  }
}
/* =========================================================
   ACORDEÓN PREMIUM (Mesas / Asignaciones)
   - igual que el resto de la web
========================================================= */

body.page-novios .nv-acc{
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

body.page-novios .nv-acc-h{
  width: 100%;
  border-radius: 18px !important;
  border: 1px solid rgba(46,46,46,.10) !important;
  background: rgba(255,255,255,.76) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.06) !important;
  padding: 14px 14px !important;

  display: grid !important;
  grid-template-columns: 1fr auto auto !important;
  align-items: center !important;
  gap: 10px !important;

  cursor: pointer;
  text-align: left;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

body.page-novios .nv-acc-h:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 34px rgba(0,0,0,.08) !important;
}

body.page-novios .nv-acc-h[aria-expanded="true"]{
  border-color: rgba(184,110,136,.28) !important;
  box-shadow: 0 16px 36px rgba(184,110,136,.10) !important;
}

body.page-novios .nv-acc-title{
  font-family: "Fraunces", serif !important;
  font-weight: 900 !important;
  letter-spacing: -0.2px;
}

body.page-novios .nv-acc-badge{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(46,46,46,.10);
  background: rgba(255,255,255,.88);
  white-space: nowrap;
}

body.page-novios .nv-acc-ico{
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(46,46,46,.10);
  background: rgba(255,255,255,.88);
  transition: transform .18s ease;
}

/* flecha gira */
body.page-novios .nv-acc-h[aria-expanded="false"] .nv-acc-ico{
  transform: rotate(-90deg);
}
body.page-novios .nv-acc-h[aria-expanded="true"] .nv-acc-ico{
  transform: rotate(0deg);
}

/* Panel */
body.page-novios .nv-acc-p{
  margin-top: -6px;
  border-radius: 18px;
  border: 1px solid rgba(46,46,46,.08);
  background: rgba(255,255,255,.62);
  padding: 14px;
}

body.page-novios .nv-acc-p.is-collapsed{
  display: none;
}
/* ✅ INVITADOS PRO: Filtros premium */
body.page-novios .nv-filters{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  gap: 10px;
  margin-top: 10px;
  align-items: center;
}

body.page-novios .nv-filters .nv-input{
  width: 100%;
}

body.page-novios .nv-filters-actions{
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  white-space: nowrap;
}

@media (max-width: 980px){
  body.page-novios .nv-filters{
    grid-template-columns: 1fr 1fr;
  }
  body.page-novios .nv-filters-actions{
    grid-column: 1 / -1;
    justify-content: stretch;
  }
  body.page-novios .nv-filters-actions .btn{
    width: 100%;
  }
}
/* =========================================
   FEEDBACK PRO verde/rojo (flash + shake)
========================================= */
.nv-guest{
  transition: transform .12s ease, box-shadow .12s ease, outline-color .12s ease;
  outline: 2px solid transparent;
  border-radius: 16px; /* por si tu card no lo hereda */
}

@keyframes nvFlashOk{
  0%{ outline-color: rgba(40,160,90,.0); box-shadow: 0 0 0 rgba(40,160,90,0); }
  30%{ outline-color: rgba(40,160,90,.85); box-shadow: 0 0 0 6px rgba(40,160,90,.18); }
  100%{ outline-color: rgba(40,160,90,0); box-shadow: 0 0 0 rgba(40,160,90,0); }
}
@keyframes nvFlashBad{
  0%{ outline-color: rgba(200,60,60,.0); box-shadow: 0 0 0 rgba(200,60,60,0); }
  30%{ outline-color: rgba(200,60,60,.9); box-shadow: 0 0 0 6px rgba(200,60,60,.16); }
  100%{ outline-color: rgba(200,60,60,0); box-shadow: 0 0 0 rgba(200,60,60,0); }
}
@keyframes nvShake{
  0%{ transform: translateX(0); }
  25%{ transform: translateX(-4px); }
  50%{ transform: translateX(4px); }
  75%{ transform: translateX(-3px); }
  100%{ transform: translateX(0); }
}

.nv-flash-ok{ animation: nvFlashOk .55s ease; }
.nv-flash-bad{ animation: nvFlashBad .65s ease; }
.nv-shake{ animation: nvShake .28s ease; }
/* =========================
   Multi-select (Paso 7)
========================= */
.nv-guest.nv-selected{
  outline: 2px solid rgba(184,110,136,.35);
  box-shadow: 0 0 0 3px rgba(184,110,136,.12);
  border-radius: 14px;
}

.nv-sel-check{
  transform: scale(1.05);
}

#multiProgress{
  min-width: 140px;
}
/* ====== Mesas: todas las tarjetas con una sola línea ====== */

#mesasList .reco-item .nv-row{
  flex-wrap: nowrap;
  align-items: center;
}

/* bloque izquierdo (nombre + id) */
#mesasList .reco-item .nv-row > div:first-child{
  min-width: 0;
  flex: 1;
}

/* nombre de la mesa */
#mesasList .reco-item .nv-row > div:first-child > div:first-child{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* bloque derecho (chip + botones) */
#mesasList .reco-item .nv-row > .nv-row{
  flex-wrap: nowrap;
  gap: 8px;
}
/* =========================================================
   FIX EDITAR PLANO · MODAL RESPONSIVE / SCROLL
========================================================= */

#planModal.nv-modal,
#planModal.nv-modal.is-on,
#planModal.nv-modal.open {
  position: fixed;
  inset: 0;
  z-index: 9999;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 14px;
  align-items: flex-start;
}

#planModal .nv-modal-panel,
#planModal .plan-panel,
#planModal > .nv-modal-panel {
  width: min(1280px, 100%);
  max-width: 1280px;
  max-height: none;
  margin: 18px auto;
  overflow: visible;
}

.nv-plan-open {
  overflow: hidden;
}

.plan-stage,
.plan-canvas-wrap,
.plan-canvas-box {
  width: 100%;
  max-width: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

#planCanvas {
  display: block;
  width: 100%;
  min-width: 760px;
  height: 68vh;
  min-height: 520px;
  border-radius: 18px;
}

@media (max-width: 760px) {
  #planModal.nv-modal,
  #planModal.nv-modal.is-on,
  #planModal.nv-modal.open {
    padding: 8px;
  }

  #planModal .nv-modal-panel,
  #planModal .plan-panel,
  #planModal > .nv-modal-panel {
    margin: 8px auto;
    border-radius: 20px;
  }

  #planCanvas {
    min-width: 900px;
    height: 62vh;
    min-height: 460px;
  }
}
/* =========================================================
   PLANO PRO · EDITOR MESAS
========================================================= */

.plan-pro-panel {
  width: min(1500px, 100%);
  max-width: 1500px;
}

.plan-pro-head {
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  padding:22px 22px 12px;
}

.plan-pro-actions {
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.plan-save-state {
  font-size:13px;
  font-weight:800;
  color:rgba(30,120,70,.95);
}

.plan-pro-toolbar {
  margin:0 22px 14px;
  padding:12px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.plan-tool-group {
  display:flex;
  gap:8px;
  align-items:center;
  padding-right:10px;
  border-right:1px solid rgba(0,0,0,.08);
}

.plan-tool-group:last-child {
  border-right:0;
}

.plan-obj-select {
  min-width:190px;
  height:44px;
}

.plan-pro-layout {
  display:grid;
  grid-template-columns:320px 1fr;
  gap:18px;
  padding:0 22px 22px;
}

.plan-side {
  border:1px solid rgba(0,0,0,.08);
  border-radius:20px;
  background:rgba(255,255,255,.72);
  padding:16px;
  max-height:72vh;
  overflow:auto;
}

.plan-side h4 {
  margin:0 0 12px;
  font-family:'Fraunces',serif;
  font-size:18px;
}

.plan-table-list {
  display:grid;
  gap:10px;
  margin-top:12px;
}

.plan-table-card {
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:rgba(255,255,255,.8);
  padding:10px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
}

.plan-table-card strong {
  display:block;
  font-size:14px;
}

.plan-table-card span {
  display:block;
  font-size:12px;
  opacity:.72;
  margin-top:2px;
}

.plan-main {
  min-width:0;
}

.plan-canvas-scroll {
  width:100%;
  height:72vh;
  min-height:540px;
  overflow:auto;
  border:1px solid rgba(0,0,0,.10);
  border-radius:20px;
  background:rgba(255,255,255,.74);
  -webkit-overflow-scrolling:touch;
}

#planCanvas {
  width:2400px !important;
  height:1600px !important;
  min-width:2400px;
  min-height:1600px;
  display:block;
  border-radius:0;
}

.plan-statusbar {
  margin-top:10px;
  padding:10px 12px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:rgba(255,255,255,.72);
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

@media (max-width: 900px) {
  .plan-pro-head {
    padding:16px 14px 10px;
    flex-direction:column;
  }

  .plan-pro-actions {
    justify-content:flex-start;
  }

  .plan-pro-toolbar {
    margin:0 14px 12px;
    overflow-x:auto;
    flex-wrap:nowrap;
  }

  .plan-tool-group {
    flex:0 0 auto;
  }

  .plan-pro-layout {
    grid-template-columns:1fr;
    padding:0 14px 16px;
  }

  .plan-side {
    max-height:240px;
  }

  .plan-canvas-scroll {
    height:58vh;
    min-height:440px;
  }
}
/* FIX SCROLL REAL DEL CANVAS DEL PLANO */
.plan-canvas-scroll {
  overflow: scroll !important;
  touch-action: pan-x pan-y !important;
  overscroll-behavior: contain;
  max-height: 64vh;
}

#planCanvas {
  touch-action: auto !important;
}
/* =========================================================
   PLANO PRO FINAL · SCROLL + CANVAS REAL
========================================================= */

body.page-novios #planModal .plan-pro-layout {
  height: calc(100vh - 250px);
  min-height: 560px;
}

body.page-novios #planModal .plan-side {
  height: 100%;
  max-height: none !important;
  overflow-y: auto !important;
}

body.page-novios #planModal .plan-main {
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}

body.page-novios #planModal .plan-canvas-scroll {
  flex: 1 1 auto;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: auto !important;
  touch-action: pan-x pan-y !important;
  -webkit-overflow-scrolling: touch;
}

body.page-novios #planModal #planCanvas {
  width: 2400px !important;
  height: 1600px !important;
  min-width: 2400px !important;
  min-height: 1600px !important;
  max-width: none !important;
  max-height: none !important;
  flex: 0 0 auto;
}

body.page-novios #planModal .plan-statusbar {
  flex: 0 0 auto;
}

@media (max-width: 900px) {
  body.page-novios #planModal .plan-pro-layout {
    height: calc(100vh - 330px);
    min-height: 520px;
  }

  body.page-novios #planModal .plan-side {
    height: 210px;
    max-height: 210px !important;
  }

  body.page-novios #planModal .plan-canvas-scroll {
    min-height: 360px !important;
  }
}
/* =========================================================
   PLANO PRO · DETALLE MESA SELECCIONADA
========================================================= */

.plan-selected-info {
  margin-top: 14px;
}

.plan-selected-card {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  padding: 14px;
  box-shadow: 0 14px 28px rgba(0,0,0,.05);
}

.plan-selected-card.is-empty {
  border-color: rgba(45,120,78,.24);
}

.plan-selected-card.is-partial {
  border-color: rgba(174,126,28,.30);
}

.plan-selected-card.is-full {
  border-color: rgba(150,45,55,.32);
}

.plan-selected-kicker {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
  opacity: .55;
  margin-bottom: 6px;
}

.plan-selected-title {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.plan-selected-title strong {
  font-family: 'Fraunces', serif;
  font-size: 18px;
}

.plan-selected-title span {
  font-weight: 900;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(0,0,0,.06);
}

.plan-selected-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.plan-selected-meta span {
  font-size: 12px;
  font-weight: 800;
  border-radius: 999px;
  padding: 6px 9px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(0,0,0,.08);
}

.plan-selected-guests {
  margin-top: 10px;
}

.plan-guest-line {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 0;
  border-top: 1px solid rgba(0,0,0,.07);
  font-size: 13px;
}

.plan-guest-line span {
  font-weight: 700;
}

.plan-guest-line em {
  font-style: normal;
  opacity: .65;
  font-weight: 800;
}
/* =========================================================
   PLANO PRO · KPIS INFERIORES
========================================================= */

.plan-statusbar-pro {
  align-items: center;
}

.plan-statusbar-pro span {
  font-weight: 900;
}

#planKpiMesas {
  color: #2d2d2d;
}

#planKpiSentados {
  color: #2f7a4f;
}

#planKpiLibres {
  color: #9a7b20;
}

#planKpiOcupacion {
  color: #b86e88;
}
/* =========================================================
   PLANO PRO · MINIMAPA
========================================================= */

.plan-main {
  position: relative;
}

.plan-minimap-wrap {
  position: absolute;
  right: 18px;
  bottom: 58px;
  width: 220px;
  height: 140px;
  border-radius: 16px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  padding: 8px;
  z-index: 20;
  backdrop-filter: blur(10px);
}

#planMiniMap {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 10px;
}

@media (max-width: 900px) {
  .plan-minimap-wrap {
    width: 150px;
    height: 96px;
    right: 12px;
    bottom: 64px;
  }
}
/* BLOQUEO DE SCROLL CUANDO SE ARRASTRA UN ELEMENTO */
.plan-canvas-scroll.is-dragging {
  overflow: hidden !important;
  touch-action: none !important;
}

.plan-canvas-scroll.is-dragging #planCanvas {
  touch-action: none !important;
  cursor: grabbing;
}
/* =========================================================
   PLANO PRO · LEYENDA SUPERIOR
========================================================= */

.plan-legend-pro {
  margin: 0 22px 14px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.plan-legend-pro span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 900;
  color: rgba(30,30,30,.72);
}

.plan-legend-pro i {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  display: inline-block;
  border: 1px solid rgba(0,0,0,.12);
}

.plan-legend-pro .lg-free {
  background: rgba(45,120,78,.75);
}

.plan-legend-pro .lg-partial {
  background: rgba(174,126,28,.8);
}

.plan-legend-pro .lg-full {
  background: rgba(150,45,55,.8);
}

.plan-legend-pro .lg-object {
  background: rgba(80,80,80,.55);
}

@media (max-width: 900px) {
  .plan-legend-pro {
    margin: 0 14px 12px;
    overflow-x: auto;
    flex-wrap: nowrap;
  }

  .plan-legend-pro span {
    flex: 0 0 auto;
  }
}
/* =========================================================
   FIX FINAL · SCROLL VISIBLE PLANO EDITOR
========================================================= */

body.page-novios #planModal .plan-pro-layout {
  height: calc(100vh - 330px) !important;
  min-height: 520px !important;
  overflow: hidden !important;
}

body.page-novios #planModal .plan-main {
  position: relative !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

body.page-novios #planModal .plan-canvas-scroll {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: scroll !important;
  overflow-x: scroll !important;
  overflow-y: scroll !important;
  scrollbar-width: auto !important;
  -webkit-overflow-scrolling: touch !important;
  touch-action: pan-x pan-y !important;
}

body.page-novios #planModal #planCanvas {
  width: 2400px !important;
  height: 1600px !important;
  min-width: 2400px !important;
  min-height: 1600px !important;
  max-width: none !important;
  max-height: none !important;
  display: block !important;
  flex: 0 0 auto !important;
}

body.page-novios #planModal .plan-statusbar {
  flex: 0 0 auto !important;
}
/* =========================================================
   FIX DEFINITIVO · CANVAS MUEVE ELEMENTOS / CONTENEDOR SCROLL
========================================================= */

body.page-novios #planModal #planCanvas {
  touch-action: none !important;
  cursor: grab;
}

body.page-novios #planModal #planCanvas:active {
  cursor: grabbing;
}

body.page-novios #planModal .plan-canvas-scroll {
  overflow: scroll !important;
  touch-action: auto !important;
  overscroll-behavior: contain !important;
}

body.page-novios #planModal .plan-canvas-scroll.is-dragging {
  overflow: hidden !important;
  touch-action: none !important;
}
/* =========================================================
   FIX FINAL ALTURA EDITOR · CANVAS VISIBLE Y SCROLL ÚTIL
========================================================= */

body.page-novios #planModal .nv-modal-card,
body.page-novios #planModal .nv-modal-card-wide,
body.page-novios #planModal .plan-pro-panel {
  height: 94vh !important;
  max-height: 94vh !important;
  overflow: hidden !important;
}

body.page-novios #planModal .plan-pro-head {
  flex: 0 0 auto !important;
}

body.page-novios #planModal .plan-pro-toolbar {
  flex: 0 0 auto !important;
}

body.page-novios #planModal .plan-legend-pro {
  flex: 0 0 auto !important;
  margin-bottom: 10px !important;
}

body.page-novios #planModal .plan-pro-layout {
  height: calc(94vh - 250px) !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

body.page-novios #planModal .plan-side {
  height: 100% !important;
  max-height: none !important;
  overflow-y: auto !important;
}

body.page-novios #planModal .plan-main {
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

body.page-novios #planModal .plan-canvas-scroll {
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: scroll !important;
}

body.page-novios #planModal .plan-statusbar {
  display: none !important;
}
/* =========================================================
   FIX MINIMAPA · SIEMPRE VISIBLE SOBRE EL PLANO
========================================================= */

body.page-novios #planModal .plan-main {
  position: relative !important;
}

body.page-novios #planModal .plan-minimap-wrap {
  display: block !important;
  position: absolute !important;
  right: 18px !important;
  bottom: 18px !important;
  width: 220px !important;
  height: 140px !important;
  z-index: 60 !important;
  pointer-events: none !important;
  background: rgba(255,255,255,.92) !important;
}

body.page-novios #planModal #planMiniMap {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
/* MINIMAPA FINAL · DESKTOP OK / MÓVIL OCULTO */
body.page-novios #planModal .plan-minimap-wrap {
  width: 220px !important;
  height: 140px !important;
  right: 18px !important;
  bottom: 18px !important;
  opacity: .96 !important;
}

@media (max-width: 900px) {
  body.page-novios #planModal .plan-minimap-wrap {
    display: none !important;
  }
}
/* =========================================================
   INFORMES PRO · ZONA NOVIOS
========================================================= */

.reports-pro-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.report-card {
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  background:
    radial-gradient(circle at 15% 0%, rgba(232,184,198,.26), transparent 34%),
    rgba(255,255,255,.82);
  padding: 16px;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(0,0,0,.045);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.report-card:hover {
  transform: translateY(-2px);
  border-color: rgba(184,110,136,.30);
  box-shadow: 0 18px 38px rgba(184,110,136,.12);
}

.report-card strong {
  display: block;
  font-family: 'Fraunces', serif;
  font-size: 17px;
  line-height: 1.1;
  color: rgba(35,35,35,.95);
}

.report-card span {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.35;
  color: rgba(35,35,35,.62);
}

@media (max-width: 760px) {
  .reports-pro-grid {
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   KPI DASHBOARD PRO
========================================================= */

.mesas-kpis-pro{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:12px;
  margin-bottom:18px;
}

.kpi-mini{
  display:flex;
  align-items:center;
  gap:12px;

  padding:12px 14px;

  background:rgba(255,255,255,.82);
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;

  backdrop-filter:blur(10px);
}

.kpi-ico{
  font-size:24px;
  line-height:1;
}

.kpi-mini strong{
  display:block;
  font-size:22px;
  font-weight:900;
  line-height:1;
}

.kpi-mini small{
  display:block;
  margin-top:4px;
  font-size:12px;
  opacity:.65;
}

@media (max-width:1200px){
  .mesas-kpis-pro{
    grid-template-columns:repeat(4,1fr);
  }
}

@media (max-width:700px){
  .mesas-kpis-pro{
    grid-template-columns:repeat(2,1fr);
  }

  .kpi-mini strong{
    font-size:18px;
  }
}
/* =========================================================
   FIX FINAL ZONA NOVIOS · KPI BAR + LAYOUT PRO
========================================================= */

/* KPIs siempre como barra superior limpia */
body.page-novios .nv-kpis{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  margin:18px 0 26px !important;
}

body.page-novios .mesas-kpis-pro{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:0 !important;
  width:100% !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding:0 !important;

  background:rgba(255,255,255,.78) !important;
  border:1px solid rgba(0,0,0,.08) !important;
  border-radius:22px !important;
  box-shadow:0 18px 44px rgba(0,0,0,.055) !important;
  -webkit-overflow-scrolling:touch !important;
}

body.page-novios .kpi-mini{
  flex:1 0 138px !important;
  min-width:138px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;

  padding:14px 12px !important;
  border:0 !important;
  border-right:1px solid rgba(0,0,0,.08) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

body.page-novios .kpi-mini:last-child{
  border-right:0 !important;
}

body.page-novios .kpi-ico{
  font-size:28px !important;
  line-height:1 !important;
}

body.page-novios .kpi-mini strong{
  display:block !important;
  font-size:24px !important;
  font-weight:900 !important;
  line-height:1 !important;
  color:rgba(20,20,20,.96) !important;
}

body.page-novios .kpi-mini small{
  display:block !important;
  margin-top:4px !important;
  font-size:12px !important;
  line-height:1.1 !important;
  opacity:.72 !important;
  white-space:nowrap !important;
}

/* Corrige el grid principal para que no se corte Gestión de mesas */
body.page-novios .nv-grid,
body.page-novios .nv-main-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr) !important;
  gap:22px !important;
  align-items:start !important;
}

body.page-novios section.card,
body.page-novios .nv-card{
  min-width:0 !important;
  width:100% !important;
  overflow:visible !important;
}

/* Los acordeones y tarjetas no deben salirse/cortarse */
body.page-novios .nv-acc,
body.page-novios .nv-acc-p,
body.page-novios .reports-pro-grid{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}

/* Informes PRO más limpio */
body.page-novios .reports-pro-grid{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}

body.page-novios .report-card{
  min-height:132px !important;
}

/* Responsive real */
@media (max-width: 980px){
  body.page-novios .nv-grid,
  body.page-novios .nv-main-grid{
    grid-template-columns:1fr !important;
  }

  body.page-novios .mesas-kpis-pro{
    margin-bottom:18px !important;
  }

  body.page-novios .kpi-mini{
    flex:0 0 145px !important;
  }
}

@media (max-width: 700px){
  body.page-novios .reports-pro-grid{
    grid-template-columns:1fr !important;
  }

  body.page-novios .kpi-mini{
    flex:0 0 132px !important;
    padding:12px 10px !important;
  }

  body.page-novios .kpi-ico{
    font-size:23px !important;
  }

  body.page-novios .kpi-mini strong{
    font-size:20px !important;
  }
}
/* =========================================================
   FIX DEFINITIVO PANELES ZONA NOVIOS
========================================================= */

body.page-novios main,
body.page-novios .main,
body.page-novios .page {
  max-width: 1500px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.page-novios .nv-grid {
  display: grid !important;
  grid-template-columns: minmax(580px, 1fr) minmax(460px, 0.75fr) !important;
  gap: 28px !important;
  align-items: start !important;
  width: 100% !important;
}

body.page-novios .nv-grid > section.card {
  position: relative !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  transform: none !important;
  margin: 0 !important;
  overflow: visible !important;
}

body.page-novios .nv-grid > section.card:first-child {
  grid-column: 1 !important;
}

body.page-novios .nv-grid > section.card:nth-child(2) {
  grid-column: 2 !important;
}

body.page-novios .card.tip,
body.page-novios .wash,
body.page-novios .nv-card {
  overflow: visible !important;
}

body.page-novios .nv-row {
  min-width: 0 !important;
}

body.page-novios .nv-input,
body.page-novios select,
body.page-novios input {
  max-width: 100% !important;
}

@media (max-width: 1100px) {
  body.page-novios .nv-grid {
    grid-template-columns: 1fr !important;
  }

  body.page-novios .nv-grid > section.card:first-child,
  body.page-novios .nv-grid > section.card:nth-child(2) {
    grid-column: auto !important;
  }
}
/* =========================================================
   FIX FINAL · KPIS UNA LÍNEA + FOOTER ABAJO
========================================================= */

body.page-novios .mesas-kpis-pro{
  position: relative !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  margin: 18px 0 36px !important;
  padding: 0 !important;
}

body.page-novios .kpi-mini{
  flex: 1 0 150px !important;
  min-width: 150px !important;
  max-width: none !important;
  height: 78px !important;
}

body.page-novios .nv-kpis{
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
}

/* Evita que los KPIs se metan encima del título */
body.page-novios main,
body.page-novios .page-main,
body.page-novios .nv-shell{
  overflow-x: hidden !important;
}

/* Footer normal abajo, no lateral */
body.page-novios .footer{
  position: static !important;
  width: 100% !important;
  margin: 42px auto 20px !important;
  padding: 18px 24px !important;
  clear: both !important;
}

body.page-novios .footer .nv-row{
  max-width: 1280px !important;
  margin: 0 auto !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

/* Botón salir visible y elegante abajo */
body.page-novios #logoutBtn{
  position: static !important;
  white-space: nowrap !important;
}

/* Tablet/móvil: KPIs siguen en una línea con scroll horizontal */
@media (max-width: 900px){
  body.page-novios .mesas-kpis-pro{
    margin-top: 14px !important;
    margin-bottom: 24px !important;
  }

  body.page-novios .kpi-mini{
    flex: 0 0 142px !important;
    min-width: 142px !important;
    height: 72px !important;
  }

  body.page-novios .footer .nv-row{
    flex-direction: row !important;
  }
}
/* KPIS FINAL · FUERA DEL TOPBAR */
body.page-novios .nv-topbar{
  display:block !important;
  margin-bottom:18px !important;
}

body.page-novios .mesas-kpis-pro{
  display:flex !important;
  flex-wrap:nowrap !important;
  width:100% !important;
  max-width:100% !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  margin:0 0 28px !important;
  padding:0 !important;
  background:rgba(255,255,255,.82) !important;
  border:1px solid rgba(0,0,0,.08) !important;
  border-radius:22px !important;
  box-shadow:0 18px 44px rgba(0,0,0,.055) !important;
}

body.page-novios .kpi-mini{
  flex:1 0 135px !important;
  min-width:135px !important;
  height:76px !important;
  border:0 !important;
  border-right:1px solid rgba(0,0,0,.08) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

body.page-novios .kpi-mini:last-child{
  border-right:0 !important;
}
/* CARTEL A5 · visible destacado dentro de Informes PRO */
body.page-novios .report-card[data-report="tablecards"]{
  grid-column: 1 / -1 !important;
  min-height: 110px !important;
  border-color: rgba(184,110,136,.28) !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(232,184,198,.30), transparent 32%),
    rgba(255,255,255,.92) !important;
}