/* ══════════════════════════════════════════
   FORGE Beta Registration
   legacygamers.net/beta-register
   ══════════════════════════════════════════ */

/* ─── Reset ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── Variables ─── */
:root {
  --ember: #E87A20;
  --ember-light: #F0A050;
  --ember-dark: #C46518;
  --ember-glow: rgba(232, 122, 32, .25);
  --ember-dim: rgba(232, 122, 32, .08);
  --void: #080510;
  --void-surface: #121020;
  --void-panel: #1a1730;
  --void-border: rgba(184, 176, 160, .08);
  --text: #e0d8cc;
  --text-dim: #827c72;
  --text-muted: #5a5650;
  --success: #4ade80;
  --error: #ef4444;
}

/* ─── Body ─── */
body {
  font-family: 'Barlow', sans-serif;
  background: var(--void);
  color: var(--text);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ─── Background ─── */
canvas { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }

.glow { position: fixed; border-radius: 50%; filter: blur(100px); pointer-events: none; z-index: 0; }
.glow-1 { width: 600px; height: 600px; top: -200px; right: -100px; background: radial-gradient(circle, rgba(232, 122, 32, .06) 0%, transparent 70%); animation: drift1 20s ease-in-out infinite; }
.glow-2 { width: 500px; height: 500px; bottom: -150px; left: -100px; background: radial-gradient(circle, rgba(184, 176, 160, .04) 0%, transparent 70%); animation: drift2 25s ease-in-out infinite; }
.vig { position: fixed; inset: 0; background: radial-gradient(ellipse 70% 60% at 50% 50%, transparent, var(--void)); pointer-events: none; z-index: 1; }

@keyframes drift1 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(-40px, 30px); } }
@keyframes drift2 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(30px, -20px); } }

/* ─── Layout ─── */
.page { position: relative; z-index: 2; width: 100%; max-width: 520px; padding: 1.5rem; }

/* ─── Brand ─── */
.brand { text-align: center; margin-bottom: 2rem; animation: fadeUp .6s cubic-bezier(.16, 1, .3, 1) both; }
.brand-icon { position: relative; width: 56px; height: 56px; margin: 0 auto 1rem; filter: drop-shadow(0 0 16px rgba(232, 122, 32, .35)); overflow: visible; }
.brand-icon img { width: 100%; height: 100%; object-fit: contain; }

.brand-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: .08em;
  background: linear-gradient(100deg, #c8c0b0, #e8a040, #f0c060, #e8a040, #c8c0b0);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: sweep 6s ease-in-out infinite;
  filter: drop-shadow(0 0 20px rgba(232, 122, 32, .15));
}

.brand-sub {
  font-family: 'Orbitron', sans-serif;
  font-size: .6rem;
  font-weight: 500;
  letter-spacing: .25em;
  color: var(--text-muted);
  margin-top: .25rem;
}

@keyframes sweep { 0%, 100% { background-position: 200% 50%; } 50% { background-position: 0% 50%; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); filter: blur(4px); } to { opacity: 1; transform: none; filter: none; } }

/* ─── Anvil Sparks ─── */
.forge-sparks { position: absolute; inset: 0; pointer-events: none; overflow: visible; }
.spark { position: absolute; width: 3px; height: 3px; border-radius: 50%; background: #e8a040; box-shadow: 0 0 4px #e8a040, 0 0 8px rgba(232, 160, 64, .5); opacity: 0; animation: sparkFloat 2.4s ease-out infinite; }
.spark:nth-child(1) { right: 8px; top: 6px; animation-delay: 0s; --drift: 0.3; }
.spark:nth-child(2) { right: 5px; top: 10px; animation-delay: 0.5s; width: 2px; height: 2px; --drift: 0.7; }
.spark:nth-child(3) { right: 12px; top: 3px; animation-delay: 1.0s; width: 2.5px; height: 2.5px; --drift: 0.1; }
.spark:nth-child(4) { right: 7px; top: 14px; animation-delay: 1.5s; width: 2px; height: 2px; --drift: 0.9; }
.spark:nth-child(5) { right: 14px; top: 9px; animation-delay: 2.0s; width: 1.5px; height: 1.5px; --drift: 0.5; }
@keyframes sparkFloat { 0% { opacity: 0; transform: translate(0, 0) scale(1); } 10% { opacity: 1; } 100% { opacity: 0; transform: translate(calc(-6px + 12px * var(--drift, .5)), -22px) scale(0.3); } }

/* ─── Steps Indicator ─── */
.steps { display: flex; align-items: center; justify-content: center; gap: .75rem; margin-bottom: 1.75rem; animation: fadeUp .6s .1s cubic-bezier(.16, 1, .3, 1) both; }
.step-dot {
  width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'JetBrains Mono', monospace; font-size: .65rem; font-weight: 600;
  border: 1.5px solid var(--void-border); color: var(--text-muted); background: transparent;
  transition: all .4s cubic-bezier(.16, 1, .3, 1);
}
.step-dot.active { border-color: var(--ember); color: var(--ember); background: var(--ember-dim); box-shadow: 0 0 12px var(--ember-glow); }
.step-dot.done { border-color: var(--success); color: var(--void); background: var(--success); }
.step-dot.done::after { content: '\2713'; }
.step-line { width: 40px; height: 1px; background: var(--void-border); transition: background .4s; }
.step-line.active { background: linear-gradient(90deg, var(--ember), var(--ember-glow)); }

/* ─── Card ─── */
.card {
  position: relative; padding: 2.5rem; animation: fadeUp .6s .15s cubic-bezier(.16, 1, .3, 1) both;
  background: linear-gradient(145deg, rgba(12, 10, 23, .65), rgba(18, 16, 30, .45));
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--void-border); box-shadow: 0 20px 60px rgba(0, 0, 0, .4), inset 0 1px 0 rgba(255, 255, 255, .03);
}

