/* =========================
   Tema & Tokens
========================= */
:root{
  /* Paleta */
  --bg:#0b1220; --panel:#0f172a; --muted:#94a3b8; --text:#e5e7eb;
  --b:#1f2937; --brand:#38bdf8; --ok:#28A745; --ok2:#1DB954;
  --sky:#2B84C6; --sky2:#38A1DB; --amber:#B88900; --amber2:#E0A800;
  --err:#962737; --err2:#B02A37; --card-bg:rgba(2,6,23,.45);

  /* Motion util */
  --reveal-y:14px;
  --reveal-dur:.55s;
  --reveal-ease:cubic-bezier(.2,.7,.2,1);

  /* Header */
  --headerH:64px;

  /* Acento dinámico (lo pisa el JS) */
  --accent:#3b82f6;
  --accent-rgb:59,130,246;
}

/* =========================
   Reset & Base
========================= */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Arial,sans-serif}
html{scroll-behavior:smooth}
.container{max-width:1100px;margin:0 auto;padding:18px 16px}
.is-hidden,[hidden]{display:none !important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Accesibilidad: focus visible */
:where(a,button,.pill,.lang-btn,.menu-btn):focus{outline:none}
:where(a,button,.pill,.lang-btn,.menu-btn):focus-visible{
  outline:2px solid var(--brand);outline-offset:2px;box-shadow:0 0 0 4px rgba(56,189,248,.25)
}

/* Skip link */
.skip-link{
  position:absolute;left:8px;top:-40px;z-index:1000;padding:8px 12px;border-radius:10px;
  background:#0b1220;border:1px solid #223048;color:#e5e7eb;text-decoration:none;box-shadow:0 6px 18px rgba(0,0,0,.3)
}
.skip-link:focus{top:8px;outline:2px solid var(--brand);outline-offset:2px}

/* =========================
   Header & Nav
========================= */
.header{
  position:sticky;top:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding-block:14px;min-height:var(--headerH);
  background:rgba(11,18,32,.75);backdrop-filter:blur(8px);
  border-bottom:1px solid #0b1327
}
.brand{flex:1 1 auto}
.logo-full{height:28px;width:auto;display:block}

.nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;flex:2 1 auto;z-index:300}
.pill{
  font-size:13px;color:#cbd5e1;text-decoration:none;border:1px solid #253045;
  padding:6px 12px;border-radius:12px;display:inline-flex;align-items:center;gap:8px;
  transition:.2s background-color,.2s border-color,.2s transform
}
.pill:hover{background:#121a2c;border-color:#344257}
.pill--cta{background:#25d366;color:#0b1220;border-color:#25d366;font-weight:700}
.pill--cta:hover{background:#1ebe5d;border-color:#1ebe5d}

button.pill,.pill.btn{
  -webkit-appearance:none;appearance:none;background:transparent;color:#cbd5e1;
  border:1px solid #253045;padding:8px 12px;border-radius:12px;cursor:pointer;
  transition:.2s background-color,.2s border-color,.15s transform
}
button.pill:hover,.pill.btn:hover{background:#121a2c;border-color:#344257}

.lang-btn{
  margin-left:auto;border:1px solid #2a3a46;background:rgba(2,6,23,.6);
  color:#cbd5e1;border-radius:10px;padding:6px 10px;font-size:12px;cursor:pointer;
  transition:.2s background-color,.2s transform;position:relative;z-index:320
}
.lang-btn:hover{background:#162237;transform:translateY(-1px)}

.menu-btn{display:none;position:relative;width:38px;height:34px;border:1px solid #2a3a46;border-radius:8px;background:rgba(2,6,23,.6);cursor:pointer}
.menu-btn__bar{position:absolute;left:8px;right:8px;height:2px;background:#cbd5e1;transition:transform .25s ease,opacity .25s ease,top .25s ease}
.menu-btn__bar:nth-child(1){top:9px}
.menu-btn__bar:nth-child(2){top:16px}
.menu-btn__bar:nth-child(3){top:23px}
.menu-btn.is-open .menu-btn__bar:nth-child(1){top:16px;transform:rotate(45deg)}
.menu-btn.is-open .menu-btn__bar:nth-child(2){opacity:0}
.menu-btn.is-open .menu-btn__bar:nth-child(3){top:16px;transform:rotate(-45deg)}
.body--lock{overflow:hidden}

@media (max-width:900px){
  [id]{scroll-margin-top:calc(var(--headerH) + 8px)}
  .menu-btn{display:block;margin-left:8px}
  .nav{
    position:absolute;left:0;right:0;top:var(--headerH);
    background:rgba(11,18,32,.98);
    display:flex;flex-direction:column;align-items:stretch;gap:10px;overflow:hidden;
    max-height:0;padding:0;border-top:0;opacity:0;pointer-events:none;
    transition:max-height .42s ease,padding .42s ease,opacity .32s ease,border-top-color .42s ease;z-index:300
  }
  .nav .pill{display:block;width:100%;text-align:left}
  .nav.is-open{max-height:70vh;padding:12px 14px;border-top:1px solid #223048;opacity:1;pointer-events:auto}
  .nav-backdrop{position:fixed;inset:var(--headerH) 0 0 0;background:rgba(0,0,0,.35);backdrop-filter:saturate(.9) blur(2px);z-index:250}
}

/* =========================
   Hero & Secciones
========================= */
.hero{position:relative;z-index:0;text-align:center;padding:28px 16px 6px}
.hero-logo{width:100%;max-width:1200px;height:auto;display:block;margin:0 auto}
.hero-title{font-size:clamp(28px,4vw,44px);font-weight:800;margin:14px 0 6px}
.hero-subtitle{color:#cbd5e1;font-size:clamp(16px,2.2vw,20px)}
.section-title{font-size:22px;margin:18px 0 12px}

/* Grid Cards / Split */
.split__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
@media (max-width:1119px){.split__grid{grid-template-columns:1fr 1fr}}
@media (max-width:679px){.split__grid{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;gap:8px;padding:16px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:var(--card-bg);min-height:164px}
.card .title{font-weight:700}

/* =========================
   Consola & Charts
========================= */
.console .console-box{border:1px solid #243047;background:linear-gradient(180deg,rgba(2,6,23,.4),rgba(2,6,23,.7));border-radius:18px;padding:12px 12px 16px}
.console .console-head{display:flex;align-items:center;justify-content:space-between}
.head-title{font-weight:600;color:#cbd5e1}
.badge{font-size:12px;border:1px solid #2a3a46;padding:4px 8px;border-radius:999px;color:#cbd5e1;background:rgba(56,189,248,.15)}
.badge-online{background:rgba(16,185,129,.25);border-color:#10b981;color:#a7f3d0;animation:pulse-green 1s ease-in-out infinite;box-shadow:0 0 6px rgba(16,185,129,.6)}
@keyframes pulse-green{0%,100%{transform:scale(1);opacity:1;box-shadow:0 0 6px rgba(16,185,129,.6)}50%{transform:scale(1.15);opacity:1;box-shadow:0 0 16px rgba(16,185,129,1)}}

.legend{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;align-items:start;margin:10px 6px}
@media (max-width:520px){.legend{grid-template-columns:1fr}}
.legend .chip{font-size:12px;color:#cbd5e1;border:1px solid #2a3a46;padding:6px 10px;border-radius:10px;background:rgba(2,6,23,.4);display:flex;align-items:center;justify-content:space-between}
.legend .chip b{color:#fff;padding-left:8px}

/* =========================
   Footer & FAB
========================= */
.footer{border-top:1px solid #0b1327;margin-top:24px;padding-top:14px;color:#9aa7b8}
.wa-float{
  position:fixed;right:18px;bottom:18px;z-index:50;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;background:#25d366;border:none;box-shadow:0 10px 26px rgba(0,0,0,.35);
  opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .25s ease,transform .25s ease,background-color .2s ease
}
.wa-float.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.wa-float:hover{background:#1ebe5d}

/* =========================
   Reveal (único y unificado)
========================= */
.reveal{
  opacity:0;transform:translateY(var(--reveal-y));
  transition:opacity var(--reveal-dur) var(--reveal-ease),transform var(--reveal-dur) var(--reveal-ease);
  will-change:opacity,transform;transition-delay:var(--d,0ms)
}
.reveal.is-in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal,.reveal.is-in{transform:none !important;opacity:1 !important}
}

/* =========================
   FAQ (acordeón)
========================= */
.faq.capsula{background:transparent;border-radius:12px;padding:12px 16px}
.faq-list{display:grid;gap:4px}
.faq-item{border:1px solid #223048;border-radius:8px;background:var(--card-bg);overflow:hidden}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:6px 10px;border:0;background:none;color:var(--text);font-size:.92rem;font-weight:600;cursor:pointer;text-align:left
}
.faq-q:hover{background:rgba(255,255,255,.03)}
.faq-q .chev{font-size:.85rem;transform:rotate(0deg);transition:transform .2s ease}
.faq-item[aria-expanded="true"] .faq-q .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease,padding .2s ease,opacity .2s ease;padding:0 10px;opacity:0}
.faq-item[aria-expanded="true"] .faq-a{max-height:200px;padding:0 10px 6px;opacity:1}
.faq-a p{margin:4px 0 0;color:var(--muted);font-size:.88rem;line-height:1.4}

/* =========================
   Página Legal
========================= */
.page-legal [id]{scroll-margin-top:calc(var(--headerH) + 8px)}
.page-legal .container{max-width:1100px;padding:32px 20px}
.page-legal h1,.page-legal h2{color:var(--brand);margin-top:28px;margin-bottom:8px}
.page-legal p{color:var(--muted);line-height:1.6;margin:6px 0 16px}
.page-legal .legal-toc{
  margin:14px 0 24px;padding:12px;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);border-radius:12px
}
.page-legal .legal-toc>div{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:8px}
.page-legal .legal-toc a,.page-legal .legal-toc a:visited{
  display:inline-block;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);color:#e5e7eb;text-decoration:none;font-size:13px
}
.page-legal .legal-toc a:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22)}
.page-legal .doc-box{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px}
.page-legal .doc-box h3{margin-top:0}

/* =========================
   JOIN (Client / Operator)
========================= */
#join .title,.page-join .section-title{
  font-size:clamp(22px,3.6vw,28px);font-weight:800;margin:4px 0 4px;text-align:center;color:#e7f5ff
}
.join-wrap{display:flex;justify-content:center;padding:16px 0}
.join-center{width:100%;max-width:980px;margin:28px auto 16px;padding:0 16px;text-align:center}

/* Tabs */
.join-tabs{
  display:flex;justify-content:center;gap:14px;margin-top:14px;margin-bottom:22px;
  will-change:opacity,transform;
}
.join-tabs .pill{
  padding:9px 14px;border-radius:12px;font-size:.95rem;
  background:#1f2937;border-color:#2a3a46;color:#cbd5e1;
  opacity:0;transform:translateY(10px);
  transition:opacity .50s ease,transform .50s ease;
}
.join-tabs.is-in .pill{opacity:1;transform:none}
.join-tabs .pill:nth-child(1){transition-delay:.06s}
.join-tabs .pill:nth-child(2){transition-delay:.18s}
.join-tabs .pill[aria-selected="true"],.join-tabs .pill.is-active{
  background:#2B84C6;border-color:#2B84C6;color:#0b1220;box-shadow:0 8px 22px rgba(43,132,198,.28)
}

/* Panel base */
.panel{
  width:clamp(360px,96vw,880px);
  margin:0 auto;background:#0f172a;border:1px solid #1e293b;border-radius:16px;
  padding:12px;box-shadow:0 8px 28px rgba(0,0,0,.35);
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .48s ease,transform .48s ease
}
.panel.is-show{opacity:1;transform:none;pointer-events:auto}
section.panel.is-hidden{display:none !important}

/* Grid del formulario */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.form-grid .col{display:grid;gap:10px}
@media (max-width:820px){.form-grid{grid-template-columns:1fr}}

label{display:block;color:#cbd5e1;font-size:.95rem;line-height:1.2}
#join label>span{display:block;margin-bottom:6px;color:var(--muted);font-weight:700}

/* Inputs normales (excluye checkbox/radio) */
:where(input:not([type="checkbox"]):not([type="radio"]), select, textarea){
  width:100%;padding:11px 12px;border-radius:10px;border:1px solid #233244;background:#0b1526;color:#eaf2ff;
  font-size:16px;line-height:1.4;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease
}
::placeholder{color:#9bb0c7}
:where(input:not([type="checkbox"]):not([type="radio"]), select, textarea):focus{
  outline:none;border-color:#2B84C6;box-shadow:0 0 0 3px rgba(43,132,198,.25);background:#0e1a2b
}

/* Checkboxes y radios (tamaño natural + acento) */
input[type="checkbox"],input[type="radio"]{
  width:auto;height:auto;inline-size:auto;background:initial;border:initial;box-shadow:none;vertical-align:middle;accent-color:#2B84C6
}

/* Fila de nombres: First | M | Last */
.name-row{display:grid;grid-template-columns:1.6fr .55fr 1.6fr;gap:10px;align-items:end}
.name-row input[name$="middle"]{text-align:center}
@media (max-width:520px){.name-row{grid-template-columns:1fr 64px 1fr}}

/* Caja contrato (#boxClient/#boxOperator) */
#boxClient,#boxOperator{
  display:block;white-space:pre-wrap;color:#e5e7eb;line-height:1.5;font-size:.95rem;
  padding:1rem;background:rgba(255,255,255,.03);border-radius:8px;max-height:60vh;overflow-y:auto
}

/* CTA centrado (una sola definición) */
.cta-row{display:flex;justify-content:center;gap:.75rem}
.cta-row[hidden]{display:none !important}

/* Radios Empresa/Persona como pills */
#join fieldset[aria-label]{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;border:1px solid #223048;border-radius:12px;padding:10px;background:rgba(2,6,23,.35)
}
#join fieldset[aria-label] label.pill{
  display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:10px;
  border:1px solid #2a3a46;background:#0c1526;color:#cfe2ff;cursor:pointer;user-select:none
}
#join fieldset[aria-label] input[type="radio"]{appearance:none;width:0;height:0}
#join fieldset[aria-label] label.pill:has(input[type="radio"]:checked){
  background:#18324d;border-color:#2B84C6;color:#eaf6ff;box-shadow:inset 0 0 0 1px rgba(43,132,198,.25)
}

/* intl-tel-input — input y flag */
#join .iti{position:relative;width:100%}
#join .iti input[type=tel]{padding-left:92px !important}
#join .iti--separate-dial-code .iti__selected-flag{
  padding:0 8px;background:#0b1526;border:1px solid #2a3a46;border-right:0;border-top-left-radius:10px;border-bottom-left-radius:10px
}
#join .iti--separate-dial-code .iti__selected-dial-code{
  display:inline-block;min-width:34px;margin-left:4px;font-weight:600;color:#eaf2ff;opacity:1
}

/* ====== intl-tel-input – Dropdown pulido (única versión) ====== */
.iti--container{position:absolute !important;z-index:10000 !important}
.iti--container .iti__dropdown-content{
  background:linear-gradient(180deg,rgba(2,6,23,.98),rgba(2,6,23,.94));
  border:1px solid #223048;border-radius:12px;overflow:hidden;box-shadow:0 18px 48px rgba(0,0,0,.55)
}
.iti--container .iti__search-input{
  position:sticky;top:0;z-index:1;display:block;width:100%;
  margin:0;padding:10px 12px;background:#0f172a;color:#eaf2ff;border:0;border-bottom:1px solid #223048;outline:0
}
.iti--container .iti__search-input:focus{
  border-bottom-color:#2B84C6;box-shadow:0 0 0 3px rgba(43,132,198,.25)
}
.iti--container .iti__country-list{
  max-height:min(48vh,420px);padding:6px;background:transparent;border:0;overscroll-behavior:contain
}
.iti--container .iti__country{
  display:grid;grid-auto-flow:column;align-items:center;grid-template-columns:22px 1fr auto;gap:10px;
  padding:8px 10px;border-radius:8px
}
.iti--container .iti__country:hover,
.iti--container .iti__country.iti__highlight{background:rgba(56,189,248,.12)}
.iti--container .iti__country-name{color:#eaf2ff}
.iti--container .iti__dial-code{color:#9fc6ff;font-weight:600}
.iti--container .iti__divider{margin:6px 4px;border-color:#1f2b3d}
.iti--container .iti__country-list::-webkit-scrollbar{width:10px}
.iti--container .iti__country-list::-webkit-scrollbar-thumb{background:#1f2b3d;border-radius:8px}

/* Errores (solo inputs reales) */
:where(input,select,textarea)[aria-invalid="true"]{
  border-color:#f87171 !important;box-shadow:0 0 0 3px rgba(248,113,113,.18) !important
}
/* Grupo de cumplimiento con error: borde sutil, sin aura ancha */
.compliance-list[aria-invalid="true"]{
  border-color:#f87171 !important; box-shadow:none !important;
}

/* =========================
   Operator (ICA) Layout
========================= */
#panelOperator .form-grid{grid-template-columns:1fr !important}
#panelOperator .row-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
#panelOperator .row-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
#panelOperator .split{display:grid;grid-template-columns:1.3fr .9fr;gap:20px;align-items:start}
#panelOperator .licenses-grid{display:grid;grid-template-columns:1.2fr .6fr 1.2fr;gap:12px;align-items:end}
#panelOperator .compliance-list label{display:flex;align-items:flex-start;gap:10px;margin:8px 0}
#panelOperator .compliance-list input[type="checkbox"]{width:18px;height:18px;margin-top:2px}
#panelOperator .name-row label:nth-child(2) input#op_ssn_last4{text-align:center;letter-spacing:.18em}
@media (max-width:960px){#panelOperator .row-3{grid-template-columns:repeat(2,minmax(0,1fr))}#panelOperator .split{grid-template-columns:1fr}}
@media (max-width:560px){#panelOperator .row-3,#panelOperator .row-2{grid-template-columns:1fr}}
.nowrap>span{white-space:nowrap}

/* Caja de checks con marco */
.checkcard{margin-top:10px;padding:12px;border:1px solid #223048;border-radius:12px;background:var(--card-bg)}
.checkcard.compliance-list{display:grid;gap:10px}
.checkcard.compliance-list input[type="checkbox"]{width:18px;height:18px;margin-top:2px;flex:0 0 18px;accent-color:#2B84C6}

/* =========================
   Modales ESIGN / OTP
========================= */
#esignModal,#esignGate{
  position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:16px;background:rgba(6,12,24,.78)
}
.sheet,.esign__sheet{
  position:relative;width:100%;max-width:960px;max-height:90vh;overflow:auto;
  background:#0b1220;color:#fff;border-radius:18px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.35)
}
#esignClose,#gateClose{
  position:absolute;top:10px;right:12px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:#fff;font-size:18px;cursor:pointer
}
#esignClose:hover,#gateClose:hover{background:rgba(255,255,255,.12)}
.esign__sheet iframe,.sheet iframe{width:100%;height:72vh;min-height:420px;border:0;border-radius:12px;background:#fff}
.gate__body{display:grid;gap:12px}
.gate__otp{display:grid;gap:10px}
.gate__otp-row{display:flex;gap:10px;align-items:center}
.gate__status{font-size:.9em;opacity:.85}

/* Progreso lectura (opcional) */
#readProgressBar{
  position:fixed;left:0;top:0;height:3px;width:0;background:#009EFF;box-shadow:0 2px 8px rgba(0,158,255,.4);
  z-index:60;opacity:0;transition:width .15s ease,opacity .2s ease
}

/* =========================
   Inline Help "?" — SOLO click (portal)
========================= */
#join label.has-help{position:relative;overflow:visible}
#join label.has-help>.label-line{display:inline-flex;align-items:center;gap:6px}
#join label.has-help .help-dot{
  width:18px;height:18px;border-radius:999px;display:inline-grid;place-items:center;
  font:700 11px/1 Inter,system-ui,sans-serif;color:#e7f5ff;background:#0b1220;border:1px solid #2B84C6;
  box-shadow:0 2px 8px rgba(0,0,0,.25);cursor:pointer
}
#helpPortal{position:fixed;inset:0;z-index:9999;pointer-events:none}
#helpPortal .help-pop{
  position:absolute;max-width:340px;background:#0f172a;color:#e7f5ff;border:1px solid #223048;border-radius:10px;
  padding:10px 12px;box-shadow:0 14px 36px rgba(0,0,0,.45);pointer-events:auto;transform-origin:top left;
  opacity:0;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease
}
#helpPortal .help-pop.is-in{opacity:1;transform:translateY(0)}
#helpPortal .help-pop::after{
  content:"";position:absolute;width:10px;height:10px;background:#0f172a;border-left:1px solid #223048;border-top:1px solid #223048;
  transform:rotate(45deg);left:12px;top:-6px
}
#helpPortal .help-pop[data-dir="up"]{transform-origin:bottom left}
#helpPortal .help-pop[data-dir="up"]::after{top:auto;bottom:-6px;transform:rotate(225deg)}

/* =========================
   Hint flotante + halo sutil (únicos)
========================= */
.scroll-hint{
  position:fixed;left:50%;bottom:16px;transform:translateX(-50%);
  padding:.55rem .85rem;border:none;border-radius:999px;font-weight:600;font-size:.9rem;
  color:#fff;background:var(--accent);
  box-shadow:0 10px 28px rgba(0,0,0,.35), 0 0 0 2px rgba(var(--accent-rgb), .25);
  z-index:9999;opacity:.96;pointer-events:none
}

/* Halo pequeño (3 pulsos) */
@keyframes pulseRingSmall{
  0%{box-shadow:0 0 0 0 rgba(var(--accent-rgb), .40)}
  60%{box-shadow:0 0 0 8px rgba(var(--accent-rgb), 0)}
  100%{box-shadow:0 0 0 0 rgba(var(--accent-rgb), 0)}
}
.pulse{animation:pulseRingSmall 1.0s ease-out 3}

/* Halo específico para checkbox: no ocupa todo el ancho */
input[type="checkbox"].pulse,
input[type="checkbox"].pulse:focus{
  outline:none;position:relative;box-shadow:none !important
}
input[type="checkbox"].pulse::after{
  content:"";position:absolute;inset:-6px;border-radius:6px;pointer-events:none;
  box-shadow:0 0 0 0 rgba(var(--accent-rgb), .45);animation:pulseRingSmall 1.1s ease-out 3
}

/* Evitar outline si por alguna razón toma foco */
.help-dot[tabindex="-1"]:focus{outline:none !important}

/* === Espaciado cómodo para botones y contenedores === */

/* Más aire dentro de los modales */
.sheet,
.esign__sheet{
  padding:20px 18px; /* antes 16px */
}

/* CTA de los contratos: separar de la caja de texto */
#boxClient + .cta-row,
#boxOperator + .cta-row{
  margin-top:12px;
}

/* Cualquier fila de CTAs: gap y margen vertical uniforme */
.cta-row{
  gap:12px;              /* antes .75rem aprox */
  margin-top:12px;       /* añade respiro con el bloque anterior */
}

/* --- ESIGN Gate / OTP --- */
#esignGate .gate__body{ gap:14px; }               /* separa secciones dentro del sheet */
#esignGate .gate__otp{ gap:14px; }                 /* separa teléfono / código */
#esignGate .gate__otp-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;        /* si no entra, baja a la siguiente línea */
  margin-top:6px;        /* respiro con el input de código */
}
#esignGate .gate__otp-row button{
  padding:10px 16px;     /* botones un poco más “cómodos” */
  border-radius:12px;
  min-width:140px;       /* evita que se vean apretados */
}

/* Estado/errores del gate: en bloque, con margen y wrap */
#esignGate .gate__status{
  margin-top:8px;
  padding:8px 10px;
  border:1px solid #223048;
  border-radius:10px;
  background:rgba(255,255,255,.05);
  max-width:100%;
  word-break:break-word; /* mensajes largos no empujan el layout */
}

/* Que el último elemento no quede pegado al borde inferior del modal */
#esignGate .esign__sheet .gate__body > *:last-child{
  margin-bottom:4px;
}

/* Un pelín más de separación vertical dentro de columnas del form */
.form-grid .col{ gap:12px; } /* antes 10px */
