/* ═══════════════════════════════════════════════════════════
   APEX REGISTRO — Funnel de admisión / Solicitud de plaza
   ═══════════════════════════════════════════════════════════ */

html,body{min-height:100%;font-family:var(--font-body)}
body{background:#07131a;color:#ddeaea;display:flex;flex-direction:column;align-items:center;padding:0;min-height:100vh;overflow-x:hidden}

/* ── Topbar ── */
.top-bar{width:100%;background:rgba(7,19,26,.97);border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:58px;position:sticky;top:0;z-index:200;backdrop-filter:blur(16px)}
.top-left{display:flex;align-items:center;gap:14px}
.top-back{display:flex;align-items:center;justify-content:center;width:30px;height:30px;flex-shrink:0;background:none;border:1px solid var(--border2);border-radius:50%;color:var(--gray);cursor:pointer;padding:0;transition:color .15s,border-color .15s}
.top-back:hover{color:var(--text);border-color:var(--accent-bd)}
.top-logo{display:inline-flex;align-items:center;gap:0;line-height:1}
.top-logo-apex{display:inline-flex;align-items:center;font-family:var(--font-display);font-size:26px;font-weight:900;letter-spacing:.01em;color:var(--text);line-height:1}
.top-logo-apex .lx{color:var(--accent)}
.top-logo-academy-wrap{display:flex;flex-direction:column;justify-content:center;padding-left:8px;border-left:2px solid var(--accent);margin-left:8px;height:22px}
.top-logo-academy{font-family:var(--font-display);font-weight:600;font-size:10px;letter-spacing:.22em;color:var(--gray);line-height:1;text-transform:uppercase}
.top-step-indicator{font-family:var(--font-mono);font-size:11px;color:var(--gray2);letter-spacing:.08em;text-transform:uppercase}
.top-step-indicator span{color:var(--accent)}

/* Barra de progreso sticky */
.funnel-progress{width:100%;height:3px;background:var(--bg3);position:sticky;top:58px;z-index:199}
.funnel-progress-fill{height:100%;background:var(--accent);transition:width .6s cubic-bezier(.4,0,.2,1)}

/* ── Cuerpo del funnel ── */
.funnel-body{width:100%;max-width:740px;padding:44px 24px 88px;display:flex;flex-direction:column;align-items:center}
.step{width:100%;display:none;animation:fadeUp .4s ease}
.step.active{display:flex;flex-direction:column;align-items:center;gap:0}
.step-counter{font-family:var(--font-mono);font-size:11px;color:var(--gray2);letter-spacing:.10em;text-transform:uppercase;margin-bottom:22px;text-align:center}
.step-counter .current{color:var(--accent);font-weight:600}

/* ── Bloque de video ── */
.video-block{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;overflow:hidden;margin-bottom:28px}
.video-header{padding:18px 24px 0;display:flex;align-items:center;gap:10px}
.video-tag{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bd);padding:4px 10px;border-radius:3px}
.video-title-text{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text)}
.video-embed{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#0c1e2c,#091520);position:relative;display:flex;align-items:center;justify-content:center;margin-top:16px}
.vimeo-wrap{position:absolute;inset:0}
.vimeo-wrap iframe{width:100%;height:100%;border:none}
.video-progress-wrap{padding:4px 24px 18px;margin-top:14px}
.video-progress-bar{height:3px;background:var(--bg4);border-radius:99px;overflow:hidden;margin-bottom:7px}
.video-progress-fill{height:100%;background:var(--accent);border-radius:99px;width:0%;transition:width .5s}
.video-time-row{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--gray2)}
.video-cta-wrap{padding:14px 24px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.video-cta-note{font-size:13px;color:var(--gray)}
.video-cta-note.locked{color:var(--gray2);display:flex;align-items:center;gap:7px}

/* ── Bloque de formulario ── */
.form-block{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;overflow:hidden;margin-bottom:28px}
.form-block-header{padding:22px 26px 18px;border-bottom:1px solid var(--border)}
.form-block-title{font-family:var(--font-display);font-size:30px;font-weight:900;color:var(--text);letter-spacing:-.01em;margin-bottom:6px}
.form-block-sub{font-size:15px;color:var(--gray);line-height:1.6}
.form-block-body{padding:22px 26px 26px}

/* Sub-steps */
.substep-bar{display:flex;gap:6px;margin-bottom:20px;width:100%}
.substep-pip{flex:1;height:3px;border-radius:99px;background:var(--bg4);transition:background .3s}
.substep-pip.done{background:var(--accent)}
.substep-pip.active{background:var(--accent);opacity:.5}

/* Campos */
.field{margin-bottom:20px}
.field-label{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:9px;display:flex;align-items:center;gap:5px}
.req{color:var(--accent)}
.field-input,.field-textarea{width:100%;height:50px;padding:0 16px;background:var(--bg3);border:1px solid var(--border2);border-radius:6px;font-family:var(--font-body);font-size:15px;color:var(--text);outline:none;transition:border-color .2s}
.field-input::placeholder,.field-textarea::placeholder{color:var(--gray2)}
.field-input:focus,.field-textarea:focus{border-color:var(--accent-bd)}
.field-textarea{height:96px;resize:none;padding:14px 16px;line-height:1.6}
.fields-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.phone-wrap{display:flex;gap:8px}
.phone-country{flex-shrink:0;height:50px;padding:0 14px;background:var(--bg3);border:1px solid var(--border2);border-radius:6px;font-family:var(--font-mono);font-size:12px;color:var(--gray);display:flex;align-items:center;gap:7px;cursor:pointer;transition:border-color .2s;white-space:nowrap}
.phone-country:hover{border-color:var(--accent-bd)}

/* Select custom */
.custom-select-wrap{position:relative;width:100%}
.custom-select-trigger{width:100%;height:50px;padding:0 16px;background:var(--bg3);border:1px solid var(--border2);border-radius:6px;font-family:var(--font-body);font-size:15px;color:var(--text);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .2s;user-select:none}
.custom-select-trigger .placeholder{color:var(--gray2)}
.custom-select-trigger:hover,.custom-select-trigger.open{border-color:var(--border2)}
.custom-select-trigger.open{border-color:var(--accent-bd)}
.custom-select-arrow{flex-shrink:0;transition:transform .2s;color:var(--gray2)}
.custom-select-trigger.open .custom-select-arrow{transform:rotate(180deg)}
.custom-select-dropdown{position:absolute;left:0;right:0;z-index:150;background:var(--bg4);border:1px solid var(--border2);border-radius:8px;overflow-y:auto;max-height:260px;box-shadow:0 16px 40px rgba(0,0,0,.55);display:none;top:calc(100% + 6px);animation:dropIn .18s ease}
.custom-select-dropdown.up{top:auto;bottom:calc(100% + 6px);animation:dropIn .18s ease}
.custom-select-dropdown.open{display:block}
.custom-select-option{padding:13px 16px;font-family:var(--font-body);font-size:15px;color:var(--text);cursor:pointer;transition:background .12s,color .12s;border-bottom:1px solid var(--border)}
.custom-select-option:last-child{border-bottom:none}
.custom-select-option:hover{background:var(--bg5);color:var(--text)}
.custom-select-option.selected{background:var(--accent-bg);color:var(--accent)}

/* Escala */
.scale-group{display:flex;gap:6px;flex-wrap:wrap}
.scale-btn{flex:1;min-width:46px;height:48px;background:var(--bg3);border:1px solid var(--border2);border-radius:6px;font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--gray);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.scale-btn:hover{border-color:var(--accent-bd);color:var(--accent)}
.scale-btn.selected{background:var(--accent-bg);border-color:var(--accent-bd);color:var(--accent)}
.scale-labels{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--gray2);margin-top:7px}

