/* ── Auth Pages (Login / Register / Verify) ──────────────── */

.auth-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - var(--nav-height));
  padding: var(--space-xl);
  /* Subtle dot-grid bg */
  background-image:
    radial-gradient(circle, rgba(205,65,43,0.05) 1px, transparent 1px);
  background-size: 24px 24px;
}

/* The card */
.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--bg-card);
  border: 1px solid rgba(150,50,35,0.25);
  border-left: 2px solid rgba(205,65,43,0.55);
  border-radius: var(--radius-sm);
  padding: var(--space-2xl);
  position: relative;
  box-shadow: 0 16px 48px rgba(0,0,0,0.55);
}

/* Corner brackets */
.auth-card::before,
.auth-card::after {
  content: '';
  position: absolute;
  width: 10px;
  height: 10px;
  pointer-events: none;
}

.auth-card::before {
  top: -1px;
  right: -1px;
  border-top: 2px solid rgba(205,65,43,0.5);
  border-right: 2px solid rgba(205,65,43,0.5);
}

.auth-card::after {
  bottom: -1px;
  left: -1px;
  border-bottom: 2px solid rgba(205,65,43,0.5);
  border-left: 2px solid rgba(205,65,43,0.5);
}

.auth-header {
  text-align: center;
  margin-bottom: var(--space-xl);
}

/* Eyebrow label above title */
.auth-header::before {
  content: '// ACCESS TERMINAL';
  display: block;
  font-size: 9.5px;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.2em;
  color: rgba(205,65,43,0.6);
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

.auth-header h1 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.auth-header p {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.auth-form .btn-primary {
  margin-top: var(--space-sm);
  padding: 0.75rem;
  width: 100%;
  font-size: var(--font-size-base);
}

.auth-footer {
  text-align: center;
  margin-top: var(--space-lg);
  font-size: var(--font-size-sm);
  color: var(--text-muted);
}

.auth-footer a {
  color: var(--accent);
  font-weight: var(--font-weight-semibold);
}

/* Alert boxes */
.auth-error {
  background: rgba(224,80,80,0.08);
  border: 1px solid rgba(224,80,80,0.25);
  border-left: 2px solid var(--error);
  color: #e07070;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  display: none;
}

.auth-error.visible {
  display: block;
}

.auth-success {
  background: rgba(110,200,104,0.08);
  border: 1px solid rgba(110,200,104,0.25);
  border-left: 2px solid var(--success);
  color: #6ec868;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  display: none;
}

.auth-success.visible {
  display: block;
}
