*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#06090f;
  --bg2:#080d16;
  --card:#0b1220;
  --card2:#070c18;
  --border:rgba(255,255,255,.06);
  --border-hi:rgba(148,210,180,.2);
  --text:#cdd8e8;
  --muted:#5a6e85;
  --muted2:#3d5166;
  --accent:#94d2b4;
  --accent2:#4a9eff;
  --warm:#e8c97a;
  --danger:#e07070;
  --success:#94d2b4;
}
html{height:100%}
.body-style{
  background:var(--bg);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  line-height:1.6;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
  .light-theme {
    --bg: #f9f9f9;
    --bg-soft: #ffffff;
    --card: #ffffff;
    --card-2: #f4f4f4;
    --text: #0b1220;
    --muted: #5c667a;
    --accent: #4f8cff;
    --accent-2: #4CAF50;
    --warning: #e6a700;
    --danger: #d64545;
    --border: rgba(0, 0, 0, 0.1);
    --shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    --radius: 12px;
    --chip: #eef2ff;
  }

  .light-theme.body-style {
    background: var(--bg);
  }
/* AMBIENT */
.ambient{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 700px 500px at 5% 10%,rgba(74,158,255,.06) 0%,transparent 65%),
    radial-gradient(ellipse 500px 600px at 95% 20%,rgba(148,210,180,.05) 0%,transparent 60%);
}
.grain{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.018;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
 
/* NAV */
header{
  position:relative;z-index:10;
  background:var(--bg-soft);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
}
.nav{
  max-width:1100px;margin:0 auto;
  padding:14px 32px;
  display:flex;align-items:center;justify-content:space-between;
}
.logo{
  font-family:'Fraunces',serif;
  font-size:18px;font-weight:300;color:var(--text);
  text-decoration:none;
  display:flex;align-items:center;gap:9px;
}
.logo-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 7px var(--accent);
}
.nav-back{
  font-size:13px;color:var(--muted);text-decoration:none;
  display:flex;align-items:center;gap:6px;
  transition:color .2s;
}
.nav-back:hover{color:var(--text)}
 
/* LAYOUT PRINCIPAL */
.page{
  position:relative;z-index:1;
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;
}
 
/* PROGRESS */
.progress-wrap{
  display:flex;align-items:center;gap:0;
  margin-bottom:32px;
  justify-content:center;
}
.prog-step{
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:500;
  color:var(--muted2);
  transition:color .4s;
}
.prog-step.active{color:var(--accent)}
.prog-step.done{color:var(--muted)}
.prog-num{
  width:26px;height:26px;border-radius:50%;
  border:1.5px solid var(--muted2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;
  transition:all .4s;
  flex-shrink:0;
}
.prog-step.active .prog-num{
  border-color:var(--accent);
  background:rgba(148,210,180,.1);
  color:var(--accent);
}
.prog-step.done .prog-num{
  border-color:var(--muted);
  background:rgba(255,255,255,.04);
  color:var(--muted);
}
.prog-line{
  width:48px;height:1px;
  background:var(--border);
  margin:0 10px;
  flex-shrink:0;
}
.prog-line.done{background:var(--muted2)}
 
/* CARD WIZARD */
.wizard{
  width:100%;max-width:980px;
  display:grid;grid-template-columns:1fr 1fr;
  border-radius:22px;
  border:1px solid var(--border-hi);
  background:var(--card);
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.5),0 0 0 1px rgba(148,210,180,.05);
}
@media(max-width:740px){.wizard{grid-template-columns:1fr}}
 
/* PANEL IZQUIERDO — info */
.w-info{
  padding:52px 44px;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  justify-content:space-between;
}
@media(max-width:740px){.w-info{display:none}}
.w-info-tag{
  display:inline-flex;align-items:center;gap:7px;
  padding:4px 12px;border-radius:999px;
  border:1px solid rgba(148,210,180,.2);
  background:rgba(148,210,180,.05);
  color:var(--accent);font-size:10px;font-weight:700;
  letter-spacing:1.2px;text-transform:uppercase;
  margin-bottom:22px;width:fit-content;
}
.w-info-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.w-info h2{
  font-family:'Fraunces',serif;
  font-size:clamp(22px,3vw,30px);font-weight:300;
  color:#fff;line-height:1.15;margin-bottom:12px;
}
.w-info h2 em{font-style:italic;color:var(--accent)}
.w-info-sub{color:var(--muted);font-size:13px;line-height:1.75;margin-bottom:32px}
 
.w-bullets{list-style:none;display:grid;gap:12px}
.w-bullet{
  display:flex;align-items:flex-start;gap:12px;
  font-size:13px;color:var(--muted);
}
.w-bullet-ico{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:grid;place-items:center;font-size:14px;
  border:1px solid var(--border);background:rgba(255,255,255,.03);
  margin-top:1px;
}
.w-bullet-title{color:var(--text);font-weight:500;font-size:13px;margin-bottom:2px}
.w-bullet-desc{font-size:12px;color:var(--muted);line-height:1.5}
 
