/*
 * gridwork-cloud — Auth-Page Stylesheet
 *
 * Trace: DEF-0050 (LOG-0256) — wiederhergestellt nach Verlust beim Phase-1+2-Bundle-Push.
 * Sprint: S-260428_3 AP-D1 (P1).
 * Routing: aspice-defect → aspice-swe → gridwork-qa.
 *
 * Scope: Auth-spezifische Layout-Regeln + Aurora-Tokens. Brand-Stylesheet
 * (Topbar, Floatnav, Footer) kommt zusätzlich von https://gw4.me/styles.css.
 *
 * Aurora-Palette (Memory reference_gridwork_brand_palette_aurora):
 *   --aurora-deep:  #0c1a1e   (Primärtext, Dark-Theme-Background)
 *   --aurora-mist:  #e0ece8   (Light-Background)
 *   --aurora-mint:  #00d4aa   (Accent, CTA)
 */

:root {
  --aurora-deep:  #0c1a1e;
  --aurora-mist:  #e0ece8;
  --aurora-mint:  #00d4aa;
  --aurora-mint-dim: #00b894;
  --aurora-error: #c2410c;
  --aurora-line:  rgba(12, 26, 30, 0.12);
  --aurora-fg:    #0c1a1e;
  --aurora-fg-soft: rgba(12, 26, 30, 0.7);
}

[data-theme="moonrise"] {
  --aurora-fg:      #e0ece8;
  --aurora-fg-soft: rgba(224, 236, 232, 0.7);
  --aurora-line:    rgba(224, 236, 232, 0.18);
}

/* ─── Auth-Frame Layout ──────────────────────────────────────────── */

body.d3 main#main {
  color: var(--aurora-fg);
}

/* ─── Login-Card-Pattern (CR-DESIGN-AUTH-CONSISTENCY-01 Standard) ──── */

body.d3 main#main.login-card {
  text-align: left;
  max-width: 480px;
  margin: 0 auto;
  padding: clamp(48px, 10vw, 120px) clamp(24px, 5vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 40px;
}

main#main.login-card .brand {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

main#main.login-card .brand .tag {
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--aurora-fg-soft);
  margin: 0;
}

main#main.login-card .brand .wordmark {
  font-size: clamp(1.5rem, 4vw, 2rem);
  letter-spacing: 0.04em;
  color: var(--aurora-fg);
  font-weight: 600;
}

main#main.login-card .brand .subtitle {
  font-size: 0.875rem;
  color: var(--aurora-fg-soft);
  font-weight: 300;
  margin: 0;
}

.auth__frame, main.login-card .form-card {
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid var(--aurora-line);
  border-radius: 12px;
  padding: clamp(20px, 4vw, 36px);
  box-shadow: 0 1px 2px rgba(12, 26, 30, 0.04),
              0 8px 24px rgba(12, 26, 30, 0.06);
  backdrop-filter: blur(8px);
}

[data-theme="moonrise"] .auth__frame, main.login-card .form-card {
  background: rgba(12, 26, 30, 0.55);
}

.auth__frame h1, main.login-card h1 {
  font-size: clamp(22px, 3.4vw, 28px);
  margin: 0 0 12px;
  letter-spacing: -0.01em;
}

.auth__frame .copy, main.login-card .copy {
  color: var(--aurora-fg-soft);
  margin: 0 0 24px;
  line-height: 1.5;
}

/* ─── Form-Felder ─────────────────────────────────────────────────── */

.auth__frame label, main.login-card label {
  display: block;
  margin: 14px 0;
  font-weight: 600;
  font-size: 14px;
  color: var(--aurora-fg);
}

.auth__frame label.checkbox, main.login-card label.checkbox {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-weight: 400;
  font-size: 14px;
  margin-top: 18px;
}

.auth__frame label.checkbox input[type="checkbox"], main.login-card label.checkbox input[type="checkbox"] {
  margin-top: 3px;
  flex-shrink: 0;
  accent-color: var(--aurora-mint);
}

