/* ============================================================
   auth.css — Standalone auth page styles
   Used by: forgot-password.html, reset-password.html,
            claim.html, speaker-register.html
   Requires: base.css
   ============================================================ */

.auth-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
}
.auth-card {
  background: #fff;
  border: 1px solid var(--br);
  border-radius: var(--ra);
  padding: 36px;
  max-width: 440px;
  width: 100%;
}
.auth-icon {
  width: 52px;
  height: 52px;
  background: var(--nl);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 22px;
  color: var(--nm);
}
.auth-h1 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 28px;
  text-align: center;
  color: var(--nvy);
  letter-spacing: .5px;
  margin-bottom: 8px;
}
.auth-sub {
  font-size: 13px;
  color: var(--tm);
  text-align: center;
  line-height: 1.6;
  margin-bottom: 24px;
}

/* Password strength meter */
.pw-wrap { position: relative; }
.pw-wrap input { padding-right: 40px; }
.pw-eye {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--tf);
  font-size: 14px;
}
.pw-strength { display: flex; gap: 3px; margin-top: 6px; align-items: center; }
.pw-bar {
  height: 3px;
  flex: 1;
  border-radius: 2px;
  background: var(--br);
  transition: background .2s;
}
.pw-bar.w { background: #EF9F27; }
.pw-bar.s { background: var(--tel); }

/* Step indicators (for multi-step flows) */
.auth-steps {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-bottom: 24px;
}
.auth-step {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  background: var(--g50);
  color: var(--tf);
  border: 1.5px solid var(--br);
}
.auth-step.active { background: var(--nm); color: #fff; border-color: var(--nm); }
.auth-step.done   { background: var(--tel); color: #fff; border-color: var(--tel); }
.auth-step-line   { width: 24px; height: 1.5px; background: var(--br); margin-top: 13px; }

/* Plan cards (speaker-register.html) */
.plan-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 16px; }
.plan-card {
  border: 2px solid var(--br);
  border-radius: var(--ra);
  padding: 14px 12px;
  cursor: pointer;
  transition: all .15s;
  text-align: center;
  position: relative;
}
.plan-card:hover { border-color: var(--nm); }
.plan-card.selected { border-color: var(--nm); background: var(--nl); }
.plan-card.recommended::before {
  content: 'Popular';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--red);
  color: #fff;
  font-size: 8px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 10px;
  white-space: nowrap;
}
.plan-name { font-weight: 800; font-size: 13px; color: var(--nvy); margin-bottom: 3px; }
.plan-price { font-family: 'Bebas Neue', sans-serif; font-size: 22px; color: var(--tx); line-height: 1; margin-bottom: 4px; }
.plan-desc  { font-size: 10px; color: var(--tf); line-height: 1.4; }

@media (max-width: 500px) {
  .plan-grid { grid-template-columns: 1fr; }
  .auth-card { padding: 24px 20px; }
}
