/* Auth pages (login, set-password). Scoped to .auth-infomo wrapper —
   the rest of the admin UI keeps using main.css / theme.*.css. */

.auth-infomo {
  --ai-bg: #0a0a0a;
  --ai-bg-card: #111111;
  --ai-bg-input: #0a0a0a;
  --ai-border: rgba(255, 255, 255, 0.08);
  --ai-border-strong: rgba(255, 255, 255, 0.16);
  --ai-text: #f5f5f5;
  --ai-muted: #8a8a8a;
  --ai-accent: #ff3b1f;
  --ai-accent-hover: #ff5a3d;

  min-height: 100vh;
  width: 100%;
  background-color: var(--ai-bg);
  background-image:
    radial-gradient(ellipse 60% 80% at 80% 15%, rgba(255, 59, 31, 0.20), transparent 60%),
    radial-gradient(ellipse 40% 60% at 15% 85%, rgba(255, 59, 31, 0.08), transparent 60%),
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: auto, auto, 48px 48px, 48px 48px;
  color: var(--ai-text);
  font-family: 'Inter', 'Montserrat', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 16px;
}

.auth-infomo__brand {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 40px;
  color: var(--ai-text);
  text-decoration: none;
  user-select: none;
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
}
.auth-infomo__brand:hover { color: var(--ai-text); }
.auth-infomo__brand-dot { color: var(--ai-accent); }
.auth-infomo__brand-product {
  color: var(--ai-accent);
  font-weight: 700;
  letter-spacing: -0.01em;
  text-shadow:
    0 0 8px rgba(255, 59, 31, 0.55),
    0 0 22px rgba(255, 59, 31, 0.40),
    0 0 44px rgba(255, 59, 31, 0.25);
}

.auth-infomo__card {
  width: 100%;
  max-width: 420px;
  background: var(--ai-bg-card);
  border: 1px solid var(--ai-border);
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.55);
}

.auth-infomo__title {
  font-size: 26px;
  font-weight: 600;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
  color: var(--ai-text);
}
.auth-infomo__subtitle {
  font-size: 14px;
  color: var(--ai-muted);
  margin: 0 0 28px;
}

.auth-infomo__alert {
  background: rgba(255, 59, 31, 0.10);
  border: 1px solid rgba(255, 59, 31, 0.35);
  color: #ffb3a6;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 14px;
  margin-bottom: 20px;
  line-height: 1.4;
}

