/* Fondo: lo maneja el fondo global (Fondo.png) */
body{ background: transparent !important; color: var(--navy); }

.back-btn--page{
  position: fixed; top: 20px; left: 20px; z-index: 9999;
  width: 52px; height: 52px; border-radius: 999px;
  display:grid; place-items:center;
  background: var(--gold); color:#151515;
  font-weight:900; font-size:26px; text-decoration:none;
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 45px rgba(7,26,43,.25);
}
.back-btn--page:hover{ transform: translateY(-2px); }
.back-btn--page:active{ transform: translateY(0); opacity:.92; }

.login-page{
  min-height: 100vh;
  display:grid;
  place-items:center;
  padding: 28px 0;
}

.login-card{
  width: min(980px, 92%);
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  border-radius: 22px;
  overflow:hidden;
  background:#fff;
  border: 1px solid rgba(7,26,43,.10);
  box-shadow: 0 26px 70px rgba(7,26,43,.18);
}

.login-left{
  background: var(--navy);
  color:#fff;
  padding: 1.6rem;
  display:flex;
  flex-direction:column;
  gap:.7rem;
}

.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__logo{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(214,178,94,.18);
  border: 1px solid rgba(214,178,94,.45);
  font-weight:800;color:#fff;
}
.brand__name{ font-weight:700; }

.login-left h1{ margin:.5rem 0 0; font-size:2rem; }
.muted{ margin:0; color: rgba(255,255,255,.75); }

.doc-img{
  margin-top:auto;
  width:100%;
  border-radius:18px;
  border: 1px solid rgba(255,255,255,.10);
}

.login-right{ padding: 1.6rem; }

.form{ display:flex; flex-direction:column; gap: 1rem; }
.field label{ font-weight:800; display:block; margin-bottom:.35rem; }

input{
  width:100%;
  padding:.9rem .95rem;
  border-radius:14px;
  border:1px solid rgba(7,26,43,.12);
  outline:none;
  font:inherit;
}
input:focus{
  border-color: rgba(214,178,94,.60);
  box-shadow: 0 0 0 4px rgba(214,178,94,.18);
}

.pw{ position:relative; }
.pw input{ padding-right: 3.2rem; }
.pw__toggle{
  position:absolute; right:.55rem; top:50%; transform: translateY(-50%);
  border: 1px solid rgba(7,26,43,.12);
  background: rgba(7,26,43,.04);
  border-radius: 12px;
  padding: .42rem .55rem;
  cursor:pointer;
}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.9rem 1.1rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:900;
  cursor:pointer;
}
.btn--gold{ background: var(--gold); color:#141414; }
.w100{ width:100%; }

.mini{ margin:.2rem 0 0; color: rgba(7,26,43,.65); }
.link{ color:#b8902f; font-weight:900; text-decoration:none; }
.link:hover{ text-decoration:underline; }

.alert{
  background:#fff3cd;
  border:1px solid #ffe69c;
  padding:.75rem;
  border-radius:14px;
  margin-bottom: .8rem;
}

@media (max-width: 900px){
  .login-card{ grid-template-columns: 1fr; }
  .login-page{ padding: 80px 0 24px; }
  .back-btn--page{ top: 12px; left: 12px; width: 46px; height: 46px; }
}
/* ===== Login layout fix ===== */
.login-page *{ box-sizing: border-box; }

.login-page{
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px 0;
  /* IMPORTANTE:
     El fondo global (Fondo.png) vive en core/static/core/css/base.css.
     Si ponemos un fondo sólido aquí, tapamos la marca de agua.
  */
  background: transparent;
}

.login-card{
  width: min(980px, 92%);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(7,26,43,.10);
  box-shadow: 0 24px 70px rgba(7,26,43,.12);
  overflow: hidden; /* CLAVE: evita que algo se salga */
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* lado izquierdo */
.login-aside{
  background: linear-gradient(180deg, #061821, #071c26);
  color: #fff;
  padding: 26px;
}

/* lado derecho form */
.login-form{
  padding: 26px;
  min-width: 0; /* CLAVE para que inputs no empujen */
}

.login-form form{ display:flex; flex-direction:column; gap: 14px; }

.field{ min-width: 0; }
.field label{ font-weight: 900; display:block; margin-bottom: 6px; }

.login-form input{
  width: 100%;
  max-width: 100%;
  display:block;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(7,26,43,.14);
  outline: none;
  font: inherit;
}

.login-form input:focus{
  border-color: rgba(199,162,74,.75);
  box-shadow: 0 0 0 5px rgba(199,162,74,.20);
}

/* botón dorado */
.login-form .btn-gold{
  width: 100%;
  padding: 14px 16px;
  border-radius: 999px;
  font-weight: 900;
  border: 0;
  cursor: pointer;
  background: linear-gradient(180deg, #c7a24a, #b38f3d);
  color: #0b1320;
  box-shadow: 0 14px 34px rgba(199,162,74,.28);
}
.login-form .btn-gold:active{ transform: translateY(1px); }

/* ojo contraseña alineado (si usas icono) */
.input-with-icon{
  position: relative;
}
.input-with-icon input{ padding-right: 48px; }
.input-with-icon .toggle-pass{
  position:absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(7,26,43,.14);
  background: rgba(7,26,43,.03);
  cursor: pointer;
}

/* responsive */
@media (max-width: 900px){
  .login-card{ grid-template-columns: 1fr; }
}
.back-btn{
  position: fixed;
  top: 18px;
  left: 18px;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
  color: #0b1320;
  background: linear-gradient(180deg, #c7a24a, #b38f3d);
  box-shadow: 0 14px 34px rgba(199,162,74,.28);
  z-index: 200;
}
.back-btn:active{ transform: translateY(1px); }
.login-illus{
  margin-top: 18px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}

.login-illus img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
/* --- FIX: centrar el botón del ojo respecto al INPUT --- */
.input-with-icon{
  position: relative;
}

.input-with-icon input{
  padding-right: 56px; /* espacio para el botón */
}

/* En vez de top:50%, lo anclamos al centro del input */
.input-with-icon .toggle-pass{
  position: absolute;
  right: 12px;
  top: 46px;            /* ajusta fino si tu input es más alto */
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid rgba(7,26,43,.14);
  background: rgba(7,26,43,.03);
  cursor: pointer;
}
.pw{
  position: relative;
}

.pw input{
  width: 100%;
  padding-right: 56px;
}

.pw .toggle-pass{
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid rgba(7,26,43,.14);
  background: rgba(7,26,43,.03);
  cursor: pointer;
}
/* ===== Fila "¿No tienes cuenta?  Crear cuenta" (pro) ===== */
.auth-alt-row{
  display: flex;
  align-items: center;
  justify-content: center;   /* centra todo debajo del botón */
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.auth-alt{
  margin: 0;
  font-size: .95rem;
  font-weight: 700;
  color: rgba(7,26,43,.65);
}

/* Botón pill elegante */
.auth-linkbtn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .40rem .78rem;
  border-radius: 999px;
  background: var(--gold);
  border: 1px solid rgba(199,162,74,.55);
  color: #141414;
  font-weight: 900;
  font-size: .92rem;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(199,162,74,.18);
  transition: transform .15s ease, filter .15s ease, opacity .15s ease;
}

.auth-linkbtn:hover{
  filter: brightness(1.03);
  transform: translateY(-1px);
}

.auth-linkbtn:active{
  transform: translateY(0);
  opacity: .92;
}

/* En móvil: que no se desacomode */
@media (max-width: 420px){
  .auth-alt-row{ gap: 8px; }
  .auth-linkbtn{ padding: .42rem .72rem; }
}