/* ─── HUD Corners ─── */
.hud { position: absolute; width: 16px; height: 16px; pointer-events: none; }
.hud::before, .hud::after { content: ''; position: absolute; background: rgba(122, 116, 106, .5); }
.hud::before { width: 16px; height: 1px; }
.hud::after { width: 1px; height: 16px; }
.hud-tl { top: -1px; left: -1px; }  .hud-tl::before { top: 0; left: 0; }  .hud-tl::after { top: 0; left: 0; }
.hud-tr { top: -1px; right: -1px; } .hud-tr::before { top: 0; right: 0; } .hud-tr::after { top: 0; right: 0; }
.hud-bl { bottom: -1px; left: -1px; }  .hud-bl::before { bottom: 0; left: 0; }  .hud-bl::after { bottom: 0; left: 0; }
.hud-br { bottom: -1px; right: -1px; } .hud-br::before { bottom: 0; right: 0; } .hud-br::after { bottom: 0; right: 0; }

/* ─── Step Panels ─── */
.step-panel { display: none; }
.step-panel.active { display: block; animation: stepIn .4s cubic-bezier(.16, 1, .3, 1) both; }
@keyframes stepIn { from { opacity: 0; transform: translateY(12px) scale(.98); } to { opacity: 1; transform: none; } }

.step-title { font-family: 'Orbitron', sans-serif; font-size: 1.1rem; font-weight: 700; letter-spacing: .04em; color: var(--text); margin-bottom: .5rem; text-align: center; }
.step-desc { font-size: .85rem; color: var(--text-dim); text-align: center; margin-bottom: 1.75rem; line-height: 1.5; }

/* ─── Form Fields ─── */
.field { margin-bottom: 1.25rem; }
.field-label { display: block; font-family: 'Orbitron', sans-serif; font-size: .55rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--text-muted); margin-bottom: .5rem; }
.field-input {
  width: 100%; background: rgba(8, 5, 16, .6); border: 1px solid rgba(184, 176, 160, .1); padding: .75rem 1rem;
  font-family: 'Barlow', sans-serif; font-size: .9rem; color: var(--text); outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.field-input:focus { border-color: rgba(232, 122, 32, .4); box-shadow: 0 0 0 3px var(--ember-dim), 0 0 20px rgba(232, 122, 32, .06); }
.field-input::placeholder { color: rgba(130, 124, 114, .4); }
.field-input.code-input {
  font-family: 'JetBrains Mono', monospace; font-size: 1.2rem; font-weight: 600; letter-spacing: .12em;
  text-align: center; text-transform: uppercase; padding: 1rem;
}
.field-hint { font-size: .7rem; color: var(--text-muted); margin-top: .35rem; }
.field-error { font-size: .75rem; color: var(--error); margin-top: .35rem; display: none; }

/* ─── Password Strength ─── */
.pw-bar { height: 3px; background: rgba(184, 176, 160, .08); margin-top: .5rem; overflow: hidden; }
.pw-fill { height: 100%; width: 0; transition: width .3s, background .3s; }
.pw-label { font-family: 'JetBrains Mono', monospace; font-size: .6rem; margin-top: .25rem; color: var(--text-muted); }

/* ─── Buttons ─── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem; width: 100%;
  font-family: 'Orbitron', sans-serif; font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: .85rem 2rem; border: none; cursor: pointer; transition: all .25s; text-decoration: none;
}
.btn-primary { color: var(--void); background: linear-gradient(135deg, var(--ember), var(--ember-dark)); border: 1px solid var(--ember-dark); }
.btn-primary:hover:not(:disabled) { background: linear-gradient(135deg, var(--ember-light), var(--ember)); box-shadow: 0 0 24px var(--ember-glow); transform: translateY(-1px); }
.btn-primary:disabled { opacity: .35; cursor: not-allowed; }
.btn-ghost { color: var(--text-dim); background: transparent; border: 1px solid rgba(184, 176, 160, .12); }
.btn-ghost:hover { color: var(--text); border-color: rgba(184, 176, 160, .3); }

.btn-loader { display: none; width: 14px; height: 14px; border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%; animation: spin .6s linear infinite; }
.btn.loading .btn-text { display: none; }
.btn.loading .btn-loader { display: block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ─── Alerts ─── */
.alert { padding: .75rem 1rem; font-size: .8rem; margin-bottom: 1.25rem; display: none; border-left: 3px solid; }
.alert-error { color: var(--error); border-color: var(--error); background: rgba(239, 68, 68, .06); }
.alert-success { color: var(--success); border-color: var(--success); background: rgba(74, 222, 128, .06); }

/* ─── Code Validation Badge ─── */
.code-badge { display: none; align-items: center; justify-content: center; gap: .5rem; padding: .5rem 1rem; font-family: 'Orbitron', sans-serif; font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1.25rem; }
.code-badge.valid { display: flex; color: var(--success); border: 1px solid rgba(74, 222, 128, .2); background: rgba(74, 222, 128, .05); }
.code-badge .badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--success); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .3; } }

