/* ============================================================
   E · Auth (login / register / forgot) shared
   依赖 _tokens.css · _e-fashion.css
   ============================================================ */

.e-auth-bg {
  min-height: 100vh;
  background:
    radial-gradient(ellipse 60% 40% at 80% 20%, rgba(255,210,63,.20), transparent 60%),
    radial-gradient(ellipse 50% 35% at 15% 75%, rgba(255,107,74,.15), transparent 60%),
    linear-gradient(180deg, #E0F7F1 0%, #B8E8DD 60%, #7DD3C0 100%);
  position: relative;
  overflow: hidden;
}
.e-auth-bg::before, .e-auth-bg::after { content: ""; position: absolute; background: rgba(255,255,255,.85); border-radius: 50%; filter: blur(2px); pointer-events: none; }
.e-auth-bg::before { width: 140px; height: 44px; top: 12%; left: 8%; }
.e-auth-bg::after { width: 80px; height: 28px; top: 18%; right: 12%; }

.e-auth-shell { max-width: 1180px; margin: 0 auto; padding: 32px 24px; min-height: 100vh; display: grid; grid-template-columns: 1fr 480px; gap: 56px; align-items: center; position: relative; z-index: 1; }
@media (max-width: 900px) { .e-auth-shell { grid-template-columns: 1fr; gap: 24px; padding: 24px 16px; } }

/* —— Left: marketing panel —— */
.e-auth-pitch { padding: 24px; }
.e-auth-pitch__brand { display: flex; align-items: center; gap: 10px; margin-bottom: 28px; font-family: var(--font-display); font-weight: 900; font-size: 22px; color: var(--color-primary-fill); letter-spacing: -0.02em; }
.e-auth-pitch__brand .e-brand__mark { width: 36px; height: 36px; border-radius: 12px; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-fill) 100%); color: #fff; display: grid; place-items: center; font-size: 18px; font-weight: 900; font-style: italic; font-family: "Times New Roman", serif; box-shadow: var(--shadow-teal); }

.e-auth-pitch__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; background: rgba(255,255,255,.7); backdrop-filter: blur(6px); border-radius: 999px; font-size: 13px; font-weight: 600; color: var(--color-primary-fill); border: 1px solid rgba(11,168,136,.2); }
.e-auth-pitch__eyebrow__dot { width: 6px; height: 6px; background: var(--color-cta); border-radius: 50%; animation: e-pulse 2s ease-in-out infinite; }

.e-auth-pitch h1 { font-family: var(--font-display); font-weight: 900; font-size: 52px; line-height: 1.02; letter-spacing: -0.035em; margin: 16px 0 16px; color: var(--color-text); }
.e-auth-pitch h1 .accent { color: var(--color-cta); }
.e-auth-pitch h1 .accent-teal { color: var(--color-primary-fill); }
@media (max-width: 900px) { .e-auth-pitch h1 { font-size: 36px; } }

.e-auth-pitch__sub { font-size: 17px; color: var(--color-text-muted); max-width: 440px; line-height: 1.55; margin: 0 0 28px; }

.e-auth-pitch__bullets { display: flex; flex-direction: column; gap: 10px; max-width: 420px; }
.e-auth-pitch__bullet { display: flex; gap: 12px; align-items: center; background: rgba(255,255,255,.7); backdrop-filter: blur(6px); border-radius: 14px; padding: 12px 16px; border: 1px solid rgba(255,255,255,.6); }
.e-auth-pitch__bullet__ic { width: 36px; height: 36px; border-radius: 10px; background: rgba(11,168,136,.15); color: var(--color-primary-fill); display: grid; place-items: center; font-size: 18px; flex-shrink: 0; }
.e-auth-pitch__bullet__t { font-size: 14px; font-weight: 800; color: var(--color-text); font-family: var(--font-display); letter-spacing: -0.005em; }
.e-auth-pitch__bullet__s { font-size: 12px; color: var(--color-text-muted); margin-top: 2px; line-height: 1.4; }

/* Bear mascot inline floating */
.e-auth-pitch__bear { position: absolute; right: 480px; top: 50%; transform: translate(-50%, -50%); width: 280px; opacity: 0.4; pointer-events: none; }
@media (max-width: 900px) { .e-auth-pitch__bear { display: none; } }

