/* =========================================================
   /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;
}

