/* Revamp – Activá tu tarjeta
   CSS aislado para evitar conflictos con rg-revamp-full.css */

:root {
  --rg-act-blue: #1B2B6B;
  --rg-act-blue-mid: #2E3FA3;
  --rg-act-blue-light: #E8EBF7;
  --rg-act-red: #CE0037;
  --rg-act-red-mid: #C0392B;
  --rg-act-red-light: #FDEAEA;
  --rg-act-gray-bg: #FFFFFF;
  --rg-act-gray-mid: #DDE1EA;
  --rg-act-gray-line: #EAEDF3;
  --rg-act-muted: #8A8FA8;
  --rg-act-shadow-sm: 0 2px 8px rgba(27, 43, 107, 0.08);
}

/* Ocultar navbar legacy si se renderiza */
body.rg-active .header-wrapper,
body.rg-active header.row,
body.rg-active nav#header-nav,
body.rg-active #header-nav,
body.rg-active #navbar.nav-wrapper {
  display: none !important;
}

body.rg-active {
  background: var(--rg-act-gray-bg) !important;
}


.rg-act-page {
  min-height: 100vh;
  background: var(--rg-act-gray-bg);
  color: var(--rg-act-blue);
}

.ap-topbar {
  background: var(--rg-act-blue);
  height: 6px;
}



.ap-steps-bar {
  display: flex;
  border-bottom: 1px solid var(--rg-act-gray-line);
  background: #fff;
}
.ap-step-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 20px;
  font-weight: 800;
  font-size: 13px;
  color: var(--rg-act-muted);
  border-bottom: 3px solid transparent;
}
.ap-step-tab.active { color: var(--rg-act-blue); border-bottom-color: var(--rg-act-blue); }
.ap-step-tab.done { color: var(--rg-act-red); border-bottom-color: var(--rg-act-red); }
.ap-step-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  flex-shrink: 0;
}
.ap-step-tab.done .ap-step-num {
  background: var(--rg-act-red);
  border-color: var(--rg-act-red);
  color: #fff;
}
.ap-step-tab.done .ap-step-num::before { content: '✓'; font-size: 11px; }
.ap-step-tab.done .ap-step-num-inner { display: none; }

.act-body {
  max-width: 580px;
  margin: 0 auto;
  padding: 48px 40px 80px;
}
.act-body.rg-step2-open {
  max-width: 980px;
}
.ap-section-title {
  font-weight: 900;
  font-size: 28px;
  color: var(--rg-act-blue);
  letter-spacing: -0.5px;
  margin: 0 0 6px;
}
.ap-section-sub {
  font-size: 14px;
  color: var(--rg-act-muted);
  margin: 0 0 32px;
  padding-bottom: 20px;  
}

.act-state { display: none; }
.act-state.active { display: block; }

.act-form-card {
  background: #fff;
  border-radius: 20px;
  padding: 32px;
  border: 1px solid var(--rg-act-gray-line);
  box-shadow: var(--rg-act-shadow-sm);
}
.act-form-intro {
  font-size: 14px;
  color: var(--rg-act-muted);
  line-height: 1.65;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--rg-act-gray-line);
}

.form-group { margin-bottom: 16px; }
.form-label {
  font-size: 12px;
  font-weight: 800;
  color: var(--rg-act-blue);
  letter-spacing: 0.3px;
  margin-bottom: 6px;
  display: block;
}

.form-input, .form-select {
  width: 100%;
  padding: 12px 16px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  font-size: 15px !important;
  color: var(--rg-act-blue) !important;
  outline: none;
  background: #fff !important;
  box-shadow: none !important;
  margin: 0 !important;
}
.form-input:focus, .form-select:focus { border-color: var(--rg-act-blue) !important; }

.form-error {
  font-size: 12px;
  color: var(--rg-act-red);
  margin-top: 6px;
  font-weight: 700;
  display: none;
  align-items: center;
  gap: 6px;
}
.form-error.show { display: flex; }
.form-error::before {
  content: '!';
  width: 14px;
  height: 14px;
  background: var(--rg-act-red);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 900;
  flex-shrink: 0;
}

.act-card-hint {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--rg-act-blue-light);
  border-radius: 14px;
  padding: 12px 16px;
  margin-top: 10px;
}
.act-card-hint svg { width: 32px; height: 32px; flex-shrink: 0; }
.act-card-hint-text { font-size: 12px; color: var(--rg-act-blue-mid); line-height: 1.5; }
.act-card-hint-text strong { display: block; font-weight: 800; margin-bottom: 2px; }