/* ─── Success Panel ─── */
.success-icon {
  width: 64px; height: 64px; margin: 0 auto 1.5rem; border-radius: 50%;
  background: rgba(74, 222, 128, .1); border: 2px solid rgba(74, 222, 128, .3);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; color: var(--success); animation: scaleIn .5s cubic-bezier(.16, 1, .3, 1) both;
}
@keyframes scaleIn { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.result-table { width: 100%; margin: 1.5rem 0; }
.result-row { display: flex; justify-content: space-between; padding: .6rem 0; border-bottom: 1px solid rgba(184, 176, 160, .06); }
.result-label { font-family: 'Orbitron', sans-serif; font-size: .55rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--text-muted); }
.result-value { font-family: 'JetBrains Mono', monospace; font-size: .8rem; color: var(--text); }
.result-value.ember { color: var(--ember); }
.btn-group { display: flex; flex-direction: column; gap: .75rem; margin-top: 1.5rem; }

/* ─── Turnstile ─── */
.turnstile-wrap { margin-bottom: 1.25rem; display: flex; justify-content: center; }

/* ─── Divider ─── */
.divider { display: flex; align-items: center; gap: .5rem; margin: 1.5rem 0; }
.divider-line { flex: 1; height: 1px; background: linear-gradient(90deg, transparent, rgba(232, 122, 32, .15)); }
.divider-line:last-child { background: linear-gradient(90deg, rgba(232, 122, 32, .15), transparent); }
.divider-diamond { width: 4px; height: 4px; background: rgba(232, 122, 32, .3); transform: rotate(45deg); flex-shrink: 0; }

/* ─── Logged-in Badge ─── */
.logged-in-badge {
  display: flex; align-items: center; gap: .5rem; padding: .5rem 1rem; margin-bottom: 1.25rem;
  font-family: 'Orbitron', sans-serif; font-size: .55rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ember-light); border: 1px solid rgba(232, 122, 32, .15); background: var(--ember-dim);
}

/* ─── Maintenance Badge ─── */
.maint-badge {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: 'Orbitron', sans-serif; font-size: .6rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ember); padding: .35rem .75rem; border: 1px solid rgba(232, 122, 32, .2); background: var(--ember-dim);
  margin-bottom: 1.25rem;
}

/* ─── Footer ─── */
.footer { position: fixed; bottom: 1rem; left: 0; right: 0; text-align: center; z-index: 2; font-size: .65rem; color: #4a4540; }
.heart { color: #f472b6; display: inline-block; animation: heartbeat 2s ease-in-out infinite; }
@keyframes heartbeat { 0%, 100% { transform: scale(1); } 14% { transform: scale(1.15); } 28% { transform: scale(1); } 42% { transform: scale(1.15); } 56% { transform: scale(1); } }

/* ─── Selection ─── */
::selection { background: var(--ember); color: white; }

/* ─── Responsive ─── */
@media (max-width: 540px) {
  .card { padding: 1.75rem 1.25rem; }
  .brand-title { font-size: 1.6rem; }
  .field-input.code-input { font-size: 1rem; letter-spacing: .08em; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  canvas { display: none; }
}
