/* Shared auth page styling — login, signup, account, reset-password */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:        #060b12;
  --surface:   #0b1422;
  --surface2:  #0e1a2e;
  --border:    #1f2a44;
  --border-h:  #2a3a5e;
  --text-1:    #e2e8f0;
  --text-2:    #94a3b8;
  --text-3:    #64748b;
  --amber:     #f59e0b;
  --amber-2:   #d97706;
  --win:       #10b981;
  --loss:      #ef4444;
}
body {
  min-height: 100vh; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: linear-gradient(160deg, #060b12 0%, #0e1a2e 100%); color: var(--text-1);
  display: flex; flex-direction: column; align-items: center; padding: 32px 16px;
}
header { width: 100%; max-width: 440px; margin-bottom: 24px;
  display: flex; justify-content: space-between; align-items: center; }
.logo { font-size: 1.05rem; font-weight: 800; color: var(--amber); text-decoration: none; }
.logo span { color: var(--text-1); margin-left: 6px; font-weight: 700; }
.back { font-size: .85rem; color: var(--text-2); text-decoration: none; }
.back:hover { color: var(--text-1); }
.card {
  width: 100%; max-width: 440px; background: var(--surface);
  border: 1px solid var(--border); border-radius: 18px;
  padding: 32px; box-shadow: 0 12px 40px rgba(0,0,0,.4);
}
.card h1 { font-size: 1.5rem; font-weight: 800; margin-bottom: 6px; }
.card .lede { color: var(--text-2); font-size: .92rem; margin-bottom: 24px; line-height: 1.5; }
.field { margin-bottom: 16px; }
.field label {
  display: block; color: var(--text-2);
  font-size: .76rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .5px; margin-bottom: 6px;
}
.field input {
  width: 100%; padding: 12px 14px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--surface2);
  color: var(--text-1); font-size: 1rem; outline: none;
  transition: border-color .15s;
}
.field input:focus { border-color: var(--amber); }
.field .hint { font-size: .75rem; color: var(--text-3); margin-top: 6px; }
.btn {
  width: 100%; padding: 14px; border: none; border-radius: 12px;
  background: linear-gradient(135deg, var(--amber), var(--amber-2));
  color: #1a1a2e; font-weight: 800; font-size: 1rem;
  cursor: pointer; transition: transform .12s;
}
.btn:hover  { transform: translateY(-1px); }
.btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.btn-secondary {
  background: var(--surface2); color: var(--text-1);
  border: 1px solid var(--border);
}
.alert {
  padding: 10px 14px; border-radius: 10px;
  font-size: .85rem; margin-bottom: 14px; display: none;
}
.alert.err { background: rgba(239,68,68,.1);  border: 1px solid rgba(239,68,68,.4);  color: #fca5a5; }
.alert.ok  { background: rgba(16,185,129,.1); border: 1px solid rgba(16,185,129,.4); color: #6ee7b7; }
.alert.show { display: block; }
.foot {
  margin-top: 18px; font-size: .85rem; color: var(--text-2); text-align: center;
}
.foot a { color: var(--amber); text-decoration: none; font-weight: 600; }
.foot a:hover { text-decoration: underline; }
.muted-link { color: var(--text-3); font-size: .8rem; text-decoration: none; }
.muted-link:hover { color: var(--text-1); }

/* Account page extras */
.kv-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.kv-row:last-child { border-bottom: none; }
.kv-label { color: var(--text-2); font-size: .85rem; }
.kv-value { color: var(--text-1); font-weight: 700; font-size: .92rem; }
.tier-pill {
  padding: 4px 12px; border-radius: 999px; font-size: .72rem; font-weight: 800; letter-spacing: .5px;
}
.tier-pill.free { background: rgba(148,163,184,.15); color: var(--text-2); border: 1px solid rgba(148,163,184,.3); }
.tier-pill.paid { background: rgba(245,158,11,.15);  color: var(--amber);  border: 1px solid rgba(245,158,11,.4); }