/* Pills */
.pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.pill{padding:9px 16px;border-radius:99px;font-size:14px;color:var(--gray);background:var(--bg3);border:1px solid var(--border2);cursor:pointer;transition:all .15s}
.pill:hover{border-color:var(--accent-bd);color:var(--accent)}
.pill.selected{background:var(--accent-bg);border-color:var(--accent-bd);color:var(--accent)}
.q-number{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bd);padding:3px 9px;border-radius:3px;margin-bottom:8px;display:inline-block}

/* ── Botón principal ── */
.btn-primary{width:100%;height:54px;background:var(--accent);color:var(--accent-t);font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:filter .15s,transform .1s;position:relative;overflow:hidden;margin-top:10px}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.4;cursor:default;transform:none}
.btn-primary.sending{pointer-events:none;cursor:default;filter:brightness(.9)}
.btn-primary.sending .btn-text{display:none}
.btn-primary.sending .btn-sending{display:flex}
.btn-sending{display:none;align-items:center;gap:6px;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.08em;color:var(--accent-t)}
.sending-dots{display:flex;gap:4px;align-items:center}
.sending-dots span{width:5px;height:5px;border-radius:50%;background:var(--accent-t);animation:dots 1.2s infinite;display:inline-block}
.sending-dots span:nth-child(2){animation-delay:.2s}
.sending-dots span:nth-child(3){animation-delay:.4s}