/* —— Right: auth card —— */
.e-auth-card { background: #fff; border-radius: 28px; padding: 36px 40px; box-shadow: 0 24px 48px rgba(15,31,26,.16), 0 8px 16px rgba(15,31,26,.08); position: relative; }
@media (max-width: 540px) { .e-auth-card { padding: 28px 24px; border-radius: 20px; } }

.e-auth-card__head { margin-bottom: 26px; }
.e-auth-card__tabs { display: flex; gap: 4px; padding: 4px; background: var(--color-surface); border-radius: 12px; margin-bottom: 22px; }
.e-auth-card__tabs button { flex: 1; background: transparent; border: 0; padding: 10px; border-radius: 8px; font-family: inherit; font-size: 13px; font-weight: 700; color: var(--color-text-muted); cursor: pointer; }
.e-auth-card__tabs button.is-active { background: #fff; color: var(--color-text); box-shadow: var(--shadow-soft); }
.e-auth-card__h { font-family: var(--font-display); font-size: 26px; font-weight: 900; letter-spacing: -0.015em; line-height: 1.1; margin: 0 0 6px; }
.e-auth-card__sub { font-size: 13px; color: var(--color-text-muted); margin: 0; line-height: 1.55; }
.e-auth-card__sub a { color: var(--color-primary-fill); font-weight: 700; }

/* Social login buttons */
.e-auth-social { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 18px; }
.e-auth-social__btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 14px; border: 1.5px solid var(--color-border); border-radius: 12px;
  background: #fff; font-family: inherit; font-size: 13px; font-weight: 700; color: var(--color-text);
  cursor: pointer; transition: border-color var(--duration-fast) var(--ease-out);
}
.e-auth-social__btn:hover { border-color: var(--color-text); }
.e-auth-social__btn__ic { width: 20px; height: 20px; flex-shrink: 0; display: grid; place-items: center; font-family: var(--font-display); font-weight: 900; }
.e-auth-social__btn--tg { background: #229ED9; color: #fff; border-color: #229ED9; }
.e-auth-social__btn--tg:hover { background: #1F8DC4; border-color: #1F8DC4; }

/* Divider OR */
.e-auth-or { display: flex; align-items: center; gap: 10px; margin: 18px 0; }
.e-auth-or::before, .e-auth-or::after { content: ""; flex: 1; height: 1px; background: var(--color-border); }
.e-auth-or span { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-muted); }

/* Footer link row */
.e-auth-foot { margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--color-border); text-align: center; font-size: 13px; color: var(--color-text-muted); }
.e-auth-foot a { color: var(--color-primary-fill); font-weight: 700; }
.e-auth-foot a:hover { text-decoration: underline; }

/* Strong/weak password meter */
.e-pw-meter { display: flex; gap: 4px; margin-top: 6px; }
.e-pw-meter__seg { flex: 1; height: 4px; border-radius: 2px; background: var(--color-border); transition: background var(--duration-fast) var(--ease-out); }
.e-pw-meter--weak .e-pw-meter__seg:nth-child(1) { background: var(--color-danger); }
.e-pw-meter--mid .e-pw-meter__seg:nth-child(-n+2) { background: var(--color-warning); }
.e-pw-meter--strong .e-pw-meter__seg { background: var(--color-primary-fill); }
.e-pw-hint { display: flex; justify-content: space-between; margin-top: 4px; font-size: 11px; }
.e-pw-hint__l { color: var(--color-text-muted); }
.e-pw-hint__v { font-weight: 700; }
.e-pw-hint__v--strong { color: var(--color-primary-fill); }
.e-pw-hint__v--mid { color: var(--color-warning-foreground); }
.e-pw-hint__v--weak { color: var(--color-danger); }

/* Password checklist */
.e-pw-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 12px; margin-top: 10px; padding: 10px 12px; background: var(--color-surface); border-radius: 10px; }
.e-pw-check { font-size: 11px; color: var(--color-text-muted); display: flex; align-items: center; gap: 6px; }
.e-pw-check.is-ok { color: var(--color-primary-fill); }
.e-pw-check::before { content: "·"; width: 14px; height: 14px; display: grid; place-items: center; font-weight: 900; }
.e-pw-check.is-ok::before { content: "✓"; color: var(--color-primary-fill); }

/* Code verification 6-digit */
.e-otp { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; margin-bottom: 14px; max-width: 360px; }
.e-otp input { width: 100%; height: 56px; min-height: 56px; text-align: center; font-family: var(--font-display); font-size: 24px; font-weight: 900; border: 1.5px solid var(--color-border); border-radius: 12px; background: #fff; font-variant-numeric: tabular-nums; transition: all var(--duration-fast); padding: 0; box-sizing: border-box; }
.e-otp input:focus { outline: 0; border-color: var(--color-primary-fill); box-shadow: 0 0 0 3px var(--color-focus-ring); }
.e-otp input:not(:placeholder-shown) { background: var(--color-primary-soft); border-color: var(--color-primary-fill); color: var(--color-primary-fill); }

.e-otp-resend { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--color-text-muted); margin-bottom: 16px; }
.e-otp-resend a { color: var(--color-primary-fill); font-weight: 700; }
.e-otp-resend a.is-disabled { color: var(--color-text-disabled); pointer-events: none; }

/* Step indicator (for forgot password 3 steps) */
.e-auth-steps { display: flex; gap: 6px; margin-bottom: 22px; }
.e-auth-steps__s { flex: 1; height: 4px; border-radius: 2px; background: var(--color-border); }
.e-auth-steps__s.is-done { background: var(--color-primary-fill); }
.e-auth-steps__s.is-current { background: linear-gradient(90deg, var(--color-primary-fill) 50%, var(--color-border) 50%); }
.e-auth-steps__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--color-text-muted); text-transform: uppercase; margin-top: 8px; }
.e-auth-steps__label strong { color: var(--color-text); }
