:root{
  --space:#25344F;
  --slate:#617891;
  --tan:#D5B893;
  --coffee:#6F4D38;
  --caput:#632024;

  --txt: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.62);
  --line: rgba(255,255,255,.12);

  --glass: rgba(255,255,255,.06);
  --glass2: rgba(0,0,0,.18);
  
    /* Panels sólidos (opacos) */
  --panelA: #0F131B;   /* fondo card */
  --panelB: #141A24;   /* degradado card */
  --panelLine: rgba(255,255,255,.10);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:"Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--txt);
  background: #070a10;
  overflow:hidden;
}

.screen{
  position:relative;
  min-height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 52px 16px;
}

/* Fondo */
.bg{ position:absolute; inset:0; pointer-events:none; }
.spot{
  position:absolute; inset:-20%;
  background:
    radial-gradient(1100px 680px at 50% 28%, rgba(255,255,255,.08), transparent 62%),
    radial-gradient(900px 700px at 12% 86%, rgba(99,32,36,.28), transparent 62%),
    radial-gradient(900px 700px at 88% 26%, rgba(97,120,145,.22), transparent 62%),
    radial-gradient(900px 700px at 12% 16%, rgba(37,52,79,.28), transparent 62%),
    linear-gradient(180deg, #070a10, #080b12);
  filter: saturate(1.08);
}
.vignette{
  position:absolute; inset:-2%;
  background: radial-gradient(1200px 900px at 50% 50%, transparent 45%, rgba(0,0,0,.70) 78%, rgba(0,0,0,.96) 100%);
}
.grain{
  position:absolute; inset:-40%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  opacity:.055;
  transform: rotate(5deg);
}

/* Manchas elegantes */
.mist{
  position:absolute;
  width: 1200px;     /* ✅ más grandes */
  height: 1200px;
  border-radius: 999px;
  filter: blur(88px);
  opacity:.22;
  mix-blend-mode: screen;
}

.m1{
  left:-420px; top:-120px;
  background:
    radial-gradient(circle at 32% 30%, rgba(213,184,147,.40), transparent 60%),
    radial-gradient(circle at 70% 65%, rgba(37,52,79,.36), transparent 62%);
}
.m2{
  right:-520px; top:-380px;
  background:
    radial-gradient(circle at 35% 35%, rgba(97,120,145,.44), transparent 60%),
    radial-gradient(circle at 70% 65%, rgba(99,32,36,.34), transparent 62%);
}
.m3{
  left: -80px; bottom:-720px;
  background:
    radial-gradient(circle at 36% 35%, rgba(111,77,56,.46), transparent 60%),
    radial-gradient(circle at 70% 65%, rgba(213,184,147,.26), transparent 65%);
}
.m4{
  right:-120px; bottom:-760px;
  background:
    radial-gradient(circle at 35% 35%, rgba(37,52,79,.40), transparent 60%),
    radial-gradient(circle at 70% 65%, rgba(97,120,145,.20), transparent 65%);
}

/* Contenedor principal */
.shell{
  width: min(520px, 92vw);
  z-index:2;
  display:flex;
  flex-direction:column;
  gap: 18px;
  align-items:center;
}

/* HERO institucional */
.hero{
  width:100%;
  display:flex;
  align-items:center;
  gap: 14px;
  padding: 14px 14px;
  border-radius: 22px;

  /* ✅ sólido (no se ven manchas dentro) */
  background: linear-gradient(180deg, var(--panelB), var(--panelA));
  border: 1px solid var(--panelLine);

  box-shadow: 0 18px 65px rgba(0,0,0,.40);
  backdrop-filter: none; /* ✅ fuera blur para evitar transparencia */
}


.badge{
  width: 78px; height: 78px;
  border-radius: 22px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(213,184,147,.22);
  display:grid;
  place-items:center;
  box-shadow:
    0 18px 55px rgba(0,0,0,.45),
    0 0 0 6px rgba(213,184,147,.05);
  flex: 0 0 auto;
}

.logo{
  width: 54px; height: 54px;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(0گز,0,0,.35));
}

.heroTxt{ flex:1; text-align:left; }
.title{
  margin:0;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .2px;
  line-height: 1.12;
}
.sub{
  margin: 6px 0 0;
  font-size: 12.8px;
  color: var(--muted);
}

.meta{
  margin-top: 10px;
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap:wrap;
}
.pill{
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: .25px;
  color: rgba(0,0,0,.86);
  padding: 6px 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(213,184,147,.95), rgba(213,184,147,.82));
  box-shadow: 0 12px 30px rgba(213,184,147,.12);
}
.sep{
  width: 10px; height: 1px;
  background: rgba(255,255,255,.22);
}
.mini{
  font-size: 12px;
  color: rgba(255,255,255,.58);
}

/* CARD */
.card{
  width:100%;
  position:relative;
  border-radius: 26px;
  padding: 24px 20px 20px;

  /* ✅ sólido (no se ven manchas dentro) */
  background: linear-gradient(180deg, var(--panelB), var(--panelA));
  border: 1px solid var(--panelLine);

  box-shadow:
    0 42px 120px rgba(0,0,0,.65),
    0 18px 60px rgba(0,0,0,.28);

  backdrop-filter: none; /* ✅ clave */
  overflow:hidden;
}


/* brillo superior sutil */
.cardGlow{
  position:absolute; inset:-40% -10% auto -10%;
  height: 240px;
  background:
    radial-gradient(240px 180px at 30% 30%, rgba(213,184,147,.22), transparent 60%),
    radial-gradient(260px 200px at 70% 40%, rgba(97,120,145,.14), transparent 62%);
  opacity:.35;
  pointer-events:none;
}