.w-info-footer{
  margin-top:32px;padding-top:20px;
  border-top:1px solid var(--border);
  font-size:11px;color:var(--muted2);line-height:1.6;
}
 
/* PANEL DERECHO — form */
.w-form{
  padding:52px 44px;
  display:flex;flex-direction:column;
}
@media(max-width:480px){.w-form{padding:36px 24px}}
 
.w-form-title{
  font-family:'Fraunces',serif;
  font-size:22px;font-weight:300;color:#fff;
  margin-bottom:6px;
}
.w-form-sub{font-size:13px;color:var(--muted);margin-bottom:28px}
 
/* STEPS container */
.steps-wrap{flex:1}
.step{display:none}
.step.active{display:block;animation:stepIn .4s ease}
@keyframes stepIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
 
/* INPUTS */
.field{margin-bottom:16px}
.field label{
  display:block;font-size:11px;font-weight:600;
  color:var(--muted);letter-spacing:.8px;text-transform:uppercase;
  margin-bottom:7px;
}
.field input{
  width:100%;
  padding:11px 14px;border-radius:11px;
  border:1px solid var(--border);
  background:var(--bg-soft);
  color:var(--text);font-size:14px;
  font-family:'DM Sans',sans-serif;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus{
  border-color:rgba(148,210,180,.4);
  box-shadow:0 0 0 3px rgba(148,210,180,.07);
}
.field input::placeholder{color:var(--muted2)}
.field input.error{border-color:rgba(224,112,112,.45);box-shadow:0 0 0 3px rgba(224,112,112,.07)}
.field-err{font-size:11px;color:var(--danger);margin-top:5px;display:none}
.field-err.show{display:block}
 
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.field-row{grid-template-columns:1fr}}
 
/* CHECKBOX */
.check-wrap{
  display:flex;align-items:flex-start;gap:10px;
  margin-bottom:20px;cursor:pointer;
}
.check-wrap input[type=checkbox]{
  width:16px;height:16px;flex-shrink:0;
  accent-color:var(--accent);margin-top:2px;cursor:pointer;
}
.check-label{font-size:12px;color:var(--muted);line-height:1.55}
.check-label a{color:var(--accent);text-decoration:none}
.check-label a:hover{text-decoration:underline}
 
/* PASSWORD STRENGTH */
.pwd-bars{display:flex;gap:4px;margin-top:7px;height:3px}
.pwd-bar{flex:1;border-radius:2px;background:var(--border);transition:background .3s}
.pwd-bar.weak{background:var(--danger)}
.pwd-bar.medium{background:var(--warm)}
.pwd-bar.strong{background:var(--accent)}
.pwd-hint{font-size:11px;color:var(--muted2);margin-top:5px}
 
/* CEDULA */
.cedula-row{display:flex;gap:8px}
.cedula-row input{flex:1}
.btn-validar{
  padding:11px 16px;border-radius:11px;
  border:1px solid var(--border-hi);
  background:transparent;color:var(--accent);
  font-size:13px;font-weight:600;
  cursor:pointer;white-space:nowrap;
  transition:all .2s;flex-shrink:0;
}
.btn-validar:hover{background:rgba(148,210,180,.08)}
.btn-validar:disabled{opacity:.4;cursor:not-allowed}
 