.act-single-action { margin-top: 24px; }
.btn-continue {
  width: 100%;
  background: var(--rg-act-red);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 14px;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
  letter-spacing: .3px;
  transition: all .2s;
}
.btn-continue:hover { background: var(--rg-act-red-mid); transform: translateY(-1px); }

.act-no-tarjeta {
  margin-top: 20px;
  text-align: center;
  font-size: 13px;
  color: var(--rg-act-muted);
}
.act-no-tarjeta a {
  color: var(--rg-act-blue-mid);
  font-weight: 800;
  text-decoration: none;
  transition: color .2s;
}
.act-no-tarjeta a:hover { color: var(--rg-act-red); }

/* Ajustes visuales del paso 2 (sin tocar KO) */
.rg-act-step2-wrap .row.grey.lighten-3.rg-act-social-row {
  background: transparent !important;
}

.rg-act-step2-card {
  max-width: 920px;
  margin: 0 auto;
}

.rg-act-step2-wrap {
  display: none;
}

.rg-act-separator {
  margin: 6px 0 14px;
  text-align: center;
  font-size: 12px;
  color: var(--rg-act-muted);
  position: relative;
}

.rg-act-separator:before,
.rg-act-separator:after {
  content: "";
  position: absolute;
  top: 50%;
  width: 38%;
  height: 1px;
  background: var(--rg-act-gray-line);
}

.rg-act-separator:before { left: 0; }
.rg-act-separator:after { right: 0; }

.rg-act-step2-wrap .rg-act-social-row {
  background: #f8f9fc !important;
  border-radius: 10px;
  padding: 8px;
}

/* Social buttons del step 2 (estilo mockup) */
.rg-act-step2-wrap .rg-act-social-row .sf-margin-top-15 {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.rg-act-step2-wrap .rg-act-social-row button.cg-btn-social-network {
  flex: 1 !important;
  min-width: 220px;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 44px !important;
  border-radius: 14px !important;
  padding: 0 12px !important;
  box-shadow: none !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  font-family: 'Nunito Sans', sans-serif !important;
}
.rg-act-step2-wrap .rg-act-social-row button.cg-btn-social-network i.fa {
  margin-right: 8px !important;
}

/* Inputs boxed estilo mockup (solo paso 2) */
.rg-act-step2-wrap .validable-input input,
.rg-act-step2-wrap .validable-input select,
.rg-act-step2-wrap input[type="text"],
.rg-act-step2-wrap input[type="password"],
.rg-act-step2-wrap input[type="number"],
.rg-act-step2-wrap input[type="email"],
.rg-act-step2-wrap select.browser-default,
.rg-act-step2-wrap select.input-ga-track {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  font-size: 15px !important;
  color: var(--rg-act-blue) !important;
  outline: none !important;
  background: #fff !important;
  box-shadow: none !important;
  min-height: 44px !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  font-family: 'Nunito Sans', sans-serif !important;
}

.rg-act-step2-wrap .validable-input input:focus,
.rg-act-step2-wrap select.browser-default:focus,
.rg-act-step2-wrap select.input-ga-track:focus {
  border-color: var(--rg-act-blue) !important;
}

/* Labels arriba del input (sin floating) */
.rg-act-step2-wrap .validable-input > label,
.rg-act-step2-wrap .input-field > label {
  position: static !important;
  transform: none !important;
  display: block !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  color: var(--rg-act-blue) !important;
  margin: 0 0 6px !important;
  line-height: 1.2 !important;
}

/* Select arrow + wrapper (Materialize) */
.rg-act-step2-wrap .select-wrapper input.select-dropdown {
  border-radius: 14px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  height: 44px !important;
  padding-left: 16px !important;
  padding-right: 44px !important;
  box-shadow: none !important;
  background: #fff !important;
  color: var(--rg-act-blue) !important;
  font-family: 'Nunito Sans', sans-serif !important;
}
.rg-act-step2-wrap .select-wrapper input.select-dropdown:focus {
  border-color: var(--rg-act-blue) !important;
}

.rg-act-step2-wrap .validationMessage {
  font-size: 11px;
}

/* Recaptcha y checks */
.rg-act-step2-wrap .cg-captcha {
  background: #fff !important;
  border-radius: 14px;
  border: 1.5px solid var(--rg-act-gray-line);
  padding: 12px;
}

.rg-act-result-card {
  border-radius: 20px;
  padding: 28px 32px;
  margin-bottom: 20px;
  background: var(--rg-act-blue-light);
  border: 1.5px solid var(--rg-act-blue);
}

.rg-act-result-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 18px;
  background: var(--rg-act-blue);
}

