/* ============================================================
   Fundación Acceso · Taller Espionaje Digital
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --purple-900:#2d1b4e;
  --purple-800:#3d2866;
  --purple-700:#5d3a8f;
  --purple-600:#7b52b0;
  --purple-500:#9b6fc9;
  --purple-100:#f5f1fa;
  --purple-50:#faf7fd;
  --green-600:#5d9968;
  --green-500:#7fb88f;
  --border:#d8cfe5;
  --border-soft:#ece5f3;
  --text:#2d1b4e;
  --text-muted:#6b5b7a;
  --text-soft:#8b6fa8;
  --white:#ffffff;
  --err:#c2410c;
  --bg-gradient-1:#5d3a8f;
  --bg-gradient-2:#7b52b0;
  --bg-gradient-3:#9b6fc9;
}

html,body{height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
  color:var(--text);
  background:
    radial-gradient(ellipse at top left,#3d2866 0%,transparent 50%),
    radial-gradient(ellipse at bottom right,#5d3a8f 0%,transparent 50%),
    #2d1b4e;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.wrap{width:100%;max-width:960px;position:relative;z-index:1}

.card{
  background:var(--white);
  border-radius:18px;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  box-shadow:
    0 30px 80px rgba(0,0,0,.4),
    0 0 0 1px rgba(255,255,255,.08);
  animation:fadeUp .7s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

@media (max-width:820px){
  .card{grid-template-columns:1fr}
  .hero{min-height:280px!important}
}

/* ============ HERO (panel izquierdo con ilustración) ============ */
.hero{
  position:relative;
  min-height:600px;
  background:linear-gradient(165deg,var(--bg-gradient-1) 0%,var(--bg-gradient-2) 50%,var(--bg-gradient-3) 100%);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:30px 28px;
}
.hero-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:0;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    rgba(45,27,78,.55) 0%,
    rgba(93,58,143,.25) 40%,
    rgba(45,27,78,.75) 100%);
  z-index:1;
}
.hero-top,.hero-bottom{position:relative;z-index:2}

.logo{
  max-width:160px;
  height:auto;
  display:block;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));
}

.badge{
  display:inline-block;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
  padding:7px 14px;
  border-radius:999px;
  font-size:10.5px;
  font-weight:600;
  letter-spacing:1.3px;
  margin-bottom:14px;
  animation:pulse 2.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.25)}
  50%{box-shadow:0 0 0 10px rgba(255,255,255,0)}
}

.hero-tag{
  color:#fff;
  font-size:12px;
  line-height:1.55;
  opacity:.92;
  max-width:320px;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}

/* ============ CONTENT (panel derecho formulario) ============ */
.content{
  padding:38px 34px;
  background:var(--white);
  display:flex;
  flex-direction:column;
}

h1{
  font-size:20px;
  font-weight:600;
  color:var(--purple-900);
  line-height:1.3;
  margin-bottom:10px;
  letter-spacing:-.2px;
}

.lead{
  font-size:13px;
  color:var(--text-muted);
  line-height:1.65;
  margin-bottom:22px;
}

/* Meta grid */
.meta{
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-bottom:24px;
}
.meta li{
  background:var(--purple-100);
  border-radius:8px;
  padding:10px 12px;
  border-left:3px solid var(--purple-600);
}
.meta li:nth-child(3),
.meta li:nth-child(4){border-left-color:var(--green-600)}

.meta-label{
  display:block;
  font-size:9.5px;
  color:var(--text-soft);
  text-transform:uppercase;
  letter-spacing:.6px;
  font-weight:600;
  margin-bottom:2px;
}
.meta-value{
  display:block;
  font-size:12.5px;
  color:var(--purple-900);
  font-weight:600;
}

/* Form */
form label{
  display:block;
  font-size:12px;
  font-weight:600;
  color:var(--purple-900);
  margin-bottom:6px;
  margin-top:4px;
}
form label strong{color:var(--purple-700);font-weight:700}

.input-wrap{position:relative;margin-bottom:14px}
.input-icon{
  position:absolute;
  left:12px;
  top:50%;
  transform:translateY(-50%);
  color:var(--text-soft);
  pointer-events:none;
}
input[type=email]{padding-left:36px!important}

input[type=email],
input[type=text]{
  width:100%;
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:8px;
  padding:12px 14px;
  color:var(--purple-900);
  font-size:13px;
  font-family:inherit;
  transition:all .2s ease;
  outline:none;
}
input[type=email]::placeholder,
input[type=text]::placeholder{color:#b0a3c2}
input[type=email]:focus,
input[type=text]:focus{
  border-color:var(--purple-600);
  background:var(--purple-50);
  box-shadow:0 0 0 4px rgba(123,82,176,.12);
}
input[type=text]{margin-bottom:4px}

/* Honeypot */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

button{
  width:100%;
  margin-top:18px;
  background:var(--purple-700);
  color:#fff;
  border:none;
  border-radius:8px;
  padding:14px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  position:relative;
  transition:all .25s ease;
  font-family:inherit;
  letter-spacing:.3px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow:0 6px 18px rgba(93,58,143,.3);
}
button:hover:not(:disabled){
  background:var(--purple-800);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(93,58,143,.4);
}
button:active:not(:disabled){transform:translateY(0)}
button:disabled{opacity:.7;cursor:not-allowed}
button.loading .btn-text,
button.loading .btn-arrow{opacity:0}
button.loading .spinner{opacity:1}

.spinner{
  position:absolute;
  left:50%;top:50%;
  width:20px;height:20px;
  margin:-10px 0 0 -10px;
  border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff;
  border-radius:50%;
  opacity:0;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.err{
  color:var(--err);
  font-size:12px;
  margin-top:10px;
  min-height:16px;
  font-weight:500;
}
.err:not(:empty)::before{content:"⚠ "}

.privacy{
  display:flex;
  align-items:flex-start;
  gap:8px;
  margin-top:16px;
  padding:11px 12px;
  background:var(--purple-100);
  border-radius:8px;
  color:var(--text-muted);
  font-size:10.5px;
  line-height:1.55;
}
.privacy svg{color:var(--purple-600);flex-shrink:0;margin-top:1px}

/* ============ LOADER OVERLAY ============ */
.loader{
  position:fixed;
  inset:0;
  background:rgba(45,27,78,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
  z-index:9999;
}
.loader.show{opacity:1;pointer-events:auto}
.loader-box{
  background:var(--white);
  border-radius:16px;
  padding:40px 56px;
  text-align:center;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
  min-width:280px;
}
.ring{
  width:52px;
  height:52px;
  border:4px solid var(--purple-100);
  border-top-color:var(--purple-700);
  border-right-color:var(--green-600);
  border-radius:50%;
  margin:0 auto 18px;
  animation:spin 1s linear infinite;
}
#loader-msg{
  color:var(--purple-900);
  font-size:14px;
  font-weight:500;
}

/* Success state */
.card.success{animation:successPulse .6s ease}
@keyframes successPulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.005);box-shadow:0 30px 80px rgba(93,153,104,.35)}
  100%{transform:scale(1)}
}