.cedula-status{
  margin-top:10px;padding:10px 14px;border-radius:10px;
  font-size:12px;font-weight:500;
  display:none;
}
.cedula-status.show{display:flex;align-items:flex-start;gap:8px}
.cedula-status.ok{
  background:rgba(148,210,180,.07);
  border:1px solid rgba(148,210,180,.2);
  color:var(--accent);
}
.cedula-status.err{
  background:rgba(224,112,112,.06);
  border:1px solid rgba(224,112,112,.2);
  color:var(--danger);
}
.cedula-status.loading{
  background:rgba(74,158,255,.06);
  border:1px solid rgba(74,158,255,.15);
  color:var(--accent2);
}
.cedula-detail{display:grid;gap:2px}
.cedula-name{font-weight:600;color:#fff;font-size:13px}
.cedula-meta{font-size:11px;color:var(--muted)}
 
/* SUBMIT / NAV */
.btn-next{
  width:100%;padding:13px;border-radius:12px;
  background:var(--accent);color:#06111e;
  font-weight:700;font-size:14px;
  border:none;cursor:pointer;
  box-shadow:0 6px 24px rgba(148,210,180,.18);
  transition:all .25s;margin-top:4px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 32px rgba(148,210,180,.26)}
.btn-next:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-back{
  width:100%;padding:11px;border-radius:12px;
  border:1px solid var(--border);background:transparent;
  color:var(--muted);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .2s;margin-top:8px;
}
.btn-back:hover{border-color:var(--border-hi);color:var(--text)}
 
/* SPINNER */
.spin{
  width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(6,17,30,.3);
  border-top-color:#06111e;
  animation:spin .7s linear infinite;
  display:none;
}
@keyframes spin{to{transform:rotate(360deg)}}
 
/* SUCCESS STATE */
.success-state{
  display:none;flex-direction:column;align-items:center;
  text-align:center;padding:20px 0;
  animation:stepIn .5s ease;
}
.success-state.show{display:flex}
.success-ico{
  width:56px;height:56px;border-radius:50%;
  background:rgba(148,210,180,.1);border:1.5px solid rgba(148,210,180,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:18px;
}
.success-title{
  font-family:'Fraunces',serif;font-size:22px;font-weight:300;
  color:#fff;margin-bottom:8px;
}
.success-sub{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:24px}
.redirect-bar-wrap{
  width:100%;height:3px;background:var(--border);
  border-radius:2px;overflow:hidden;margin-bottom:12px;
}
.redirect-bar{
  height:100%;background:var(--accent);border-radius:2px;
  width:0%;transition:width linear;
}
.redirect-note{font-size:11px;color:var(--muted2)}
 
/* DIVIDER */
.divider{height:1px;background:var(--border);margin:20px 0}

/* TOGGLE TEMA */
#toggle-theme{
  position:fixed;
  top:16px;right:16px;
  z-index:90;
  width:40px;height:22px;
  border-radius:11px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  cursor:pointer;
  padding:0;
  transition:background .25s,border-color .25s;
}
#toggle-theme::after{
  content:'';
  position:absolute;
  width:16px;height:16px;
  border-radius:50%;
  background:var(--accent);
  top:2px;left:2px;
  transition:transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow:0 0 10px rgba(148,210,180,.3);
}
.light-theme #toggle-theme::after{transform:translateX(18px)}
.light-theme #toggle-theme{
  background:rgba(148,210,180,.1);
  border-color:rgba(148,210,180,.2);
}

/* ====== ROLE SELECTOR ====== */
.role-selector{
  max-width:880px;
  margin:0 auto;
  padding:40px 24px 60px;
  text-align:center;
}
.role-title{
  font-family:'Fraunces',serif;
  font-weight:300;
  font-size:clamp(28px,4vw,42px);
  margin:0 0 12px;
  letter-spacing:-.02em;
  color:var(--text);
}
.role-title em{
  font-style:italic;
  color:var(--accent);
}
.role-sub{
  color:var(--muted);
  font-size:15px;
  margin:0 0 40px;
}
.role-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;
  margin:0 0 32px;
}
.role-card{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:32px 28px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  text-decoration:none;
  color:var(--text);
  transition:border-color .25s,transform .25s,box-shadow .25s;
  text-align:left;
}
.role-card:hover{
  border-color:var(--border-hi);
  transform:translateY(-2px);
  box-shadow:0 18px 40px -22px rgba(148,210,180,.35);
}
.role-card-ico{
  font-size:32px;
  margin:0 0 6px;
}
.role-card-title{
  font-family:'Fraunces',serif;
  font-weight:400;
  font-size:22px;
  letter-spacing:-.01em;
}
.role-card-desc{
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
  flex:1;
}
.role-card-cta{
  color:var(--accent);
  font-weight:600;
  font-size:14px;
  margin-top:10px;
}
.role-card--pro{
  background:linear-gradient(160deg,var(--card) 0%,rgba(148,210,180,.04) 100%);
}
.role-footer{
  color:var(--muted);
  font-size:14px;
}
.role-footer a{
  color:var(--accent);
  text-decoration:none;
  font-weight:600;
}

/* ====== ESTADO POST-REGISTRO PÚBLICO ====== */
.ok-msg{
  text-align:center;
  padding:20px 8px;
}
.ok-msg .ok-ico{
  width:54px;height:54px;
  border-radius:50%;
  background:rgba(148,210,180,.12);
  color:var(--accent);
  font-size:28px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
  border:1px solid rgba(148,210,180,.3);
}
.ok-msg .ok-title{
  font-family:'Fraunces',serif;
  font-size:22px;
  margin:0 0 8px;
}
.ok-msg .ok-sub{
  color:var(--muted);
  font-size:14px;
  margin:0;
}
.err-box{
  margin:14px 0 0;
  padding:12px 14px;
  border-radius:10px;
  background:rgba(224,112,112,.08);
  border:1px solid rgba(224,112,112,.25);
  color:var(--danger);
  font-size:13px;
}