.rg-act-result-title {
  font-weight: 900;
  font-size: 34px;
  margin: 0 0 8px;
  color: var(--rg-act-blue);
}

.rg-act-result-desc {
  font-size: 14px;
  line-height: 1.65;
  margin-bottom: 20px;
  color: var(--rg-act-blue-mid);
}

.rg-act-identity-row {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  background: rgba(255, 255, 255, .75);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 22px;
}

.rg-act-identity-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--rg-act-muted);
  margin-bottom: 3px;
}

.rg-act-identity-val {
  font-weight: 900;
  font-size: 22px;
  color: var(--rg-act-blue);
}

.rg-act-identity-val.rg-act-pending {
  color: var(--rg-act-red);
}

/* ================================
   Step 2 final - mimic mockup v13
   ================================ */
.act-body.rg-step2-open .rg-act-step2-card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  max-width: 800px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap {
  display: block;
}

.act-body.rg-step2-open .rg-act-step2-wrap .row {
  margin-left: -8px !important;
  margin-right: -8px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .row > .col,
.act-body.rg-step2-open .rg-act-step2-wrap .col.input-field,
.act-body.rg-step2-open .rg-act-step2-wrap .input-field {
  padding-left: 8px !important;
  padding-right: 8px !important;
}

/* disable Materialize widths inside step2 */
.act-body.rg-step2-open .rg-act-step2-wrap .col.s12,
.act-body.rg-step2-open .rg-act-step2-wrap .col.s12.m6,
.act-body.rg-step2-open .rg-act-step2-wrap .col.s12.m6.l6,
.act-body.rg-step2-open .rg-act-step2-wrap .col.s12.m12.l6,
.act-body.rg-step2-open .rg-act-step2-wrap .col.s12.m3,
.act-body.rg-step2-open .rg-act-step2-wrap .col.m3,
.act-body.rg-step2-open .rg-act-step2-wrap .col.m6,
.act-body.rg-step2-open .rg-act-step2-wrap .col.l6 {
  float: none !important;
  width: auto !important;
  left: auto !important;
  right: auto !important;
}

/* Social row */
.act-body.rg-step2-open .rg-act-step2-wrap .rg-act-social-row {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin-bottom: 8px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-act-social-row .sf-margin-top-15 {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-top: 0 !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-act-social-row button.cg-btn-social-network {
  flex: 1 1 220px !important;
  min-width: 220px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  height: 42px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
  padding: 0 14px !important;
  margin: 0 !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-act-social-row p.sf-font-1dot25em {
  font-size: 12px !important;
  color: var(--rg-act-muted) !important;
  margin: 10px 0 0 !important;
  padding: 10px 14px !important;
  background: var(--rg-act-gray-bg) !important;
  border-radius: 8px !important;
}

/* Main identity fields */
.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-main > .col {
  width: 100% !important;
  float: none !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-main .cg-register-customer-data-column,
.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-main .col.s12 {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}

/* Birth date internal 3 columns */
.act-body.rg-step2-open .rg-act-step2-wrap #dateDay,
.act-body.rg-step2-open .rg-act-step2-wrap #dateMonth,
.act-body.rg-step2-open .rg-act-step2-wrap #dateYear {
  width: 100% !important;
  display: block !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .validable-input > div[data-bind*="with: $root.birthDate"] {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 8px !important;
}

/* Contact row: phone + operator */
.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-contact > .col.s12 {
  width: 100% !important;
  float: none !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-contact .input-field {
  margin-bottom: 10px !important;
  min-width: 0 !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-contact > .col.s12 > .row {
  display: grid !important;
  grid-template-columns: 180px 120px 1fr 180px !important;
  gap: 12px !important;
  align-items: end !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap #OperatorCode2 {
  display: flex !important;
  align-items: center !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap #dropdownCountryCode4 {
  position: absolute !important;
  z-index: 30 !important;
}

/* Email/password/terms/actions grouped like mockup */
.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-identity {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-legal {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
  align-items: start !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .rg-row-actions > .col {
  width: 100% !important;
  float: none !important;
}

/* Inputs & labels: make legacy markup look like mockup */
.act-body.rg-step2-open .rg-act-step2-wrap .validable-input {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .validable-input > label,
.act-body.rg-step2-open .rg-act-step2-wrap .input-field > label {
  order: -1 !important;
  position: static !important;
  transform: none !important;
  width: 100% !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--rg-act-blue) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

/* keep checkbox labels inline text */
.act-body.rg-step2-open .rg-act-step2-wrap input[type="checkbox"].filled-in + label {
  position: static !important;
  transform: none !important;
  display: inline !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #3A3A5C !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .validable-input input,
.act-body.rg-step2-open .rg-act-step2-wrap .validable-input select,
.act-body.rg-step2-open .rg-act-step2-wrap .validable-input .OperatorCode,
.act-body.rg-step2-open .rg-act-step2-wrap input[type="text"],
.act-body.rg-step2-open .rg-act-step2-wrap input[type="password"],
.act-body.rg-step2-open .rg-act-step2-wrap input[type="number"],
.act-body.rg-step2-open .rg-act-step2-wrap input[type="email"],
.act-body.rg-step2-open .rg-act-step2-wrap select.browser-default,
.act-body.rg-step2-open .rg-act-step2-wrap select.input-ga-track,
.act-body.rg-step2-open .rg-act-step2-wrap .select-wrapper input.select-dropdown {
  width: 100% !important;
  min-height: 44px !important;
  padding: 12px 16px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  background: #fff !important;
  color: var(--rg-act-blue) !important;
  box-shadow: none !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  font-family: 'Nunito Sans', sans-serif !important;
}

/* Social button colors in mockup style */
.act-body.rg-step2-open .rg-act-step2-wrap button.sf-facebook-button {
  background: #1877F2 !important;
  color: #fff !important;
  border-color: #1877F2 !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap button.sf-google-button {
  background: #fff !important;
  color: #1B2B6B !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap button.apple-sign-in-btn {
  background: #fff !important;
  color: #1B2B6B !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .validable-input input:focus,
.act-body.rg-step2-open .rg-act-step2-wrap .validable-input select:focus,
.act-body.rg-step2-open .rg-act-step2-wrap .select-wrapper input.select-dropdown:focus {
  border-color: var(--rg-act-blue) !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap .select-wrapper {
  width: 100% !important;
}

/* Footer actions */
.act-body.rg-step2-open .rg-act-step2-wrap .row:last-of-type {
  margin-top: 24px !important;
  padding-top: 20px !important;
  border-top: 1px solid var(--rg-act-gray-line) !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap button[data-bind*="$root.goStep1"] {
  border-radius: 14px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  min-height: 44px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap #ButtonSaveForm {
  border-radius: 14px !important;
  min-height: 44px !important;
}

@media (max-width: 600px) {
  .act-body { padding: 28px 20px 60px; }
  .inner-page-nav-inner { padding: 0 20px; }
  .inner-page-spacer { width: 60px; }
  .act-form-card { padding: 24px 20px; }
  .ap-step-tab { font-size: 11px; padding: 12px 8px; gap: 6px; }
  .rg-act-result-card { padding: 22px 20px; }
  .rg-act-identity-val { font-size: 18px; }
  .rg-act-step2-card { max-width: 100%; }
  .act-body.rg-step2-open { max-width: 100%; }
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-main .cg-register-customer-data-column,
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-main .col.s12,
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-identity,
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-legal,
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-actions {
    grid-template-columns: 1fr !important;
  }
  .act-body.rg-step2-open .rg-act-step2-wrap .rg-row-contact > .col.s12 > .row {
    grid-template-columns: 1fr !important;
  }
  .act-body.rg-step2-open .rg-act-step2-wrap #dateDay,
  .act-body.rg-step2-open .rg-act-step2-wrap #dateMonth,
  .act-body.rg-step2-open .rg-act-step2-wrap #dateYear {
    width: 100% !important;
    margin-bottom: 8px !important;
  }
}

/* ---------------- STEP 2 VISUAL REBUILD (encapsulated) ---------------- */
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .row { margin: 0 !important; }
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .col {
  float: none !important;
  width: auto !important;
  left: auto !important;
  right: auto !important;
  padding: 0 !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .input-field { margin: 0 !important; }

.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-main-fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-birth .validable-input > div[data-bind*="with: $root.birthDate"] {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 8px !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-phone-block { margin-top: 14px !important; }
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-block-title {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #1B2B6B !important;
  margin: 0 0 8px !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-phone-grid {
  display: grid !important;
  grid-template-columns: 180px 120px 1fr 180px !important;
  gap: 12px !important;
  align-items: end !important;
}

.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-contact-fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-legal-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  align-items: start !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg-row-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}

/* Labels above controls (non-floating) */
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .validable-input > label,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .input-field > label {
  position: static !important;
  transform: none !important;
  display: block !important;
  margin: 0 0 6px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #1B2B6B !important;
}

/* Keep legal checkbox labels inline */
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout input[type="checkbox"].filled-in + label {
  display: inline !important;
  margin: 0 !important;
  font-size: 13px !important;
  color: #3A3A5C !important;
  font-weight: 600 !important;
}

/* Control look */
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .form-input,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .form-select,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .validable-input input,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .validable-input select,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .select-wrapper input.select-dropdown,
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .OperatorCode {
  width: 100% !important;
  min-height: 44px !important;
  padding: 12px 16px !important;
  border: 1.5px solid #DDE1EA !important;
  border-radius: 14px !important;
  background: #fff !important;
  box-shadow: none !important;
  color: #1B2B6B !important;
  line-height: 1.2 !important;
}
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .validationMessage {
  margin-top: 4px !important;
  font-size: 11px !important;
}

@media (max-width: 600px) {
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-main-fields,
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-contact-fields,
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-legal-grid,
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg-row-actions,
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-phone-grid,
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg2-birth .validable-input > div[data-bind*="with: $root.birthDate"] {
    grid-template-columns: 1fr !important;
  }
}

/* ===== Step 2 clean revamp wrappers ===== */
.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout {
  display: block;
}

.act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg-act-social-block {
  margin-bottom: 14px;
}

/* ---------------- REGISTER AP COMPONENTS ADOPTED ---------------- */

/* SOCIAL BUTTONS & DIVIDER (Adopted) */
.ap-social-row {
  display: flex !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
  flex-wrap: wrap !important;
}
.ap-social-btn {
  flex: 1 !important;
  min-width: 140px !important;
  display: flex !important; 
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 11px 16px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 24px !important;
  font-family: inherit !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  color: var(--rg-act-blue) !important;
  background: #fff !important;
  cursor: pointer !important;
  transition: all .2s !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  height: 44px !important;
  line-height: normal !important;
}
.ap-social-btn:hover { border-color: var(--rg-act-blue) !important; background: #f0f4ff !important; }
.ap-social-btn i { font-size: 16px !important; flex-shrink: 0 !important; }
.ap-social-btn.facebook { color: #1877F2 !important; }

.ap-social-note {
  font-size: 12px !important;
  color: var(--rg-act-muted) !important;
  margin-bottom: 8px !important;
  padding: 10px 14px !important;
  background: #F4F5F8 !important;
  border-radius: 8px !important;
  text-align: center !important;
}
.ap-social-note:empty {
  display: none !important;
}

.ap-divider {
  display: flex !important;
  align-items: center !important;
  text-align: center !important;
  font-size: 13px !important;
  color: var(--rg-act-muted) !important;
  margin: 24px 0 !important;
}
.ap-divider::before, .ap-divider::after {
  content: '' !important;
  flex: 1 !important;
  border-bottom: 1px solid var(--rg-act-gray-line) !important;
}
.ap-divider::before { margin-right: 12px !important; }
.ap-divider::after { margin-left: 12px !important; }

/* FORMULARIO BASE */
.form-group   { margin-bottom: 16px; position:relative; }
.form-label   {
  font-size: 12px;
  font-weight: 700;
  color: var(--rg-act-blue);
  letter-spacing: 0.3px;
  margin-bottom: 6px;
  display: block;
}

input.form-input, select.form-select,
.rg-step2-open input.form-input, .rg-step2-open select.form-select {
  width: 100% !important;
  padding: 0 16px !important; 
  height: 48px !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  font-size: 15px !important;
  color: var(--rg-act-blue) !important;
  outline: none !important;
  background: #fff !important;
  box-sizing: border-box !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}

input.form-input:focus, select.form-select:focus,
.rg-step2-open input.form-input:focus, .rg-step2-open select.form-select:focus { 
  border-color: var(--rg-act-blue) !important; 
  box-shadow: 0 0 0 1px var(--rg-act-blue) !important; 
}

/* GRIDS */
.ap-form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px;}
.ap-form-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px;}
.ap-phone-row   { display: grid; grid-template-columns: 140px 100px 1fr 150px; gap: 12px; align-items: end; }

/* Override legacy inline styles applied via JS on #OperatorCode2 */
#OperatorCode2 {
  padding: 0 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 48px !important;
  box-sizing: border-box !important;
}

#OperatorCode2 > * {
  pointer-events: none !important;
}

#OperatorCode2 > div {
  background: transparent !important;
  border: none !important;
  height: auto !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}

#OperatorCode2 > div > img {
  width: 20px !important;
  height: auto !important;
  margin-right: 8px !important;
flex-shrink: 0;
}

/* ─────────────────────────────────────────────
   SUCCESS SCREEN (Inline & Full Screen Override)
───────────────────────────────────────────── */
.ap-success {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 48px 24px;
  min-height: 60vh;
}
.ap-success-icon {
  width: 72px; height: 72px;
  background: var(--rg-act-blue-pale);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px; font-size: 32px;
}
.ap-success-title {
  font-family: var(--rg-act-font-display);
  font-weight: 900; font-size: 28px;
  color: var(--rg-act-blue);
  margin-bottom: 10px;
}
.ap-success-desc {
  font-size: 15px; color: var(--rg-act-muted);
  line-height: 1.7; margin-bottom: 32px;
}

/* Materialize Modal Override for Fullscreen Success */
#SuccessNewMember.modal {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  top: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-color: #ffffff;
  z-index: 9999 !important;
}
#SuccessNewMember .modal-content {
  height: 100%;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#OperatorCode2 > div > p {
  padding-bottom: 0 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--rg-act-blue) !important;
  flex-grow: 1;
}

#dropdownCountryCode4 {
  position: absolute !important;
  z-index: 50 !important;
  width: 180px !important;
}

/* BOTONES CTA */
.ap-actions {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 16px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid var(--rg-act-gray-line);
}
.btn-back-action {
  background: transparent !important;
  color: var(--rg-act-muted) !important;
  border: 1.5px solid var(--rg-act-gray-mid) !important;
  border-radius: 14px !important;
  padding: 14px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer;
  text-align: center;
  box-shadow: none !important;
  height: auto !important;
  line-height: normal !important;
  width: 100%;
}
.btn-confirm {
  background: var(--rg-act-red) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 14px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  cursor: pointer;
  letter-spacing: 0.3px !important;
  box-shadow: 0px 2px 4px rgba(0,0,0,0.1) !important;
  text-align: center;
  height: auto !important;
  line-height: normal !important;
  width: 100%;
}
.btn-confirm[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* CHECKBOXES LEGALES */
.ap-check-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 20px 0 6px;
}
.ap-check-item {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  position: relative;
}
.ap-check-item input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: var(--rg-act-blue) !important;
  flex-shrink: 0;
  margin-top: 1px;
  cursor: pointer;
  position: relative !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  visibility: visible !important;
  left: auto !important;
}
.ap-check-label { font-size: 13px !important; color: #3A3A5C !important; line-height: 1.5 !important; margin-left: 0 !important; }
.ap-check-label a { color: var(--rg-act-blue-mid) !important; font-weight: 600 !important; text-decoration: none !important; }

/* Overrides for Materialize */
.ap-check-item label {
   position: static;
   padding-left: 0;
   height: auto;
   line-height: 1.5;
}
.ap-check-item label:before { display: none !important; }
.ap-check-item label:after { display: none !important; }

/* CAPTCHA MOCK */
.ap-captcha-wrap { margin: 20px 0; }
.ap-captcha-note { font-size: 12px; color: var(--rg-act-muted); margin-bottom: 8px; }

@media (max-width: 768px) {
  .act-body.rg-step2-open .rg-act-step2-wrap.rg2-layout .rg-act-social-row { flex-direction: column !important; }
  .ap-form-grid-2 { grid-template-columns: 1fr !important; }
  .ap-phone-row { grid-template-columns: 100px 1fr !important; gap: 8px !important; }
  .ap-actions { grid-template-columns: 1fr !important; }
}

/* Validations */
.validationMessage {
  font-size: 12px !important;
  color: var(--rg-act-red) !important;
  margin-top: 5px !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center;
  gap: 4px;
}
.validationMessage:empty {
  display: none !important;
}
.validationMessage::before {
  content: '!';
  width: 14px; height: 14px;
  background: var(--rg-act-red);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 900;
  flex-shrink: 0;
}
