/* ============================================================================
   Icifan — register.css  (registro multipaso, split-screen, temeable dark/light)
   ============================================================================ */
.ici-reg {
  --r-pink: var(--ici-primary, #e6006e);
  --r-purple: var(--ici-secondary, #6c00ff);
  --r-grad: linear-gradient(100deg, var(--r-pink), var(--r-purple));
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  min-height: 100vh; display: grid; grid-template-columns: .8fr 1fr;

  --f-bg1: #fff8fd; --f-bg2: #fff; --f-bg3: #f4f6ff;
  --f-card: #ffffff; --f-text: #101327; --f-muted: #7b8195;
  --f-line: #e2e6f0; --f-input: #fff; --f-chip: rgba(255,255,255,.78);
}
[data-bs-theme="dark"] .ici-reg {
  --f-bg1: #0d0d14; --f-bg2: #101018; --f-bg3: #0b0b12;
  --f-card: #15151d; --f-text: var(--ici-text,#f2f2f5); --f-muted: #9aa2b8;
  --f-line: rgba(255,255,255,.12); --f-input: rgba(255,255,255,.04); --f-chip: rgba(255,255,255,.06);
}
.ici-reg a { text-decoration: none; }

/* Logo */
.ici-reg-logo { font-size: 2rem; font-weight: 900; letter-spacing: -.05em; color: #fff; }
.ici-reg-logo b { background: var(--r-grad); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Panel izquierdo */
.ici-reg-left {
  position: relative; color: #fff; padding: 5vh 4vw; display: flex; align-items: center; overflow: hidden;
  background:
    radial-gradient(circle at 85% 30%, color-mix(in srgb, var(--r-pink) 46%, transparent), transparent 30%),
    radial-gradient(circle at 80% 65%, color-mix(in srgb, var(--r-purple) 42%, transparent), transparent 32%),
    linear-gradient(135deg, #080914 0%, #111326 45%, #351054 100%);
}
.ici-reg-brandlogo { display: inline-block; margin-bottom: 6vh; }
.ici-reg-left h2 { font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 900; letter-spacing: -.03em; }
.ici-reg-left > .ici-reg-left-in > p { color: rgba(255,255,255,.82); margin: 14px 0 32px; font-size: 1.1rem; line-height: 1.5; }
.ici-reg-feats { list-style: none; padding: 0; margin: 0; display: grid; gap: 16px; }
.ici-reg-feats li { display: flex; align-items: center; gap: 12px; font-weight: 600; }
.ici-reg-feats i { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 10px; background: rgba(255,255,255,.12); color: #fff; }

/* Panel derecho */
.ici-reg-right {
  position: relative; display: flex; align-items: flex-start; justify-content: center; padding: 5vh 5vw; overflow-y: auto;
  background:
    radial-gradient(circle at 12% 12%, color-mix(in srgb, var(--r-pink) 12%, transparent), transparent 14%),
    linear-gradient(135deg, var(--f-bg1) 0%, var(--f-bg2) 46%, var(--f-bg3) 100%);
}
.ici-reg-tools { position: absolute; right: 5vw; top: 3vh; display: flex; gap: 10px; z-index: 5; }
.ici-reg-chip { height: 40px; border: 0; background: var(--f-chip); border-radius: 999px; padding: 0 15px; box-shadow: 0 10px 24px rgba(28,31,60,.08); font-weight: 700; color: var(--f-text); cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
.ici-reg-icon { width: 40px; justify-content: center; padding: 0; }
.ici-theme-light-icon { display: none; }
[data-bs-theme="light"] .ici-reg .ici-theme-dark-icon { display: none; }
[data-bs-theme="light"] .ici-reg .ici-theme-light-icon { display: inline; }

.ici-reg-wrap { width: min(100%, 540px); margin-top: 24px; }
.ici-reg-mlogo { text-align: center; margin-bottom: 18px; }
.ici-reg-mlogo .ici-reg-logo { color: var(--f-text); }

/* Stepper */
.ici-reg-stepper { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.ici-reg-stepitem { display: flex; flex-direction: column; align-items: center; gap: 6px; flex: 1; position: relative; }
.ici-reg-stepitem:not(:last-child)::after { content: ""; position: absolute; top: 16px; left: 50%; width: 100%; height: 3px; background: var(--f-line); z-index: 0; }
.ici-reg-stepitem.done:not(:last-child)::after { background: var(--r-pink); }
.ici-reg-stepnum { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; background: var(--f-line); color: var(--f-muted); position: relative; z-index: 1; transition: .2s; }
.ici-reg-stepitem.active .ici-reg-stepnum { background: var(--r-grad); color: #fff; }
.ici-reg-stepitem.done .ici-reg-stepnum { background: var(--r-pink); color: #fff; }
.ici-reg-stepitem span { font-size: .72rem; font-weight: 700; color: var(--f-muted); }
.ici-reg-stepitem.active span { color: var(--r-pink); }

/* Paneles de paso */
.ici-reg-panel { display: none; }
.ici-reg-panel.active { display: block; animation: iciRegFade .25s ease; }
@keyframes iciRegFade { from { opacity: 0; transform: translateX(8px); } to { opacity: 1; transform: none; } }
.ici-reg-title { font-size: 1.5rem; font-weight: 900; letter-spacing: -.03em; color: var(--f-text); margin: 0 0 4px; }
.ici-reg-subtitle { color: var(--f-muted); margin: 0 0 20px; font-size: .95rem; }

.ici-reg-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ici-reg-field { margin-bottom: 16px; }
.ici-reg-field label { display: block; font-weight: 700; font-size: .88rem; color: var(--f-text); margin-bottom: 7px; }
.ici-reg-field input, .ici-reg-field select {
  width: 100%; height: 50px; border: 1.5px solid var(--f-line); border-radius: 11px; padding: 0 14px;
  font: inherit; font-weight: 500; color: var(--f-text); background: var(--f-input); outline: 0; transition: .2s;
}
.ici-reg-field input:focus, .ici-reg-field select:focus { border-color: var(--r-pink); box-shadow: 0 0 0 4px color-mix(in srgb, var(--r-pink) 12%, transparent); }
.ici-reg-err { display: none; color: #dc2626; font-size: .82rem; margin-top: 5px; }
.ici-reg-err.show { display: block; }
.ici-reg-err.is-ok { color: #16a34a; }
.ici-reg-err.is-ok::before { content: "✓ "; font-weight: 800; }
.ici-reg-err.is-checking { color: var(--f-muted); }
/* Borde del input según disponibilidad */
.ici-reg-field input.is-taken { border-color: #dc2626; }
.ici-reg-field input.is-avail { border-color: #16a34a; }

/* Tarjeta informativa (paso ubicación) */
.ici-reg-info {
  display: flex; gap: 14px; align-items: flex-start; margin-bottom: 18px; padding: 16px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--r-pink) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--r-pink) 26%, var(--f-line));
}
.ici-reg-info-icon {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  color: #fff; font-size: 1.2rem; background: var(--r-grad);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--r-pink) 30%, transparent);
}
.ici-reg-info strong { display: block; color: var(--f-text); font-size: .98rem; margin-bottom: 3px; }
.ici-reg-info p { margin: 0; color: var(--f-muted); font-size: .88rem; line-height: 1.45; }

/* Preview del slug icifan.com/usuario */
.ici-reg-slug {
  margin-top: 8px; display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px;
  border-radius: 8px; font-size: .86rem; color: var(--f-muted);
  background: color-mix(in srgb, var(--r-purple) 8%, transparent);
  border: 1px dashed color-mix(in srgb, var(--r-purple) 30%, var(--f-line));
}
.ici-reg-slug i { color: var(--r-pink); }
.ici-reg-slug b { color: var(--r-pink); font-weight: 800; }

.ici-reg-phone { display: grid; grid-template-columns: 120px 1fr; gap: 10px; }
.ici-reg-map { width: 100%; height: 230px; border-radius: 12px; border: 1px solid var(--f-line); margin-top: 4px; }
.ici-reg-hint { color: var(--f-muted); font-size: .82rem; margin: 8px 0 0; }

/* OTP — verificación WhatsApp */
.ici-reg-otp { margin: -4px 0 16px; }
.ici-reg-btn-wa {
  width: 100%; height: 48px; border: 0; border-radius: 11px; cursor: pointer; font-weight: 800; font-size: .95rem;
  color: #fff; background: #25d366; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.ici-reg-btn-wa:hover { filter: brightness(1.05); }
.ici-reg-otp-input { margin-top: 12px; }
.ici-reg-otp-input > label { display: block; font-weight: 700; font-size: .88rem; color: var(--f-text); margin-bottom: 7px; }
.ici-reg-otp-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.ici-reg-otp-row input {
  height: 50px; border: 1.5px solid var(--f-line); border-radius: 11px; padding: 0 14px; font: inherit;
  font-weight: 800; letter-spacing: .3em; text-align: center; color: var(--f-text); background: var(--f-input); outline: 0;
}
.ici-reg-otp-row input:focus { border-color: var(--r-pink); box-shadow: 0 0 0 4px color-mix(in srgb, var(--r-pink) 12%, transparent); }
.ici-reg-btn-verify { padding: 0 20px; border: 0; border-radius: 11px; font-weight: 800; color: #fff; background: var(--r-grad); cursor: pointer; }
.ici-reg-otp-foot { display: flex; align-items: center; gap: 12px; margin-top: 8px; min-height: 20px; }
.ici-reg-resend { border: 0; background: transparent; color: var(--r-pink); font-weight: 700; font-size: .84rem; cursor: pointer; padding: 0; display: inline-flex; align-items: center; gap: 5px; }
.ici-reg-countdown { color: var(--f-muted); font-size: .82rem; }
.ici-reg-otp-ok { margin-top: 10px; color: #16a34a; font-weight: 800; display: flex; align-items: center; gap: 7px; }

/* Password */
.ici-reg-pw { position: relative; }
.ici-reg-pwtoggle { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; color: var(--f-muted); width: 40px; height: 40px; cursor: pointer; }
.ici-reg-strength { display: flex; gap: 6px; margin-top: 10px; }
.ici-reg-strength i { flex: 1; height: 6px; border-radius: 999px; background: var(--f-line); }
.ici-reg-strength i.on.s1 { background: #dc2626; } .ici-reg-strength i.on.s2 { background: #f59e0b; }
.ici-reg-strength i.on.s3 { background: #3b82f6; } .ici-reg-strength i.on.s4 { background: #16a34a; }
.ici-reg-strengthlbl { display: block; font-size: .8rem; font-weight: 700; margin-top: 6px; color: var(--f-muted); }

/* Botones */
.ici-reg-btns { display: flex; gap: 12px; margin-top: 22px; }
.ici-reg-btn { flex: 1; height: 52px; border: 0; border-radius: 12px; font-weight: 800; font-size: 1.02rem; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; transition: transform .18s, box-shadow .18s; }
.ici-reg-btn.primary { color: #fff; background: var(--r-grad); box-shadow: 0 16px 34px color-mix(in srgb, var(--r-pink) 24%, transparent); }
.ici-reg-btn.primary:hover { transform: translateY(-2px); }
.ici-reg-btn.primary:disabled { opacity: .7; transform: none; }
.ici-reg-btn.ghost { flex: 0 0 auto; padding: 0 20px; background: transparent; color: var(--f-text); border: 1.5px solid var(--f-line); }

/* Alert */
.ici-reg-alert { border-radius: 11px; padding: 12px 16px; font-size: .9rem; font-weight: 600; margin-bottom: 16px; }
.ici-reg-alert.err { background: color-mix(in srgb, #dc2626 12%, transparent); color: #dc2626; border: 1px solid color-mix(in srgb, #dc2626 30%, transparent); }
.ici-reg-alert.ok  { background: color-mix(in srgb, #16a34a 14%, transparent); color: #16a34a; border: 1px solid color-mix(in srgb, #16a34a 30%, transparent); }

/* Footer */
.ici-reg-footer { text-align: center; margin-top: 24px; color: var(--f-muted); }
.ici-reg-footer a { color: var(--r-pink); font-weight: 800; }
.ici-reg-badge { text-align: center; margin-top: 14px; font-size: .82rem; color: var(--f-muted); }
.ici-reg-badge i { color: var(--r-pink); }

/* Responsive */
@media (max-width: 992px) {
  .ici-reg { grid-template-columns: 1fr; }
  .ici-reg-left { display: none; }
  .ici-reg-right { padding: 8vh 6vw; }
}
@media (max-width: 560px) {
  .ici-reg-right { padding: 76px 18px 30px; }
  .ici-reg-grid2 { grid-template-columns: 1fr; }
  .ici-reg-stepitem span { font-size: .62rem; }
}
