/* ═══════════════════════════════════════════════════════════════════════
   AUTH — cyberpunk login / signup / forgot / reset / invite
   Consumes tokens from /shared/cyber.css. Hebrew-aware (RTL), neon-green.
═══════════════════════════════════════════════════════════════════════ */
* { margin: 0; padding: 0; box-sizing: border-box; }

html, body { height: 100%; }
body {
  font-family: var(--font-body);
  color: var(--cyber-fg);
  background: var(--cyber-bg);
  background-image:
    radial-gradient(70% 90% at 100% 0%, rgba(255,0,255,.10), transparent 60%),
    radial-gradient(80% 90% at 0% 100%, rgba(0,212,255,.10), transparent 55%),
    radial-gradient(60% 70% at 50% 120%, rgba(0,255,136,.10), transparent 60%),
    linear-gradient(rgba(0,255,136,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,136,.035) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 100% 100%, 48px 48px, 48px 48px;
  min-height: 100%;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  -webkit-font-smoothing: antialiased;
}

/* ── Card ───────────────────────────────────────────────────────────────── */
.auth-card {
  position: relative;
  width: 100%; max-width: 400px;
  background: var(--cyber-card);
  border: 1px solid var(--cyber-border);
  padding: 30px 28px 24px;
  clip-path: polygon(
    0 14px, 14px 0, calc(100% - 14px) 0, 100% 14px,
    100% calc(100% - 14px), calc(100% - 14px) 100%, 14px 100%, 0 calc(100% - 14px)
  );
  box-shadow: var(--neon-sm), 0 24px 70px rgba(0,0,0,.6);
}
/* HUD corner ticks */
.auth-card::before, .auth-card::after {
  content: ''; position: absolute; width: 16px; height: 16px; pointer-events: none;
}
.auth-card::before { top: 6px; inset-inline-start: 6px;  border-top: 2px solid var(--cyber-accent); border-inline-start: 2px solid var(--cyber-accent); }
.auth-card::after  { bottom: 6px; inset-inline-end: 6px; border-bottom: 2px solid var(--cyber-accent); border-inline-end: 2px solid var(--cyber-accent); }

.auth-logo {
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--cyber-accent-3); margin-bottom: 16px;
}
.auth-logo::before { content: '> '; color: var(--cyber-accent); }

.auth-card h1 {
  font-family: var(--font-head);
  font-size: 26px; font-weight: 900; text-transform: uppercase; letter-spacing: .04em;
  color: var(--cyber-fg);
  text-shadow: 0 0 10px rgba(0,255,136,.35);
}
.auth-sub { font-family: var(--font-mono); font-size: 12.5px; letter-spacing: .04em; color: var(--cyber-muted-fg); margin: 6px 0 22px; }
.auth-sub::before { content: '// '; color: var(--cyber-accent); }

/* ── Form ───────────────────────────────────────────────────────────────── */
form { display: flex; flex-direction: column; gap: 14px; }
label {
  display: flex; flex-direction: column; gap: 7px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 400;
  letter-spacing: .18em; text-transform: uppercase; color: var(--cyber-muted-fg);
}
.auth-hint { letter-spacing: .08em; opacity: .8; text-transform: none; }

/* Input with terminal ">" prefix (RTL: sits at the logical start = right side) */
.auth-field { position: relative; display: block; }
.auth-field::before {
  content: '>'; position: absolute; inset-inline-start: 12px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono); color: var(--cyber-accent); pointer-events: none; font-size: 15px;
}
input {
  width: 100%;
  font-family: var(--font-mono); font-size: 15px; color: var(--cyber-accent);
  background: var(--cyber-bg);
  border: 1px solid var(--cyber-border);
  padding: 12px 14px; padding-inline-start: 30px;
  outline: none; transition: all .2s var(--cyber-ease);
  clip-path: polygon(0 6px, 6px 0, calc(100% - 6px) 0, 100% 6px, 100% calc(100% - 6px), calc(100% - 6px) 100%, 6px 100%, 0 calc(100% - 6px));
}
input::placeholder { color: var(--cyber-muted-fg); }
input:focus { border-color: var(--cyber-accent); box-shadow: var(--neon-sm); }

/* ── Button (glitch CTA: solid accent, dark text) ───────────────────────── */
.auth-btn {
  margin-top: 6px;
  font-family: var(--font-mono); font-size: 15px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--cyber-bg);
  background: var(--cyber-accent);
  border: none; padding: 13px; cursor: pointer;
  clip-path: polygon(0 6px, 6px 0, calc(100% - 6px) 0, 100% 6px, 100% calc(100% - 6px), calc(100% - 6px) 100%, 6px 100%, 0 calc(100% - 6px));
  transition: all .15s var(--cyber-ease);
}
.auth-btn:hover { filter: brightness(1.12); box-shadow: var(--neon); }
.auth-btn:active { transform: translateY(1px); }
.auth-btn:disabled { opacity: .5; cursor: default; filter: none; box-shadow: none; }
.auth-btn:focus-visible { outline: 2px solid var(--cyber-accent); outline-offset: 2px; }

/* ── Messages ───────────────────────────────────────────────────────────── */
.auth-err, .auth-ok {
  font-family: var(--font-mono); font-size: 12.5px; letter-spacing: .03em;
  padding: 10px 12px; border: 1px solid;
  clip-path: polygon(0 5px, 5px 0, calc(100% - 5px) 0, 100% 5px, 100% calc(100% - 5px), calc(100% - 5px) 100%, 5px 100%, 0 calc(100% - 5px));
}
.auth-err { color: #ffd0d5; background: rgba(255,51,102,.12); border-color: rgba(255,51,102,.45); }
.auth-err::before { content: '! ERR: '; color: var(--cyber-danger); }
.auth-ok  { color: #c8ffe6; background: rgba(0,255,136,.10); border-color: rgba(0,255,136,.40); }
.auth-ok::before  { content: '✓ OK: '; color: var(--cyber-accent); }

/* ── Links ──────────────────────────────────────────────────────────────── */
.auth-forgot { text-align: start; margin-top: -4px; }
.auth-forgot a, .auth-alt a {
  font-family: var(--font-mono); letter-spacing: .06em; color: var(--cyber-accent-3); text-decoration: none;
}
.auth-forgot a { font-size: 11px; color: var(--cyber-muted-fg); }
.auth-forgot a:hover, .auth-alt a:hover { color: var(--cyber-accent); text-shadow: var(--neon-sm); }
.auth-alt { font-family: var(--font-mono); text-align: center; font-size: 12.5px; color: var(--cyber-muted-fg); margin-top: 20px; }

.hidden { display: none !important; }
