/* =========================================================
   VIGILIUM · MASTER CSS (limpio)
   ========================================================= */

/* ---------------------- HERO / CTA ---------------------- */
.vigi2-hero{
  display:grid; place-items:center;
  margin:min(9vh,60px) auto min(9vh,80px);
  width:min(820px,92vw);
}
.vigi2-hero-inner{
  width:100%; padding:22px 20px; border-radius:26px;
  background:
    radial-gradient(120% 140% at 70% 10%, rgba(124,58,237,.18), transparent 55%),
    radial-gradient(120% 140% at 10% 90%, rgba(34,211,238,.16), transparent 55%),
    linear-gradient(180deg, rgba(15,23,42,.88), rgba(15,23,42,.68));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 80px rgba(0,0,0,.45), inset 0 0 0 1px rgba(255,255,255,.05);
  text-align:center;
}
.vigi2-hero h1{
  margin:0 0 12px; color:#fff;
  font-size:clamp(28px,4.5vw,56px); line-height:1.06;
}
.vigi2-hero p{
  margin:0 0 16px; color:#cbd5e1;
  font-size:clamp(14px,2.2vw,18px); line-height:1.45;
}
.vigi2-cta-wrap{ display:grid; place-items:center; margin-top:6px; }
.vigi2-cta--hero{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 22px; border:0; border-radius:9999px;
  background:linear-gradient(90deg,#7c3aed,#22d3ee);
  color:#fff; font-weight:800; cursor:pointer;
  box-shadow:0 12px 26px rgba(124,58,237,.35);
  transition:transform .12s, box-shadow .15s;
}
.vigi2-cta--hero:hover{ transform:translateY(-1px); box-shadow:0 14px 30px rgba(124,58,237,.45); }
.vigi2-cta--hero .vigi2-cta-text small{ display:none !important; } /* sin subtítulo */

/* ---------------------- THEME / SHELL ------------------- */
#vigi2{
  --bg:rgba(17,24,39,.55);
  --card:rgba(30,41,59,.55);
  --text:#e5e7eb;
  --muted:#94a3b8;
  --accent:#7c3aed;
  --accent2:#22d3ee;
  --ring:rgba(255,255,255,.12);
}
#vigi2 *{ box-sizing:border-box; }
.vigi2{ display:grid; place-items:center; padding:0 10px 10px; }
.vigi2-shell{
  width:100%;
  backdrop-filter: blur(10px);
  background:linear-gradient(180deg,var(--bg),rgba(2,6,23,.35));
  border:1px solid var(--ring);
  border-radius:20px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  overflow:hidden;
}

/* ---------------------- HEADER -------------------------- */
.vigi2-header{
  display:flex; align-items:center; gap:12px;
  padding:14px 16px;
  background:linear-gradient(90deg,#0f172a,#111827);
  color:#fff;
}
.vigi2-title{ display:flex; flex-direction:column; }
.vigi2-title span{ font-weight:800; letter-spacing:.3px; }
.vigi2-title small{ color:var(--muted); font-size:12px; }
.vigi2-progress{ margin-left:auto; width:190px; height:6px; background:rgba(255,255,255,.08); border-radius:999px; overflow:hidden; }
.vigi2-bar{ height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); transition:width .25s ease; }

/* ---------------------- MODAL --------------------------- */
.vigi2-modal{
  position:fixed; inset:0; z-index:9999;
  pointer-events:none; visibility:hidden;
}
.vigi2-modal.is-open{ pointer-events:auto; visibility:visible; }
.vigi2-overlay{
  position:absolute; inset:0;
  background:rgba(2,6,23,.6); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .18s ease;
}
.vigi2-modal.is-open .vigi2-overlay{ opacity:1; }

.vigi2-dialog{
  position:fixed; top:50%; left:50%;
  width:min(640px,92vw); border-radius:18px;
  transform:translate(-50%,-48%) scale(.98);
  opacity:0; transition:transform .22s ease, opacity .22s ease;
}
.vigi2-modal.is-open .vigi2-dialog{
  transform:translate(-50%,-50%) scale(1); opacity:1;
}

/* Botón X */
.vigi2-close{
  position:absolute; top:12px; right:12px;
  padding:8px; border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#e5e7eb; cursor:pointer; line-height:0;
  transition:background .15s ease, transform .1s ease;
  z-index:5;
}
.vigi2-close:hover{ background:rgba(255,255,255,.14); transform:translateY(-1px); }