.auth__frame input[type="text"],
.auth__frame input[type="email"],
.auth__frame input[type="password"],
main.login-card input[type="text"],
main.login-card input[type="email"],
main.login-card input[type="password"] {
  display: block;
  width: 100%;
  margin-top: 6px;
  padding: 14px 0;
  font-size: 16px;
  font-family: inherit;
  color: var(--aurora-fg);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--aurora-line);
  border-radius: 0;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}

[data-theme="moonrise"] .auth__frame input[type="text"],
[data-theme="moonrise"] .auth__frame input[type="email"],
[data-theme="moonrise"] .auth__frame input[type="password"] {
  background: rgba(224, 236, 232, 0.08);
}

.auth__frame input:focus,
main.login-card input:focus {
  outline: none;
  border-color: var(--aurora-mint);
  border-bottom-color: var(--aurora-mint);
  box-shadow: 0 1px 0 var(--aurora-mint);
}

.auth__frame .hint, main.login-card .hint {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  font-weight: 400;
  color: var(--aurora-fg-soft);
}

/* ─── Honeypot (versteckt für Bots) ──────────────────────────────── */

.hp-field,
.auth__frame .hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

/* ─── CTA-Button ─────────────────────────────────────────────────── */

.auth__frame .btn,
.auth__frame button[type="submit"] {
  display: inline-block;
  padding: 12px 24px;
  margin-top: 20px;
  font-size: 16px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  border: none;
  border-radius: 6px;
  background: var(--aurora-mint);
  color: var(--aurora-deep);
  transition: background 0.15s, transform 0.05s;
}

.auth__frame .btn--primary {
  background: var(--aurora-mint);
}

.auth__frame .btn:hover,
.auth__frame button[type="submit"]:hover {
  background: var(--aurora-mint-dim);
}

.auth__frame .btn:active,
.auth__frame button[type="submit"]:active {
  transform: translateY(1px);
}

.auth__frame .btn:focus-visible,
.auth__frame button[type="submit"]:focus-visible {
  outline: 3px solid rgba(0, 212, 170, 0.35);
  outline-offset: 2px;
}

/* ─── Zusatz-Links + Privacy ──────────────────────────────────────── */

.auth__alt {
  margin: 20px 0 0;
  text-align: center;
  font-size: 14px;
  color: var(--aurora-fg-soft);
}

.auth__alt a {
  color: var(--aurora-mint-dim);
  text-decoration: none;
  font-weight: 600;
}

.auth__alt a:hover,
.auth__alt a:focus-visible {
  text-decoration: underline;
}

.auth__privacy {
  margin: 18px 0 0;
  font-size: 12px;
  color: var(--aurora-fg-soft);
  line-height: 1.45;
}

.auth__privacy a {
  color: var(--aurora-mint-dim);
  text-decoration: none;
}

.auth__privacy a:hover {
  text-decoration: underline;
}

/* ─── Fehler-Banner ───────────────────────────────────────────────── */

.auth__error {
  margin: 0 0 18px;
  padding: 10px 14px;
  background: rgba(194, 65, 12, 0.08);
  border-left: 3px solid var(--aurora-error);
  color: var(--aurora-error);
  border-radius: 4px;
  font-size: 14px;
  line-height: 1.45;
}

/* ─── Skip-Link (A11y) ────────────────────────────────────────────── */

.skip {
  position: absolute;
  left: -9999px;
  top: 4px;
  z-index: 999;
  padding: 8px 14px;
  background: var(--aurora-deep);
  color: var(--aurora-mist);
  text-decoration: none;
  border-radius: 4px;
}

.skip:focus {
  left: 4px;
  outline: 3px solid var(--aurora-mint);
}


/* ─── Field-Label Login-Pattern (CR-DESIGN-AUTH-CONSISTENCY-01 §6) ─── */

main.login-card label:not(.checkbox) {
  display: block;
  margin: 18px 0 4px;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--aurora-fg-soft);
}

main.login-card .auth__alt,
main.login-card .auth__privacy {
  text-align: left;
}
