/* Login gate — mismo tybcn_token que el resto de ticketing.nicoriva.cloud (SSO) */
#loginGate{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-page);
}
.login-card{
  background:var(--bg-card);border:0.5px solid var(--bd-2);
  border-radius:14px;padding:28px;width:340px;
  box-shadow:0 12px 40px rgba(0,0,0,0.45);
}
.login-brand{font-size:18px;font-weight:600;color:var(--tx-1);letter-spacing:-0.01em;margin-bottom:2px}
.login-sub{font-size:12px;color:var(--tx-2);margin-bottom:20px;letter-spacing:0.02em}
.login-card label{display:block;font-size:10px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx-3);margin:12px 0 6px}
.login-card input{
  width:100%;padding:10px 12px;background:var(--bg-page);
  border:0.5px solid var(--bd-2);border-radius:8px;color:var(--tx-1);
  font-family:inherit;font-size:13px;outline:none;transition:border-color .12s;
}
.login-card input:focus{border-color:var(--info)}
/* A11 — foco visible (el outline:none de arriba dejaba el input sin indicador claro) */
.login-card input:focus-visible{outline:2px solid var(--info);outline-offset:-1px}
.login-btn{
  /* A5 — #1E6FC0 (antes var(--info) #378ADD): contraste AA del texto blanco */
  width:100%;margin-top:16px;padding:10px;background:#1E6FC0;color:#fff;
  border:0;border-radius:8px;font-family:inherit;font-size:13px;font-weight:600;
  cursor:pointer;transition:opacity .12s,transform .08s;letter-spacing:0.02em;
}
.login-btn:hover{opacity:.88}
.login-btn:active{transform:scale(0.98)}
#loginError{font-size:11px;color:var(--danger-tx);margin-top:10px;font-weight:500;min-height:14px}

#app{display:none}
#app.ready{display:block}
#app.ready ~ #loginGate{display:none}