/* ---------------------- BODY / SLIDE -------------------- */
.vigi2-body{
  height:calc(var(--vh,1vh) * 60);
  min-height:360px;
  max-height:calc(var(--vh,1vh) * 60);
  overflow:hidden;
  padding:16px;
  display:grid; grid-template-rows:auto 1fr;
  background:
    radial-gradient(900px 320px at 10% -10%,rgba(124,58,237,.08),transparent),
    radial-gradient(900px 320px at 90% 110%,rgba(34,211,238,.08),transparent);
}
.vigi2-slide{
  display:grid; grid-template-rows:auto auto;
  gap:14px; align-content:start; height:100%;
}
.vigi2-msg{
  width:100%; max-width:100%;
  padding:14px; border-radius:14px; line-height:1.45;
  border:1px solid var(--ring); animation:vigi2-pop .15s ease;
}
.vigi2-msg.bot{ background:rgba(255,255,255,.06); color:#f1f5f9; border-color:rgba(255,255,255,.15); }
.vigi2-msg.user{ justify-self:end; background:#4f46e5; color:#fff; border-color:rgba(79,70,229,.5); }

/* ---------------------- OPCIONES (chips) ---------------- */
/* 1 sola fila, columnas iguales. Altura auto (puede 2 líneas). Texto blanco. */
.vigi2-options{
  display:grid; grid-auto-flow:column; grid-auto-columns:1fr;
  gap:12px; margin-top:10px; overflow:hidden; padding:0;
}
.vigi2-chip{
  width:100%;
  padding:10px 14px; border-radius:12px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#fff; font-weight:600;
  font-size:clamp(12px,1.1vw,14px);
  line-height:1.25;
  white-space:normal;        /* ← permite salto */
  height:auto;               /* ← ajusta alto */
  text-align:center;
  cursor:pointer;
  transition:transform .12s, box-shadow .12s, background .2s, border-color .2s;
}
.vigi2-chip:hover{
  background:rgba(124,58,237,.28); border-color:rgba(124,58,237,.5);
  box-shadow:0 6px 16px rgba(124,58,237,.35);
}
.vigi2-chip.selected{
  background:linear-gradient(90deg,#7c3aed,#22d3ee);
  color:#fff; border-color:transparent;
  box-shadow:0 10px 24px rgba(124,58,237,.45);
}

/* ---------------------- FOOTER -------------------------- */
.vigi2-footer{
  display:flex; gap:8px; padding:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.08));
  padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));
}
.vigi2-input{
  flex:1 1 auto; min-width:0;
  padding:12px 14px;
  border:1px solid var(--ring); border-radius:12px;
  background:rgba(0,0,0,.35); color:#fff; font-size:15px;
}
.vigi2-input::placeholder{ color:#9ca3af; }

/* Botón “Enviar” como avión de papel */
#vigi2-send{
  display:inline-flex; align-items:center; justify-content:center;
  width:56px; min-width:56px; padding:0;
  border:0; border-radius:12px; cursor:pointer;
  background:linear-gradient(90deg,#7c3aed,#22d3ee); color:#fff; font-weight:700;
  box-shadow:0 6px 18px rgba(124,58,237,.45);
  transition:transform .12s, box-shadow .15s;
}
#vigi2-send:hover{ transform:translateY(-1px); box-shadow:0 10px 22px rgba(124,58,237,.55); }

/* Consentimiento y enlaces legales */
.vigi2-consent label{ display:flex; align-items:center; gap:8px; color:#e5e7eb; flex-wrap:wrap; line-height:1.35; }
#vigi2 .vigi2-consent a{ color:#fff; text-decoration:underline; }

/* Paso de “contact methods” (checkboxes) */
.vigi2-contact{ display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
.vigi2-contact-opt{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px; border-radius:12px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  color:#fff; cursor:pointer; user-select:none;
}
.vigi2-contact-opt input{ transform:scale(1.1); }
.vigi2-contact-next{
  margin-top:10px; align-self:flex-end;
  background:linear-gradient(90deg,#7c3aed,#22d3ee); color:#fff;
  border:none; border-radius:12px; padding:10px 14px; cursor:pointer;
}

/* ---------------------- ANIMACIONES --------------------- */
@keyframes vigi2-pop{ from{transform:scale(.98); opacity:0} to{transform:scale(1); opacity:1} }
@keyframes vigi2-dot{0%,80%,100%{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}

/* ---------------------- RESPONSIVE ---------------------- */
@media (max-width:480px){
  /* Chips algo más compactos pero siguen 1 fila */
  .vigi2-chip{ font-size:12px; padding:8px 10px; }
  #vigi2-send{ width:48px; min-width:48px; }
  .vigi2-dialog{ width:92vw; }
}

/* =========================================================
   FIN
   ========================================================= */