/* watermark institucional */
.watermark{
  position:absolute;
  inset:auto -40px 10px auto;
  width: 260px; height: 260px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 40% 40%, rgba(213,184,147,.10), transparent 58%),
    radial-gradient(circle at 60% 60%, rgba(37,52,79,.14), transparent 62%);
  filter: blur(1px);
  opacity:.22;
  pointer-events:none;
}

/* header card */
.cardHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 14px;
}

.cardTitle{
  font-weight: 900;
  letter-spacing: .2px;
  font-size: 15.5px;
}
.cardHint{
  margin-top: 4px;
  font-size: 12.3px;
  color: rgba(255,255,255,.56);
}

.statusDot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: rgba(213,184,147,.85);
  box-shadow: 0 0 0 6px rgba(213,184,147,.10);
  margin-top: 6px;
}

/* Alert */
.alert{
  margin: 0 0 14px;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(99,32,36,.22);
  border: 1px solid rgba(213,184,147,.18);
  text-align:left;
}
.alertT{
  display:block;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .2px;
  margin-bottom: 4px;
}
.alertM{ font-size: 13px; color: rgba(255,255,255,.86); }

/* Form */
.form{
  display:flex;
  flex-direction:column;
  gap: 18px;
}

.block{ display:flex; flex-direction:column; gap: 10px; }

.lbl{
  text-align:left;
  font-size: 11.2px;
  margin-top: 6px;
  font-weight: 900;
  letter-spacing: .38px;
  text-transform: uppercase;
  color: rgba(255,255,255,.62);
}

/* Inputs */
.field input{
  width:100%;
  padding: 18px 14px;
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(37,52,79,.20), rgba(0,0,0,.28));
  border: 1px solid rgba(255,255,255,.10);
  color: var(--txt);
  outline:none;
  font-size: 14.5px;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.field input::placeholder{ color: rgba(255,255,255,.34); }

.field input:focus{
  transform: translateY(-1px);
  border-color: rgba(213,184,147,.42);
  box-shadow:
    0 0 0 4px rgba(213,184,147,.10),
    0 18px 70px rgba(0,0,0,.42);
  background:
    linear-gradient(180deg, rgba(37,52,79,.24), rgba(0,0,0,.26));
}

/* Password + ojo */
.fieldPass{ display:flex; align-items:center; gap: 10px; }
.fieldPass input{ flex:1; }

.eye{
  width: 50px; height: 50px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.86);
  cursor:pointer;
  display:grid;
  place-items:center;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.eye:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.085);
  border-color: rgba(213,184,147,.22);
}
.eye:active{ transform: translateY(0px) scale(.99); }

/* Botón */
.actions{ margin-top: 4px; }

.btnPrimary{
  width:100%;
  padding: 16px 14px;
  border-radius: 18px;
  border: 0;
  cursor:pointer;
  font-size: 14.8px;
  font-weight: 900;
  letter-spacing: .2px;
  color: rgba(0,0,0,.86);
  background: linear-gradient(90deg, rgba(213,184,147,.96), rgba(213,184,147,.82));
  box-shadow:
    0 22px 70px rgba(213,184,147,.16),
    0 18px 60px rgba(0,0,0,.40);
  transition: transform .18s ease, filter .18s ease;
  position:relative;
  overflow:hidden;
}
.btnPrimary:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}
.btnPrimary:active{ transform: translateY(0px) scale(.99); }

.btnBar{
  position:absolute; inset:0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.22) 45%, transparent 60%);
  transform: translateX(-120%);
}
.btnPrimary:hover .btnBar{
  transform: translateX(120%);
  transition: transform .85s ease;
}

/* Pie */
.foot{
  margin-top: 18px;
  font-size: 12px;
  color: rgba(255,255,255,.52);
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  flex-wrap: wrap;
  line-height: 1.2;
}
.dot{
  width: 5px; height: 5px;
  border-radius: 999px;
  background: rgba(213,184,147,.58);
}

.fineprint{
  width: min(520px, 92vw);
  text-align:center;
  font-size: 12px;
  color: rgba(255,255,255,.44);
  line-height: 1.35;
  padding: 0 8px;
}
.lock{ opacity:.9; margin-right: 6px; }

/* Responsive */
@media (max-width: 480px){
  .shell{ width: min(420px, 94vw); }
  .hero{ gap: 12px; padding: 12px 12px; }
  .badge{ width: 70px; height: 70px; border-radius: 20px; }
  .logo{ width: 48px; height: 48px; }
  .title{ font-size: 18.5px; }
  .card{ padding: 16px 14px 14px; border-radius: 22px; }
}

/* Motion reduce */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; }
}


.toast{
  position: fixed;
  right: 18px;
  top: 18px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 280px;
  max-width: 360px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  box-shadow: 0 16px 40px rgba(0,0,0,.10);
  transform: translateY(-8px);
  opacity: 0;
  pointer-events: none;
}

.toast--ok .toast__dot{
  background: #16a34a;
}

.toast__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  flex: 0 0 auto;
  box-shadow: 0 0 0 6px rgba(22,163,74,.14);
}

.toast__msg{
  flex: 1 1 auto;
}

.toast__title{
  font-weight: 700;
  font-size: 14px;
  line-height: 1.2;
}

.toast__sub{
  font-size: 12px;
  opacity: .75;
  margin-top: 2px;
}

.toast__x{
  appearance: none;
  border: 0;
  background: transparent;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  opacity: .55;
  padding: 6px 8px;
  border-radius: 10px;
}

.toast__x:hover{ opacity: .9; background: rgba(0,0,0,.06); }

.toast.is-show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  transition: opacity .22s ease, transform .22s ease;
}

.toast.is-hide{
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity .18s ease, transform .18s ease;
}