.auth-infomo__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.auth-infomo__label {
  font-size: 11px;
  font-weight: 500;
  color: var(--ai-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.auth-infomo__input {
  background: var(--ai-bg-input);
  border: 1px solid var(--ai-border-strong);
  border-radius: 10px;
  padding: 12px 14px;
  color: var(--ai-text);
  font-size: 15px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.auth-infomo__input::placeholder { color: #555; }
.auth-infomo__input:focus {
  border-color: var(--ai-accent);
  box-shadow: 0 0 0 3px rgba(255, 59, 31, 0.18);
}

.auth-infomo__button {
  width: 100%;
  background: var(--ai-accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 13px 18px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 0.15s ease, transform 0.05s ease, box-shadow 0.15s ease;
  box-shadow: 0 8px 24px rgba(255, 59, 31, 0.25);
}
.auth-infomo__button:hover { background: var(--ai-accent-hover); }
.auth-infomo__button:active { transform: translateY(1px); }

.auth-infomo__footer {
  margin-top: 28px;
  font-size: 13px;
  color: var(--ai-muted);
  text-align: center;
}
.auth-infomo__footer a {
  color: var(--ai-muted);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.15s ease;
}
.auth-infomo__footer a:hover { color: var(--ai-text); }
.auth-infomo__footer-dot { color: var(--ai-accent); }

.auth-infomo__card--wide { max-width: 520px; }

.auth-infomo__text {
  font-size: 14px;
  color: #c9c9c9;
  line-height: 1.55;
  margin: 0 0 20px;
}

.auth-infomo__alert--warning {
  background: rgba(255, 176, 32, 0.08);
  border: 1px solid rgba(255, 176, 32, 0.35);
  color: #f6c97a;
}

.auth-infomo__checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 4px 0 18px;
  font-size: 14px;
  color: #c9c9c9;
  cursor: pointer;
  user-select: none;
}
.auth-infomo__checkbox input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1px solid var(--ai-border-strong);
  border-radius: 5px;
  background: var(--ai-bg-input);
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 1px;
  position: relative;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.auth-infomo__checkbox input[type="checkbox"]:checked {
  background: var(--ai-accent);
  border-color: var(--ai-accent);
}
.auth-infomo__checkbox input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.auth-infomo__link-button {
  background: transparent;
  color: var(--ai-muted);
  border: 1px solid var(--ai-border);
  border-radius: 10px;
  padding: 11px 18px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  width: 100%;
  margin-top: 10px;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
  font-family: inherit;
}
.auth-infomo__link-button:hover {
  color: var(--ai-text);
  border-color: var(--ai-border-strong);
  background: rgba(255, 255, 255, 0.02);
}

.auth-infomo__divider {
  height: 1px;
  background: var(--ai-border);
  margin: 16px 0;
}

.auth-infomo__spinner {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 8px 0 4px;
}
.auth-infomo__spinner span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--ai-accent);
  animation: ai-bounce 1.2s infinite ease-in-out both;
}
.auth-infomo__spinner span:nth-child(1) { animation-delay: -0.32s; }
.auth-infomo__spinner span:nth-child(2) { animation-delay: -0.16s; }
@keyframes ai-bounce {
  0%, 80%, 100% { transform: scale(0.4); opacity: 0.5; }
  40%           { transform: scale(1.0); opacity: 1; }
}

/* ─── 2FA helpers ─────────────────────────────────────────────────────── */

.auth-infomo__step {
  font-size: 12px;
  font-weight: 600;
  color: var(--ai-accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 20px 0 6px;
}
.auth-infomo__step:first-of-type { margin-top: 0; }

.auth-infomo__qr-frame {
  display: flex;
  justify-content: center;
  margin: 12px 0 20px;
}
.auth-infomo__qr-frame img {
  background: #fff;
  padding: 14px;
  border-radius: 12px;
  max-width: 220px;
}

.auth-infomo__secret {
  background: var(--ai-bg-input);
  border: 1px solid var(--ai-border);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, monospace;
  font-size: 13px;
  color: var(--ai-text);
  text-align: center;
  word-break: break-all;
  margin-bottom: 24px;
}

.auth-infomo__code-input {
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, monospace;
  font-size: 22px;
  letter-spacing: 0.5em;
  text-align: center;
  padding: 14px 16px;
}

.auth-infomo__codes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin: 16px 0 8px;
}
.auth-infomo__code {
  background: var(--ai-bg-input);
  border: 1px solid var(--ai-border);
  border-radius: 8px;
  padding: 12px 10px;
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, monospace;
  font-size: 13px;
  text-align: center;
  color: var(--ai-text);
  letter-spacing: 0.05em;
}

.auth-infomo__btn-row {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}
.auth-infomo__btn-row > * { flex: 1; }

@media (max-width: 480px) {
  .auth-infomo { padding: 32px 14px; }
  .auth-infomo__card { padding: 28px 22px; }
  .auth-infomo__brand { font-size: 24px; margin-bottom: 28px; }
  .auth-infomo__title { font-size: 22px; }
  .auth-infomo__codes-grid { grid-template-columns: 1fr; }
  .auth-infomo__btn-row { flex-direction: column; }
}

@media print {
  body * { visibility: hidden; }
  .auth-infomo__card, .auth-infomo__card * { visibility: visible; }
  .auth-infomo__card { position: absolute; left: 0; top: 0; border: none; box-shadow: none; }
  .auth-infomo__btn-row, .auth-infomo__footer, .auth-infomo__brand { display: none !important; }
}