/* Trust row */
.trust-row{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;font-family:var(--font-mono);font-size:10px;color:var(--gray2);letter-spacing:.06em;margin-top:14px}
.trust-item{display:flex;align-items:center;gap:6px}
.trust-dot{width:5px;height:5px;border-radius:50%;background:var(--green)}

/* Nav de sub-pasos */
.substep-nav{display:flex;gap:10px;margin-top:4px}
.btn-back{height:54px;padding:0 20px;background:transparent;border:1px solid var(--border2);border-radius:6px;font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray);cursor:pointer;transition:border-color .2s,color .2s;flex-shrink:0}
.btn-back:hover{border-color:var(--accent-bd);color:var(--accent)}

/* ── Pantalla de éxito ── */
.success-screen{width:100%;max-width:540px;margin:60px auto;text-align:center;padding:0 24px;display:none}
.success-screen.show{display:block;animation:fadeUp .5s ease}
.success-icon{width:84px;height:84px;border-radius:50%;background:var(--green-bg);border:2px solid rgba(34,197,94,.35);margin:0 auto 26px;display:flex;align-items:center;justify-content:center}
.success-check{stroke-dasharray:100;stroke-dashoffset:100;animation:checkIn .7s cubic-bezier(.4,0,.2,1) .2s forwards}
.success-title{font-family:var(--font-display);font-size:40px;font-weight:900;color:var(--text);line-height:.95;margin-bottom:14px}
.success-name{color:var(--accent)}
.success-desc{font-size:15px;color:var(--gray);line-height:1.7;max-width:440px;margin:0 auto 30px}
.success-card{background:var(--bg2);border:1px solid var(--border2);border-radius:10px;padding:22px 26px;margin-bottom:22px;text-align:left}
.sc-label{font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.sc-items{display:flex;flex-direction:column;gap:10px}
.sc-item{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--gray);line-height:1.55}
.sc-item::before{content:'→';color:var(--accent);flex-shrink:0;font-size:12px;margin-top:2px}
.btn-whatsapp{display:inline-flex;align-items:center;gap:10px;background:#25D166;color:#fff;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.06em;padding:15px 30px;border-radius:6px;border:none;cursor:pointer;transition:filter .15s;text-decoration:none;margin-bottom:16px}
.btn-whatsapp:hover{filter:brightness(1.08)}
.back-link{font-size:13px;color:var(--gray2);cursor:pointer;text-decoration:none;display:inline-block;margin-top:10px}
.back-link:hover{color:var(--accent)}
.resumen-box{background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:16px 20px;margin-bottom:22px;font-size:14px;color:var(--gray);line-height:1.9}
.resumen-box strong{color:var(--text)}

.wpcf7{display:none}

/* ── Botón cierre de funnel ── */
.apex-funnel-finish-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:32px;padding:14px 34px;border-radius:999px;background:#D4AF37;color:#07151C!important;font-weight:800;font-size:15px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none!important;border:2px solid #D4AF37;box-shadow:0 12px 28px rgba(212,175,55,.28);transition:all .25s ease}
.apex-funnel-finish-btn:hover{background:#ffffff;color:#D4AF37!important;border-color:#D4AF37;transform:translateY(-2px);box-shadow:0 16px 36px rgba(212,175,55,.35)}

/* ── Responsive ── */
@media(max-width:600px){
  .fields-row{grid-template-columns:1fr}
  .scale-btn{min-width:38px;height:44px;font-size:15px}
  .top-bar{padding:0 18px}
  .funnel-body{padding:32px 16px 70px}
  .form-block-body,.form-block-header{padding-left:18px;padding-right:18px}
}
