/* ─────────────────────────────────────────────────────────────
   FW brand remap — ff/gg auth design vars → Fertility World palette.
   (Design verbatim; only these vars + the brand-panel gradient change.)
───────────────────────────────────────────────────────────────── */
:root{
  --fw-white:#ffffff; --fw-black:#0b1220;
  /* `--fw-red-*` keys reused from the original tokens — values are FW pink. */
  --fw-red:#E9348A; --fw-red-deep:#D12A7D; --fw-red-hover:#D12A7D;
  --fw-red-glow:rgba(233,52,138,.35); --fw-red-subtle:rgba(233,52,138,.08);
  --fw-error:#D12A4A; --fw-success:#198754;
  --fw-gray-50:#f8fafc; --fw-gray-100:#f1f5f9; --fw-gray-200:#e8edf3; --fw-gray-300:#d8e0ea;
  --fw-gray-400:#aab4c2; --fw-gray-500:#8a95a5; --fw-gray-600:#667085; --fw-gray-700:#475467;
  --fw-gray-800:#2d3a4b; --fw-gray-900:#1d2939;
  --fw-font-head:'Outfit',-apple-system,sans-serif; --fw-font-body:'Outfit',-apple-system,sans-serif;
  --fw-r-sm:8px; --fw-r-md:12px; --fw-r-lg:16px; --fw-r-xl:22px;
  --fw-sp-1:4px; --fw-sp-2:8px; --fw-sp-3:12px; --fw-sp-4:16px; --fw-sp-5:20px;
  --fw-sp-6:24px; --fw-sp-8:32px; --fw-sp-10:40px; --fw-sp-12:48px;
  --fw-text-2xs:10px; --fw-text-xs:12px; --fw-text-sm:13px; --fw-text-md:14px;
  --fw-text-base:15px; --fw-text-lg:17px; --fw-text-xl:20px; --fw-text-2xl:24px; --fw-text-3xl:30px;
}
/* Brand panel — FW pink → deep-pink → dark-pink-noir gradient */
.fw-auth__brand{background:linear-gradient(140deg,#E9348A 0%,#A8235F 55%,#5C1535 100%)}
/* minimal reset — FF auth page doesn't load the theme's reset, so without this
   the default body margin breaks the 100vh fit and adds scrollbars. */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%}
.fw-auth-body{overflow-x:hidden !important}
/* ───────────────── gg auth.css (verbatim) ───────────────── */
/* ═══════════════════════════════════════════
   ╔═════════════════════════════════════════╗
   ║   AUTH.CSS                              ║
   ║   login / signup / otp /                ║
   ║   forgotpassword / forgotusername       ║
   ║                                         ║
   ║   Tokens + reset come from core.css.    ║
   ║   NO :root, NO universal reset here.    ║
   ╚═════════════════════════════════════════╝
   ═══════════════════════════════════════════ */


/* --- Page shell: Start --- */
/* Prevent horizontal scroll at the very top of the chain */
html:has(.fw-auth-body){
  overflow-x:hidden !important;
  max-width:100% !important;
}
.fw-auth-body{
  height:100svh !important;
  min-height:100svh !important;
  width:100% !important;
  max-width:100% !important;
  background:var(--fw-white) !important;
  font-family:var(--fw-font-body) !important;
  color:var(--fw-gray-800);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;          /* desktop: no page scroll */
}

.fw-auth{
  display:grid !important;
  grid-template-columns:minmax(0,1.05fr) minmax(0,1fr) !important;
  height:100svh !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  overflow-x:hidden !important;
}
/* --- Page shell: End --- */


/* ═══════════════════════════════════════════
   BRAND PANEL (left on desktop, hero on mobile)
   ═══════════════════════════════════════════ */

.fw-auth__brand{
  position:relative !important;
  overflow:hidden !important;
  isolation:isolate;
  padding:var(--fw-sp-10) var(--fw-sp-12) !important;
  color:var(--fw-white) !important;
  background:var(--fw-black) !important;
  height:100svh;
  display:block;
}

.fw-auth__brand-stage{
  position:absolute;
  inset:0;
  z-index:0;
}
.fw-auth__brand-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  opacity:0;
  transform:scale(1.08);
  animation:ggAuthCrossfade 24s linear infinite, ggAuthKenBurns 24s linear infinite;
  will-change:opacity,transform;
}
.fw-auth__brand-img--0{ animation-delay: 0s, 0s; }
.fw-auth__brand-img--1{ animation-delay: -16s, -16s; }
.fw-auth__brand-img--2{ animation-delay: -8s, -8s; }

@keyframes ggAuthCrossfade{
  0%, 28%{ opacity:1; }
  33%, 95%{ opacity:0; }
  100%{ opacity:1; }
}
@keyframes ggAuthKenBurns{
  0%{ transform:scale(1.08) translate(0,0); }
  33%{ transform:scale(1.18) translate(-1.5%, -1%); }
  100%{ transform:scale(1.08) translate(0,0); }
}

.fw-auth__brand-veil{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(180deg, rgba(10,10,10,.20) 0%, rgba(10,10,10,0) 30%, rgba(10,10,10,0) 55%, rgba(10,10,10,.85) 100%),
    linear-gradient(100deg, rgba(10,10,10,.85) 0%, rgba(10,10,10,.55) 35%, rgba(10,10,10,.15) 65%, rgba(237,41,56,.18) 100%);
}

.fw-auth__brand-glow{
  position:absolute;
  inset:-20%;
  z-index:1;
  background:radial-gradient(ellipse at 30% 80%, rgba(237,41,56,.32) 0%, transparent 55%);
  filter:blur(40px);
  animation:ggAuthBrandGlow 18s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ggAuthBrandGlow{
  0%, 100%{ transform:translate(0,0) scale(1); opacity:.85; }
  50%{ transform:translate(-3%, 2%) scale(1.1); opacity:1; }
}

.fw-auth__brand-inner{
  position:relative !important;
  z-index:2;
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:space-between !important;
  align-items:flex-start !important;
  gap:var(--fw-sp-10);
  width:100%;
}

/* Back-to-home button — direct child of .fw-auth__brand,
   always absolute. On desktop sits ON THE SAME LINE as the logo
   (top matches brand padding-top); on mobile floats top-left of hero. */
.fw-auth__back{
  position:absolute !important;
  /* top matches brand's padding-top (var(--fw-sp-10) = 40px) so the
     button is vertically aligned with the logo image inside brand-inner */
  top:var(--fw-sp-10) !important;
  left:16px !important;
  z-index:4 !important;
  width:32px !important;
  height:32px !important;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  color:var(--fw-white) !important;
  border:1px solid rgba(255,255,255,.18);
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-decoration:none !important;
  font-size:16px;
  line-height:1;
  flex-shrink:0;
  cursor:pointer;
  transition:background-color .2s ease, transform .15s ease, border-color .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.fw-auth__back:hover{
  background:rgba(255,255,255,.22) !important;
  border-color:rgba(255,255,255,.32);
  transform:scale(1.06);
}
.fw-auth__back:active{
  transform:scale(.94);
}
.fw-auth__back:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(255,255,255,.4) !important;
}
.fw-auth__back i{ line-height:1; }

.fw-auth__brand-logo{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  width:fit-content;
}
.fw-auth__brand-logo-img{
  height:34px;
  width:auto;
  filter:brightness(0) invert(1) drop-shadow(0 2px 8px rgba(0,0,0,.4));
}

/* Bottom copy: brand-copy is anchored bottom of brand-inner via space-between */
.fw-auth__brand-copy{
  max-width:520px !important;
  width:100% !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  gap:var(--fw-sp-5);
  margin:0 !important;
  padding:0 !important;
}

/* ─── QUOTE ROTATOR ───
   Container is bottom-aligned. Each quote is absolutely positioned at
   bottom:0 — so the cite line is at the same y for every rotation.
   Margin-based spacing (no flex+gap) so it can't be broken by any
   overriding flex rule from elsewhere. */
.fw-auth__brand-quotes{
  position:relative !important;
  height:140px !important;
  width:100% !important;
  display:block !important;
}
.fw-auth__quote{
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  top:auto !important;
  margin:0 !important;
  padding:0 !important;
  text-align:left !important;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .55s ease, transform .55s ease;
  pointer-events:none;
  list-style:none;
  border:0;
}
.fw-auth__quote.is-active{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.fw-auth__quote-text{
  font-family:var(--fw-font-head) !important;
  font-weight:600 !important;
  font-size:var(--fw-text-2xl) !important;
  line-height:1.28 !important;
  letter-spacing:-.018em;
  color:var(--fw-white) !important;
  margin:0 0 var(--fw-sp-3) !important;
  padding:0 !important;
  text-shadow:0 2px 18px rgba(0,0,0,.4);
  /* Cap to 2 lines so the layout never jumps */
  display:-webkit-box !important;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-align:left !important;
}
.fw-auth__quote-cite{
  font-style:normal !important;
  font-size:var(--fw-text-sm) !important;
  font-weight:500;
  letter-spacing:.02em;
  color:rgba(255,255,255,.78) !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:var(--fw-sp-2);
  margin:0 !important;
  padding:0 !important;
}
.fw-auth__quote-cite::before{
  content:"";
  width:18px;
  height:1.5px;
  background:rgba(255,255,255,.35);
  display:inline-block;
  flex-shrink:0;
}

.fw-auth__brand-progress{
  display:flex !important;
  gap:var(--fw-sp-2) !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none;
}
.fw-auth__brand-tick{
  width:28px;
  height:3px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  transition:background-color .25s ease, width .25s ease, box-shadow .25s ease;
}
.fw-auth__brand-tick.is-active{
  background:var(--fw-white);
  width:44px;
  box-shadow:0 0 12px rgba(255,255,255,.5);
}


/* ═══════════════════════════════════════════
   FORM PANEL (right on desktop, sheet on mobile)
   ═══════════════════════════════════════════ */

.fw-auth__panel{
  position:relative !important;
  display:flex !important;
  flex-direction:column !important;
  background:var(--fw-white) !important;
  padding:var(--fw-sp-6) var(--fw-sp-10) !important;
  height:100svh;
  /* scroll instead of clipping when the form is taller than the viewport
     (short laptop heights) so bottom elements are never hidden */
  overflow-y:auto !important;
  overflow-x:hidden !important;
  width:100% !important;
}

.fw-auth__panel-glow{
  position:absolute;
  top:-20%;
  right:-15%;
  width:60%;
  aspect-ratio:1;
  background:radial-gradient(circle, var(--fw-red-subtle) 0%, transparent 65%);
  filter:blur(20px);
  pointer-events:none;
  z-index:0;
}

/* Top bar (LEFT form panel): back arrow (left) + original-colour logo (right).
   In-flow (not absolute) so it reserves its own space and never overlaps
   the "Welcome back" heading below. */
.fw-auth__topbar{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex:0 0 auto;
  margin-bottom:var(--fw-sp-4);
  z-index:5;
}
/* Desktop: logo lives on the blue brand panel, so hide the topbar logo here.
   It re-appears in the topbar on mobile (where the brand panel is hidden). */
.fw-auth__topbar-logo{ display:none; align-items:center; text-decoration:none; }
.fw-auth__topbar-logo img{ height:32px; width:auto; }   /* original colour (no filter) */
.fw-auth__topbar-back{
  width:38px;
  height:38px;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--fw-white);
  color:var(--fw-gray-700, #374151);
  border:1.5px solid var(--fw-gray-200);
  font-size:17px;
  line-height:1;
  text-decoration:none;
  transition:color .2s ease, border-color .2s ease, background-color .2s ease, transform .15s ease;
}
.fw-auth__topbar-back:hover{
  color:var(--fw-red);
  border-color:var(--fw-red);
  background:var(--fw-gray-50);
}
.fw-auth__topbar-back:active{ transform:scale(.94); }
.fw-auth__topbar-back:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(0,119,182,.25); }

.fw-auth__panel-inner{
  position:relative !important;
  z-index:1 !important;
  width:100% !important;
  max-width:440px !important;
  margin:0 auto !important;
  padding:var(--fw-sp-4) 0 !important;
  display:flex !important;
  flex-direction:column !important;
  /* grow to centre short forms, but don't shrink — taller forms keep their
     natural height and the panel scrolls instead of clipping the bottom */
  flex:1 0 auto !important;
  justify-content:center !important;
  min-height:0;
}

/* Heading */
.fw-auth__heading{
  margin:0 0 28px !important;     /* between sp-6 (24px) and sp-8 (32px) */
  padding:0 !important;
  text-align:left !important;
}
.fw-auth__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:var(--fw-sp-2);
  font-family:var(--fw-font-head);
  font-size:var(--fw-text-2xs);
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--fw-red);
  margin-bottom:var(--fw-sp-3);
  padding:6px 12px 6px 8px;
  border-radius:999px;
  background:rgba(0,119,182,.12);   /* our light blue — keeps "Welcome back" legible */
}
.fw-auth__eyebrow::before{
  content:"";
  width:6px;height:6px;
  border-radius:50%;
  background:var(--fw-red);
  box-shadow:0 0 0 4px rgba(237,41,56,.18);
  animation:ggAuthDotPulse 2.4s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes ggAuthDotPulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(237,41,56,.18); }
  50%{ box-shadow:0 0 0 8px rgba(237,41,56,.06); }
}
.fw-auth__title{
  font-family:var(--fw-font-head) !important;
  font-weight:700 !important;
  font-size:var(--fw-text-3xl) !important;
  line-height:1.12 !important;
  letter-spacing:-.022em !important;
  color:var(--fw-gray-900) !important;
  margin:0 !important;
  padding:0 !important;
  text-align:left !important;
  text-transform:none !important;
}
.fw-auth__subtitle{
  margin:var(--fw-sp-3) 0 0 !important;
  padding:0 !important;
  font-size:var(--fw-text-md) !important;
  line-height:1.55 !important;
  color:var(--fw-gray-500) !important;
  text-align:left !important;
  font-weight:400;
}
.fw-auth__subtitle strong{
  color:var(--fw-gray-800);
  font-weight:600;
}


/* ═══════════════════════════════════════════
   FORM
   ═══════════════════════════════════════════ */

.fw-auth__form{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  margin:0 !important;
  padding:0 !important;
  width:100% !important;
}

.fw-auth__field{
  display:flex !important;
  flex-direction:column !important;
  gap:4px !important;                    /* tight label↔input */
  margin:0 !important;
  padding:0 0 12px !important;           /* small reserved gap for error message */
  position:relative !important;          /* anchor for absolute invalid-feedback */
}
.fw-auth__label{
  font-family:var(--fw-font-head) !important;
  font-size:var(--fw-text-sm) !important;
  font-weight:600 !important;
  letter-spacing:.005em;
  color:var(--fw-gray-700) !important;
  display:inline-flex !important;
  justify-content:space-between !important;
  align-items:baseline !important;
  gap:var(--fw-sp-3);
  margin:0 !important;            /* kill any inherited label margin (Bootstrap adds .5rem) */
  padding:0 !important;
}
.fw-auth__label-aux{
  font-weight:500;
  font-size:var(--fw-text-xs);
  color:var(--fw-gray-400);
}

.fw-auth__input-wrap{
  position:relative;
  display:flex;
  align-items:center;
}
.fw-auth__input-icon{
  position:absolute;
  left:16px;
  top:50%;
  transform:translateY(-50%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--fw-gray-400);
  font-size:18px;
  line-height:1;
  pointer-events:none;
  transition:color .2s ease;
  z-index:1;
}

.fw-auth__input{
  width:100% !important;
  height:54px !important;
  padding:0 16px 0 48px !important;
  font-family:var(--fw-font-body) !important;
  font-size:16px !important;
  line-height:1.4 !important;
  color:var(--fw-gray-900) !important;
  background:var(--fw-white) !important;
  border:1.5px solid var(--fw-gray-200) !important;
  border-radius:var(--fw-r-lg) !important;
  outline:none !important;
  box-shadow:none !important;
  transition:border-color .2s ease, background-color .2s ease, padding-left .25s ease !important;
  -webkit-appearance:none;
  appearance:none;
  margin:0 !important;
  display:block;
}
.fw-auth__input::placeholder{ color:var(--fw-gray-400); font-weight:400; }
.fw-auth__input:hover{ border-color:var(--fw-gray-300); }
.fw-auth__input:focus,
.fw-auth__input-wrap:focus-within .fw-auth__input{
  border-color:var(--fw-red) !important;
  box-shadow:none !important;
}
.fw-auth__input-wrap:focus-within .fw-auth__input-icon{ color:var(--fw-red); }

/* ════════════════════════════════════════════
   Login: Email / Mobile segmented toggle
   ════════════════════════════════════════════ */
.fw-auth__seg{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--fw-gray-100);
  border:1.5px solid var(--fw-gray-200);
  border-radius:var(--fw-r-lg);
  padding:4px;
  margin-bottom:18px;
}
.fw-auth__seg-btn{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:42px;
  border:0;
  background:transparent;
  border-radius:calc(var(--fw-r-lg) - 5px);
  font-family:var(--fw-font-body);
  font-size:14.5px;
  font-weight:600;
  color:var(--fw-gray-500);
  cursor:pointer;
  transition:color .2s ease;
}
.fw-auth__seg-btn i{ font-size:16px; }
.fw-auth__seg-btn.is-active{ color:var(--fw-red); }
.fw-auth__seg-thumb{
  position:absolute;
  z-index:0;
  top:4px;
  left:4px;
  width:calc(50% - 4px);
  height:calc(100% - 8px);
  background:var(--fw-white);
  border-radius:calc(var(--fw-r-lg) - 5px);
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  transition:transform .28s cubic-bezier(.16,1,.3,1);
}
.fw-auth__form[data-login-mode="email"] .fw-auth__seg-thumb{ transform:translateX(100%); }

/* hide the inactive pane (overrides .fw-auth__field display:flex !important) */
.fw-auth__form .fw-auth__field[hidden]{ display:none !important; }

/* ── intl-tel-input (v24, local copy) — match the fw-auth input look ── */
.fw-auth__input-wrap--tel{ display:block; }
.fw-auth__input-wrap--tel .iti{ width:100%; display:block; }
/* leave room for the flag + separate dial-code button on the left.
   JS sets the exact padding-left per dial-code width; no padding
   transition here so re-asserting it on each keystroke doesn't animate. */
.fw-auth__input-wrap--tel .fw-auth__input{
  padding-left:96px !important;
  transition:border-color .2s ease, background-color .2s ease !important;
}
.fw-auth__input-wrap--tel .iti__selected-country{ background:transparent; }
.fw-auth__input-wrap--tel .iti__selected-country-primary{
  background:transparent;
  height:100%;
  padding:0 10px 0 14px;
  /* round the left corners to match the input's inner radius so the grey
     hover fill follows the rounded corner — no gap on the left side */
  border-radius:calc(var(--fw-r-lg) - 2px) 0 0 calc(var(--fw-r-lg) - 2px);
  transition:background-color .2s ease;
}
.fw-auth__input-wrap--tel .iti__selected-dial-code{
  font-family:var(--fw-font-body);
  font-size:15px;
  color:var(--fw-gray-900);
  margin-left:6px;
}
/* full-height grey fill on the left when hovering / opening the dropdown */
.fw-auth__input-wrap--tel .iti__selected-country-primary:hover,
.fw-auth__input-wrap--tel .iti__selected-country-primary:focus,
.fw-auth__input-wrap--tel .iti__selected-country[aria-expanded="true"] .iti__selected-country-primary{
  background:var(--fw-gray-100) !important;
}
.fw-auth__input-wrap--tel .iti__arrow{ margin-left:6px; border-top-color:var(--fw-gray-400); }
.fw-auth__input-wrap--tel .iti__arrow--up{ border-bottom-color:var(--fw-gray-400); }

/* ── Country dropdown — FF auth styling ── */
.iti__dropdown-content{
  margin-top:8px;
  /* base inline dropdown is z-index:2 — same as the password eye button,
     which paints over it. Raise it so it sits above other fields. */
  z-index:60 !important;
  border-radius:var(--fw-r-lg) !important;
  box-shadow:0 18px 44px -12px rgba(15,23,42,.28) !important;
  border:1px solid var(--fw-gray-200) !important;
  background:var(--fw-white);
  font-family:var(--fw-font-body);
  overflow:hidden;
  padding:6px;
}
/* ensure the open phone field stacks above sibling fields below it */
.fw-auth__input-wrap--tel .iti--inline-dropdown{ position:relative; z-index:60; }

/* search box — clean pill that matches the form inputs */
.iti__search-input{
  width:100% !important;
  height:42px;
  font-family:var(--fw-font-body) !important;
  font-size:14px !important;
  color:var(--fw-gray-900);
  padding:0 14px 0 38px !important;
  margin:2px 2px 6px !important;
  width:calc(100% - 4px) !important;
  border:1.5px solid var(--fw-gray-200) !important;
  border-radius:var(--fw-r-md, 12px) !important;
  background:var(--fw-gray-50, #f7f8fa) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239aa3af' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001q.044.06.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1 1 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0'/%3E%3C/svg%3E") no-repeat 14px center;
  outline:none !important;
  transition:border-color .2s ease, background-color .2s ease;
}
.iti__search-input::placeholder{ color:var(--fw-gray-400); }
.iti__search-input:focus{
  border-color:var(--fw-red) !important;
  background-color:var(--fw-white);
}

/* country list + rows */
.iti__country-list{
  padding:0 !important;
  max-height:240px;
  scrollbar-width:thin;
}
.iti__country{
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px !important;
  border-radius:var(--fw-r-md, 10px);
  font-size:14px;
  color:var(--fw-gray-800);
  transition:background-color .15s ease;
}
.iti__country .iti__country-name{ color:var(--fw-gray-900); font-weight:500; }
.iti__country .iti__dial-code{ color:var(--fw-gray-500); margin-left:auto; padding-left:10px; font-size:13px; }
.iti__country .iti__flag{ flex:0 0 auto; }
.iti__country:hover,
.iti__country.iti__highlight{
  background:var(--fw-red-50, rgba(0,119,182,.08)) !important;
  color:var(--fw-red);
}
.iti__country:hover .iti__country-name,
.iti__country.iti__highlight .iti__country-name{ color:var(--fw-red); }
.iti__country[aria-selected="true"]{ background:var(--fw-gray-100); }

/* thin custom scrollbar */
.iti__country-list::-webkit-scrollbar{ width:8px; }
.iti__country-list::-webkit-scrollbar-thumb{ background:var(--fw-gray-300); border-radius:8px; border:2px solid var(--fw-white); }

/* Trail (right side) */
.fw-auth__input--has-trail{ padding-right:50px; }
.fw-auth__input-trail{
  position:absolute;
  right:6px;
  top:50%;
  transform:translateY(-50%);
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:transparent;
  color:var(--fw-gray-400);
  cursor:pointer;
  border-radius:var(--fw-r-md);
  transition:color .2s ease, background-color .2s ease;
  z-index:2;
}
.fw-auth__input-trail:hover{
  color:var(--fw-gray-700);
  background:var(--fw-gray-100);
}
.fw-auth__input-trail:focus-visible{
  outline:2px solid var(--fw-red);
  outline-offset:2px;
}
.fw-auth__input-trail i{ font-size:18px; line-height:1; }

/* Phone prefix (legacy +91 single-text prefix — kept for back-compat) */
.fw-auth__input--has-prefix{ padding-left:78px; }
.fw-auth__input-prefix{
  position:absolute;
  left:46px;
  top:50%;
  transform:translateY(-50%);
  font-family:var(--fw-font-head);
  font-size:var(--fw-text-base);
  font-weight:600;
  color:var(--fw-gray-700);
  pointer-events:none;
  z-index:1;
  padding-right:10px;
  border-right:1.5px solid var(--fw-gray-200);
  height:24px;
  display:inline-flex;
  align-items:center;
}
.fw-auth__input-wrap:focus-within .fw-auth__input-prefix{
  color:var(--fw-gray-900);
  border-right-color:var(--fw-gray-300);
}

/* US country-code pill: flag + "+1" + divider, sits inside the input */
.fw-auth__phone-country{
  position:absolute !important;
  left:14px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:var(--fw-sp-2) !important;
  padding-right:var(--fw-sp-3) !important;
  height:30px;
  border-right:1.5px solid var(--fw-gray-200);
  font-family:var(--fw-font-head) !important;
  font-weight:600 !important;
  color:var(--fw-gray-800) !important;
  font-size:var(--fw-text-sm) !important;
  pointer-events:none;
  z-index:2;
  user-select:none;
}
.fw-auth__phone-country-flag{
  font-size:18px;
  line-height:1;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.08));
}
.fw-auth__phone-country-code{
  letter-spacing:.01em;
  font-variant-numeric:tabular-nums;
}
.fw-auth__input-wrap:focus-within .fw-auth__phone-country{
  border-right-color:var(--fw-gray-300) !important;
  color:var(--fw-gray-900) !important;
}
.fw-auth__input--phone{
  padding-left:92px !important;
  font-variant-numeric:tabular-nums;
  letter-spacing:.01em;
}

/* Smart login input — icon vs country-pill swap based on data-mode */
.fw-auth__input-wrap[data-mode="phone"] [data-show="email"]{ display:none !important; }
.fw-auth__input-wrap[data-mode="email"] [data-show="phone"]{ display:none !important; }
.fw-auth__input-wrap[data-show-default="email"]:not([data-mode]) [data-show="phone"]{ display:none !important; }
.fw-auth__input-wrap[data-show-default="email"]:not([data-mode="phone"]) .fw-auth__input{
  padding-left:48px !important;
}
.fw-auth__input-wrap[data-mode="phone"] .fw-auth__input{
  padding-left:92px !important;
  font-variant-numeric:tabular-nums;
}
/* Smooth transition between modes */
.fw-auth__input{
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease, padding-left .25s ease !important;
}
.fw-auth__phone-country{
  transition:opacity .2s ease;
}

/* ─── Strip Bootstrap's valid/invalid background icons + padding ───
   Bootstrap injects giant SVG checks/exclamation marks AND padding-right
   to make room for them. Both wrecked the OTP digit (number shifted left
   into the empty padded zone). We override both. */
.fw-auth__input,
.fw-auth__input:valid,
.fw-auth__input:invalid,
.fw-auth__input.is-valid,
.fw-auth__input.is-invalid,
.was-validated .fw-auth__input:valid,
.was-validated .fw-auth__input:invalid,
.fw-auth__otp-cell,
.fw-auth__otp-cell:valid,
.fw-auth__otp-cell:invalid,
.fw-auth__otp-cell.is-valid,
.fw-auth__otp-cell.is-invalid,
.was-validated .fw-auth__otp-cell:valid,
.was-validated .fw-auth__otp-cell:invalid{
  background-image:none !important;
}

/* OTP cell: lock padding to 0 in EVERY state so the digit stays centered.
   Bootstrap was adding padding-right: calc(1.5em + .75rem) for the icon. */
.fw-auth__otp-cell,
.fw-auth__otp-cell:valid,
.fw-auth__otp-cell:invalid,
.fw-auth__otp-cell.is-valid,
.fw-auth__otp-cell.is-invalid,
.fw-auth__otp-cell:focus,
.was-validated .fw-auth__otp-cell:valid,
.was-validated .fw-auth__otp-cell:invalid{
  padding:0 !important;
  text-align:center !important;
  background-position:center !important;
}

/* Valid OTP cell visual: green border only (no glow) */
.fw-auth__otp-cell.is-valid,
.fw-auth__otp-cell:valid:not(:placeholder-shown),
.was-validated .fw-auth__otp-cell:valid{
  border-color:var(--fw-success) !important;
  box-shadow:none !important;
}

/* Validation — invalid-feedback is absolutely positioned so it never
   shifts layout. Lives in the gap between this field and the next. */
.fw-auth__input.is-invalid{
  border-color:var(--fw-error) !important;
  background-image:none !important;
  box-shadow:none !important;
}
.fw-auth__input.is-invalid:focus{
  border-color:var(--fw-error) !important;
  box-shadow:none !important;
}
.fw-auth__input-wrap:has(.is-invalid) .fw-auth__input-icon{ color:var(--fw-error); }

/* Valid recovery state — after the user fixes a previously-invalid field,
   border turns green so they know it's accepted. No box-shadow, just border. */
.fw-auth__input.is-valid{
  border-color:var(--fw-success) !important;
  background-image:none !important;
  box-shadow:none !important;
}
.fw-auth__input.is-valid:focus{
  border-color:var(--fw-success) !important;
  box-shadow:none !important;
}
.fw-auth__input-wrap:has(.is-valid) .fw-auth__input-icon{ color:var(--fw-success); }
.fw-auth__field .invalid-feedback{
  position:absolute !important;
  /* sits 2px below the bottom of the field for clean breathing room */
  bottom:-2px !important;
  left:2px !important;
  top:auto !important;
  margin:0 !important;
  padding:0 !important;
  height:10px !important;
  font-size:10.5px !important;
  line-height:10px !important;
  font-weight:600 !important;
  letter-spacing:.005em;
  color:var(--fw-error) !important;
  display:none;
  pointer-events:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.fw-auth__field .is-invalid ~ .invalid-feedback,
.fw-auth__field .fw-auth__input-wrap:has(.is-invalid) ~ .invalid-feedback{
  display:block !important;
}
.was-validated .fw-auth__input:invalid ~ .invalid-feedback,
.was-validated .fw-auth__input-wrap:has(:invalid) ~ .invalid-feedback{
  display:block !important;
}
.was-validated .fw-auth__input:invalid{ border-color:var(--fw-error) !important; }

.fw-auth__hint{
  font-size:var(--fw-text-xs);
  color:var(--fw-gray-500);
  line-height:1.5;
}


/* ═══════════════════════════════════════════
   TIGHT SIGNUP MODE — desktop no-scroll for the 6-field form
   ═══════════════════════════════════════════ */
@media (min-width: 992px){
  .fw-auth-body[data-action="signup"] .fw-auth__panel{
    padding-top:var(--fw-sp-4) !important;
    padding-bottom:var(--fw-sp-4) !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__panel-inner{
    padding:0 !important;
    justify-content:flex-start !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__heading{
    margin-bottom:var(--fw-sp-4) !important;
    text-align:left !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__title{
    font-size:var(--fw-text-2xl) !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__subtitle{
    margin-top:6px !important;
    font-size:var(--fw-text-sm) !important;
    line-height:1.45 !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__legal{
    display:none !important;        /* terms checkbox already covers this */
  }
  .fw-auth-body[data-action="signup"] .fw-auth__form{
    gap:var(--fw-sp-3) !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__field{
    gap:5px !important;
    /* keep default 22px padding-bottom so the error message has 8px of
       clean air below the input — never overlaps */
  }
  .fw-auth-body[data-action="signup"] .fw-auth__input{
    height:44px !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__btn{
    height:46px !important;
    margin-top:var(--fw-sp-1) !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__strength{
    margin-top:0 !important;
    gap:5px !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__strength-bars{ gap:4px !important; }
  .fw-auth-body[data-action="signup"] .fw-auth__strength-bar{ height:3px !important; }
  .fw-auth-body[data-action="signup"] .fw-auth__strength-label{ font-size:11px !important; }
  .fw-auth-body[data-action="signup"] .fw-auth__check{
    font-size:12.5px !important;
    line-height:1.4 !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__foot{
    margin-top:var(--fw-sp-3) !important;
    padding-top:var(--fw-sp-3) !important;
  }
  .fw-auth-body[data-action="signup"] .fw-auth__legal{
    padding-top:var(--fw-sp-2) !important;
    margin-top:var(--fw-sp-3) !important;
  }
}

/* Inline row */
.fw-auth__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--fw-sp-4);
  flex-wrap:wrap;
}

.fw-auth__check{
  display:inline-flex;
  align-items:flex-start;
  gap:var(--fw-sp-3);
  cursor:pointer;
  user-select:none;
  font-size:var(--fw-text-sm);
  line-height:1.5;
  color:var(--fw-gray-700);
}
.fw-auth__check input[type="checkbox"]{
  appearance:none;
  -webkit-appearance:none;
  width:18px;height:18px;
  border:1.5px solid var(--fw-gray-300);
  border-radius:var(--fw-r-sm);
  background:var(--fw-white);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:border-color .2s ease, background-color .2s ease, box-shadow .2s ease;
  flex-shrink:0;
  position:relative;
  margin:1px 0 0;  /* align with first line of text */
}
.fw-auth__check input[type="checkbox"]:hover{ border-color:var(--fw-red); }
.fw-auth__check input[type="checkbox"]:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px var(--fw-red-subtle);
}
.fw-auth__check input[type="checkbox"]:checked{
  background:var(--fw-red);
  border-color:var(--fw-red);
  box-shadow:0 0 0 3px var(--fw-red-subtle);
}
.fw-auth__check input[type="checkbox"]:checked::after{
  content:"";
  width:5px;height:9px;
  border:solid var(--fw-white);
  border-width:0 2px 2px 0;
  transform:rotate(45deg) translate(-1px,-1px);
}
/* Invalid (unchecked + required) — red border + red label */
.fw-auth__check input[type="checkbox"].is-invalid,
.was-validated .fw-auth__check input[type="checkbox"]:invalid{
  border-color:var(--fw-error) !important;
  box-shadow:0 0 0 3px rgba(220,38,38,.14) !important;
  animation:ggAuthShake .3s ease;
}
.fw-auth__check.is-invalid > span,
.fw-auth__check.is-invalid,
.was-validated .fw-auth__check input[type="checkbox"]:invalid + span,
.was-validated .fw-auth__check input[type="checkbox"]:invalid ~ span{
  color:var(--fw-error) !important;
}

.fw-auth__link{
  font-family:var(--fw-font-head);
  font-size:var(--fw-text-sm);
  font-weight:600;
  color:var(--fw-red);
  text-decoration:none;
  transition:color .15s ease;
}
.fw-auth__link:hover{ color:var(--fw-red-hover); text-decoration:underline; }
.fw-auth__link:focus-visible{
  outline:2px solid var(--fw-red);
  outline-offset:3px;
  border-radius:2px;
}


/* ═══════════════════════════════════════════
   PASSWORD STRENGTH — bar + ticked checklist
   Bars give a quick visual; checklist shows exactly what's needed.
   ═══════════════════════════════════════════ */
.fw-auth__strength{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  margin-top:6px !important;
}

/* Single progress bar (replaces 4-segment) */
.fw-auth__strength-bars{
  display:block !important;
  height:3px !important;
  width:100% !important;
  background:var(--fw-gray-200) !important;
  border-radius:999px !important;
  overflow:hidden !important;
  position:relative !important;
}
.fw-auth__strength-bars::after{
  content:"";
  position:absolute;
  inset:0;
  width:0%;
  border-radius:999px;
  background:var(--fw-error);
  transition:width .3s ease, background-color .3s ease;
}
.fw-auth__strength[data-level="1"] .fw-auth__strength-bars::after{ width:25%; background:var(--fw-error); }
.fw-auth__strength[data-level="2"] .fw-auth__strength-bars::after{ width:50%; background:#F59E0B; }
.fw-auth__strength[data-level="3"] .fw-auth__strength-bars::after{ width:75%; background:#EAB308; }
.fw-auth__strength[data-level="4"] .fw-auth__strength-bars::after{ width:100%; background:var(--fw-success); }

/* Hide old single-line label, use checklist instead */
.fw-auth__strength-label{ display:none !important; }

/* Checklist */
.fw-auth__strength-list{
  display:grid !important;
  grid-template-columns:repeat(2, 1fr) !important;
  gap:4px 12px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
  font-size:11.5px !important;
  line-height:1.4 !important;
}
.fw-auth__strength-item{
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  color:var(--fw-gray-500) !important;
  transition:color .2s ease;
  margin:0 !important;
  padding:0 !important;
}
.fw-auth__strength-item .fw-strength-dot{
  width:14px;
  height:14px;
  border-radius:50%;
  border:1.5px solid var(--fw-gray-300);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  background:transparent;
  transition:all .2s ease;
  position:relative;
}
.fw-auth__strength-item .fw-strength-dot::after{
  content:"";
  width:5px;
  height:9px;
  border:solid var(--fw-white);
  border-width:0 1.5px 1.5px 0;
  transform:rotate(45deg) translate(-1px,-1px) scale(0);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.fw-auth__strength-item.is-met{
  color:var(--fw-success) !important;
}
.fw-auth__strength-item.is-met .fw-strength-dot{
  background:var(--fw-success);
  border-color:var(--fw-success);
}
.fw-auth__strength-item.is-met .fw-strength-dot::after{
  transform:rotate(45deg) translate(-1px,-1px) scale(1);
}


/* ═══════════════════════════════════════════
   OTP CODE BOXES
   ═══════════════════════════════════════════ */
.fw-auth__otp{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:var(--fw-sp-2);
}
.fw-auth__otp-cell{
  width:100%;
  aspect-ratio:1 / 1.15;
  max-height:64px;
  text-align:center;
  font-family:var(--fw-font-head);
  font-size:var(--fw-text-2xl);
  font-weight:700;
  color:var(--fw-gray-900);
  background:var(--fw-gray-50);
  border:1.5px solid var(--fw-gray-200);
  border-radius:var(--fw-r-lg);
  outline:none;
  box-shadow:none;
  transition:border-color .2s ease, background-color .2s ease;
  -webkit-appearance:none;
  appearance:none;
  caret-color:var(--fw-red);
  padding:0;
}
.fw-auth__otp-cell:hover{ border-color:var(--fw-gray-300); }
.fw-auth__otp-cell:focus{
  background:var(--fw-white);
  border-color:var(--fw-red);
  box-shadow:none;
}
.fw-auth__otp-cell:not(:placeholder-shown){
  background:var(--fw-white);
  border-color:var(--fw-red);
  box-shadow:none;
}
.fw-auth__otp-cell.is-invalid{
  border-color:var(--fw-error) !important;
  box-shadow:none !important;
  animation:ggAuthShake .35s ease;
}
@keyframes ggAuthShake{
  20%, 60%{ transform:translateX(-4px); }
  40%, 80%{ transform:translateX(4px); }
}

.fw-auth__otp-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--fw-sp-3);
  font-size:var(--fw-text-sm);
  color:var(--fw-gray-500);
  flex-wrap:wrap;
}
.fw-auth__otp-timer{
  font-family:var(--fw-font-head);
  font-weight:600;
  font-variant-numeric:tabular-nums;
  color:var(--fw-gray-700);
}
.fw-auth__otp-resend{
  font-family:var(--fw-font-head);
  font-size:var(--fw-text-sm);
  font-weight:600;
  color:var(--fw-red);
  background:none;
  border:none;
  padding:0;
  cursor:pointer;
  transition:color .15s ease;
}
.fw-auth__otp-resend:hover:not([disabled]){ text-decoration:underline; }
.fw-auth__otp-resend[disabled]{ color:var(--fw-gray-400); cursor:not-allowed; }


/* ═══════════════════════════════════════════
   PREMIUM CTA BUTTON  (mirrors home .ff-hr__cta)
   ═══════════════════════════════════════════ */
.fw-auth__btn{
  position:relative !important;
  width:100% !important;
  height:54px !important;
  font-family:var(--fw-font-head) !important;
  font-size:var(--fw-text-md) !important;
  font-weight:600 !important;
  letter-spacing:.005em;
  color:var(--fw-white) !important;
  background:linear-gradient(135deg, var(--fw-red) 0%, var(--fw-red-deep) 100%) !important;
  border:none !important;
  border-radius:var(--fw-r-lg) !important;
  cursor:pointer;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:var(--fw-sp-2) !important;
  transition:transform .12s ease, box-shadow .25s ease, filter .2s ease;
  box-shadow:
    0 8px 22px var(--fw-red-glow),
    0 1px 0 rgba(255,255,255,.18) inset,
    0 -1px 0 rgba(0,0,0,.18) inset;
  overflow:hidden !important;
  isolation:isolate;
  -webkit-tap-highlight-color:transparent;
  text-decoration:none !important;
  margin:0 !important;
  padding:0 !important;
  text-transform:none !important;
}
.fw-auth__btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.32), transparent);
  transform:translateX(-100%);
  transition:transform .9s ease;
  z-index:-1;
}
.fw-auth__btn:hover{
  filter:brightness(1.06);
  box-shadow:0 14px 30px var(--fw-red-glow), 0 1px 0 rgba(255,255,255,.22) inset, 0 -1px 0 rgba(0,0,0,.18) inset;
}
.fw-auth__btn:hover::after{ transform:translateX(100%); }
.fw-auth__btn:active{
  transform:translateY(1px);
  box-shadow:0 4px 12px var(--fw-red-glow), 0 1px 0 rgba(255,255,255,.18) inset, 0 -1px 0 rgba(0,0,0,.18) inset;
}
.fw-auth__btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px var(--fw-red-subtle), 0 8px 22px var(--fw-red-glow), 0 1px 0 rgba(255,255,255,.18) inset, 0 -1px 0 rgba(0,0,0,.18) inset;
}
.fw-auth__btn[disabled]{ opacity:.55; cursor:not-allowed; box-shadow:none; }

.fw-auth__btn--ghost{
  background:transparent !important;
  color:var(--fw-gray-800) !important;
  box-shadow:inset 0 0 0 1.5px var(--fw-gray-200) !important;
  text-decoration:none !important;
}
.fw-auth__btn--ghost:hover{
  background:var(--fw-gray-50) !important;
  color:var(--fw-gray-900) !important;
  filter:none !important;
}
.fw-auth__btn--ghost::after{ display:none !important; }

/* "Send me a one-time code" — FF orange: light tint by default,
   solid orange on hover, icon recolours with it. */
.fw-auth__btn--ghost[data-otp-trigger]{
  background:rgba(255,140,0,.12) !important;
  color:#C26A00 !important;
  box-shadow:inset 0 0 0 1.5px rgba(255,140,0,.24) !important;
  transition:background-color .2s ease, color .2s ease, box-shadow .2s ease !important;
}
.fw-auth__btn--ghost[data-otp-trigger] i{ color:#C26A00 !important; transition:color .2s ease; }
.fw-auth__btn--ghost[data-otp-trigger]:hover,
.fw-auth__btn--ghost[data-otp-trigger]:focus-visible{
  background:#FF8C00 !important;
  color:#fff !important;
  box-shadow:inset 0 0 0 1.5px #FF8C00 !important;
}
.fw-auth__btn--ghost[data-otp-trigger]:hover i,
.fw-auth__btn--ghost[data-otp-trigger]:focus-visible i{ color:#fff !important; }


/* ─── "or" divider used between sign-in methods ─── */
.fw-auth__or{
  display:flex !important;
  align-items:center !important;
  gap:var(--fw-sp-3) !important;
  margin:var(--fw-sp-2) 0 !important;
  color:var(--fw-gray-400) !important;
  font-family:var(--fw-font-head) !important;
  font-size:11px !important;
  font-weight:600 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
}
.fw-auth__or::before,
.fw-auth__or::after{
  content:"";
  flex:1 1 auto;
  height:1px;
  background:var(--fw-gray-200);
}


/* Footer + legal */
.fw-auth__foot{
  margin:var(--fw-sp-8) 0 0 !important;       /* breathing room from button */
  padding:var(--fw-sp-4) 0 0 !important;
  border-top:1px solid var(--fw-gray-100) !important;
  text-align:center !important;
  font-size:var(--fw-text-sm) !important;
  color:var(--fw-gray-500) !important;
}
.fw-auth__foot .fw-auth__link{ margin-left:var(--fw-sp-1); }
.fw-auth__legal{
  margin:auto 0 0 !important;                  /* pin to bottom of panel-inner */
  padding-top:var(--fw-sp-6) !important;
  font-size:var(--fw-text-xs) !important;
  line-height:1.5 !important;
  color:var(--fw-gray-400) !important;
  text-align:center !important;
}
.fw-auth__legal-link{
  color:var(--fw-gray-600);
  text-decoration:none;
  font-weight:500;
}
.fw-auth__legal-link:hover{ color:var(--fw-red); text-decoration:underline; }


/* ═══════════════════════════════════════════
   SUCCESS STATE — used after forgot-password / forgot-username
   ═══════════════════════════════════════════ */
.fw-auth__success{
  text-align:center;
  padding:var(--fw-sp-2) 0;
}
.fw-auth__success-icon{
  width:52px;
  height:52px;
  border-radius:50%;
  background:linear-gradient(135deg, #22C55E 0%, #16A34A 100%);
  color:var(--fw-white);
  font-size:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:var(--fw-sp-4);
  box-shadow:0 8px 22px rgba(34,197,94,.30), 0 1px 0 rgba(255,255,255,.25) inset;
  animation:ggAuthSuccessPop .45s cubic-bezier(.34,1.56,.64,1);
}
@keyframes ggAuthSuccessPop{
  0%{ transform:scale(.6); opacity:0; }
  100%{ transform:scale(1); opacity:1; }
}


/* ═══════════════════════════════════════════
   STUB
   ═══════════════════════════════════════════ */
.fw-auth__stub{
  position:relative;
  border:1.5px dashed rgba(237,41,56,.25);
  border-radius:var(--fw-r-xl);
  padding:var(--fw-sp-8);
  text-align:center;
  background:linear-gradient(135deg, var(--fw-red-subtle) 0%, var(--fw-gray-50) 100%);
  overflow:hidden;
}
.fw-auth__stub::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 0%, rgba(237,41,56,.12) 0%, transparent 50%);
  pointer-events:none;
}
.fw-auth__stub-icon{
  position:relative;
  width:60px;
  height:60px;
  border-radius:50%;
  background:var(--fw-white);
  color:var(--fw-red);
  font-size:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:var(--fw-sp-4);
  box-shadow:0 8px 20px var(--fw-red-glow);
}
.fw-auth__stub-title{
  font-family:var(--fw-font-head);
  font-weight:700;
  font-size:var(--fw-text-xl);
  color:var(--fw-gray-900);
  margin-bottom:var(--fw-sp-2);
}
.fw-auth__stub-text{
  color:var(--fw-gray-600);
  font-size:var(--fw-text-sm);
  line-height:1.55;
  position:relative;
}


/* ═══════════════════════════════════════════
   RESPONSIVE — tablet
   ═══════════════════════════════════════════ */

@media (max-width: 1199px){
  .fw-auth__brand{ padding:var(--fw-sp-8) var(--fw-sp-10); }
  .fw-auth__panel{ padding:var(--fw-sp-8); }
  .fw-auth__quote-text{ font-size:var(--fw-text-xl); }
  .fw-auth__brand-quotes{ height:120px; }
  /* Brand padding-top shrinks to sp-8 here → keep back button aligned with logo */
  .fw-auth__back{
    top:var(--fw-sp-8) !important;
    left:12px !important;
  }
}

@media (max-width: 991px){
  /* MOBILE: page must scroll naturally — fixed-height grid hides the form */
  .fw-auth-body{
    height:auto !important;
    min-height:100svh !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
  }
  .fw-auth{
    grid-template-columns:1fr !important;
    display:grid !important;
    height:auto !important;
    min-height:100svh !important;
  }

  .fw-auth__brand{
    height:auto !important;
    min-height:300px !important;
    max-height:360px !important;
    /* extra bottom padding so quotes never get covered by form panel overlap */
    padding:28px var(--fw-sp-6) calc(var(--fw-sp-8) + 24px) !important;
  }
  .fw-auth__brand-veil{
    background:
      linear-gradient(180deg, rgba(10,10,10,.30) 0%, rgba(10,10,10,0) 25%, rgba(10,10,10,0) 50%, rgba(10,10,10,.92) 100%),
      linear-gradient(135deg, rgba(185,28,40,.28) 0%, transparent 60%);
  }
  .fw-auth__brand-glow{
    inset:-10%;
    background:radial-gradient(ellipse at 50% 90%, rgba(237,41,56,.45) 0%, transparent 55%);
    filter:blur(50px);
  }
  .fw-auth__brand-inner{
    min-height:initial !important;
    height:100% !important;
    gap:var(--fw-sp-4) !important;
    justify-content:center !important;        /* center vertically — never hidden */
    align-items:center !important;
    text-align:center !important;
  }
  .fw-auth__brand-logo{ display:none !important; }

  /* Back button: same top-left anchor, slightly bigger + glass blur on mobile */
  .fw-auth__back{
    top:max(16px, env(safe-area-inset-top)) !important;
    left:16px !important;
    width:38px !important;
    height:38px !important;
    font-size:17px !important;
    background:rgba(255,255,255,.18) !important;
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
  }

  /* Quote centered, no bottom-anchor (form overlap was clipping it) */
  .fw-auth__brand-copy{
    gap:var(--fw-sp-4) !important;
    align-items:center !important;
    text-align:center !important;
    max-width:520px !important;
    width:100% !important;
  }
  .fw-auth__brand-quotes{ height:88px !important; }
  .fw-auth__quote{
    text-align:center !important;
    bottom:auto !important;
    top:0 !important;
  }
  .fw-auth__quote-text{
    font-size:var(--fw-text-lg) !important;
    line-height:1.32 !important;
    font-weight:600 !important;
    text-align:center !important;
  }
  .fw-auth__quote-cite{
    font-size:var(--fw-text-xs) !important;
    justify-content:center !important;
  }
  .fw-auth__quote-cite::before{ display:none !important; }
  .fw-auth__brand-progress{ justify-content:center !important; }

  .fw-auth__topbar{
    position:static !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    margin-bottom:0 !important;
    padding:var(--fw-sp-4) var(--fw-sp-5) !important;
    border-bottom:1px solid var(--fw-gray-100) !important;
    background:var(--fw-white) !important;
  }
  .fw-auth__topbar-logo{ display:inline-flex !important; }
  .fw-auth__topbar-logo img{ height:28px !important; }
  .fw-auth__topbar-back{ width:36px !important; height:36px !important; }

  .fw-auth__panel{
    position:relative !important;
    margin-top:-60px !important;
    border-radius:28px 28px 0 0 !important;
    background:var(--fw-white) !important;
    padding:var(--fw-sp-1) var(--fw-sp-5) var(--fw-sp-8) !important;
    height:auto !important;
    min-height:auto !important;
    overflow:visible !important;
    box-shadow:0 -8px 32px rgba(0,0,0,.06) !important;
    z-index:2 !important;
  }
  .fw-auth__panel-inner{
    justify-content:flex-start !important;
    flex:0 0 auto !important;
  }
  .fw-auth__panel-glow{
    top:-10%;
    right:-25%;
    width:80%;
  }
  .fw-auth__panel-inner{
    max-width:480px;
    padding:28px 0 var(--fw-sp-4);
  }
}

@media (max-width: 575px){
  .fw-auth-body{ background:var(--fw-white) !important; }

  .fw-auth__brand{
    min-height:260px !important;
    max-height:300px !important;
    padding:var(--fw-sp-6) var(--fw-sp-5) calc(28px + 24px) !important;
    padding-top:max(var(--fw-sp-6), env(safe-area-inset-top)) !important;
  }
  .fw-auth__brand-veil{
    background:
      linear-gradient(180deg, rgba(10,10,10,.20) 0%, rgba(10,10,10,0) 30%, rgba(10,10,10,.95) 100%),
      linear-gradient(160deg, rgba(185,28,40,.22) 0%, transparent 65%);
  }
  .fw-auth__brand-glow{
    background:radial-gradient(ellipse at 50% 95%, rgba(237,41,56,.55) 0%, transparent 55%);
  }
  .fw-auth__brand-quotes{ height:88px !important; }
  .fw-auth__quote-text{
    font-size:var(--fw-text-md) !important;
    font-weight:600 !important;
    line-height:1.35 !important;
  }
  .fw-auth__brand-tick{ width:22px !important; }
  .fw-auth__brand-tick.is-active{ width:34px !important; }

  .fw-auth__topbar{
    padding-top:max(var(--fw-sp-3), env(safe-area-inset-top));
    padding-bottom:var(--fw-sp-3);
  }

  .fw-auth__panel{
    margin-top:-60px !important;
    border-radius:28px 28px 0 0 !important;
    padding:var(--fw-sp-1) var(--fw-sp-5) max(var(--fw-sp-6), env(safe-area-inset-bottom)) !important;
  }
  .fw-auth__panel-inner{ padding:var(--fw-sp-2) 0 var(--fw-sp-3) !important; }

  .fw-auth__heading{ margin-bottom:var(--fw-sp-6) !important; }
  .fw-auth__title{
    font-size:var(--fw-text-2xl) !important;
    line-height:1.15 !important;
    letter-spacing:-.025em !important;
  }
  .fw-auth__subtitle{ font-size:var(--fw-text-sm) !important; line-height:1.55 !important; }

  .fw-auth__form{ gap:var(--fw-sp-3) !important; }
  .fw-auth__input{
    height:50px !important;
    border-radius:var(--fw-r-lg) !important;
    background:var(--fw-gray-50) !important;
    border-color:var(--fw-gray-100) !important;
  }
  .fw-auth__input:focus,
  .fw-auth__input-wrap:focus-within .fw-auth__input{ background:var(--fw-white) !important; }
  .fw-auth__btn{
    height:52px !important;
    border-radius:var(--fw-r-lg) !important;
    margin-top:var(--fw-sp-1) !important;
  }
  .fw-auth__legal{ margin-top:var(--fw-sp-6) !important; padding:0 var(--fw-sp-2) !important; }

  /* OTP boxes get a touch larger on mobile for easier tapping */
  .fw-auth__otp{ gap:var(--fw-sp-2); }
  .fw-auth__otp-cell{
    font-size:var(--fw-text-xl);
    background:var(--fw-gray-50);
    border-color:var(--fw-gray-100);
  }
}


/* ═══════════════════════════════════════════
   TOAST NOTIFICATIONS  (used by ggToast.show in auth.js)
   ═══════════════════════════════════════════ */
.fw-toast-host{
  position:fixed !important;
  top:max(20px, env(safe-area-inset-top)) !important;
  right:20px !important;
  left:auto !important;
  z-index:9999 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  pointer-events:none !important;
}
.fw-toast{
  display:flex !important;
  align-items:center !important;
  gap:var(--fw-sp-3) !important;
  min-width:280px;
  max-width:380px;
  padding:12px 18px 12px 14px !important;
  background:var(--fw-white) !important;
  border-radius:var(--fw-r-lg) !important;
  box-shadow:0 12px 30px rgba(0,0,0,.12), 0 4px 10px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04) !important;
  font-family:var(--fw-font-body) !important;
  font-size:13.5px !important;
  line-height:1.4 !important;
  color:var(--fw-gray-800) !important;
  font-weight:500 !important;
  pointer-events:auto;
  transform:translateX(120%);
  opacity:0;
  transition:transform .35s cubic-bezier(.34,1.4,.64,1), opacity .25s ease;
  position:relative;
  overflow:hidden;
}
.fw-toast.is-visible{
  transform:translateX(0);
  opacity:1;
}
.fw-toast__icon{
  width:32px;
  height:32px;
  border-radius:50%;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:16px;
  flex-shrink:0;
}
.fw-toast--success .fw-toast__icon{ background:rgba(34,197,94,.12); color:#16A34A; }
.fw-toast--error   .fw-toast__icon{ background:rgba(220,38,38,.12); color:var(--fw-error); }
.fw-toast--info    .fw-toast__icon{ background:var(--fw-red-subtle); color:var(--fw-red); }
.fw-toast--loading .fw-toast__icon{ background:var(--fw-red-subtle); color:var(--fw-red); }
.fw-toast--loading .fw-toast__icon i{
  animation:ggToastSpin .8s linear infinite;
  display:inline-block;
}
@keyframes ggToastSpin{ to{ transform:rotate(360deg); } }
.fw-toast__body{
  flex:1 1 auto;
  min-width:0;
}
.fw-toast__title{
  font-family:var(--fw-font-head);
  font-weight:600;
  font-size:14px;
  color:var(--fw-gray-900);
  display:block;
}
.fw-toast__text{
  display:block;
  color:var(--fw-gray-600);
}
.fw-toast__close{
  border:none;
  background:transparent;
  color:var(--fw-gray-400);
  cursor:pointer;
  padding:6px;
  border-radius:6px;
  font-size:14px;
  display:inline-flex;
  align-items:center;
  flex-shrink:0;
  transition:color .15s ease, background-color .15s ease;
}
.fw-toast__close:hover{ color:var(--fw-gray-700); background:var(--fw-gray-100); }
.fw-toast__progress{
  position:absolute;
  bottom:0; left:0;
  height:2px;
  background:linear-gradient(90deg, var(--fw-red), var(--fw-red-deep));
  width:100%;
  transform-origin:left;
  animation:ggToastProgress var(--fw-toast-dur, 4s) linear forwards;
}
.fw-toast--success .fw-toast__progress{ background:linear-gradient(90deg, #22C55E, #16A34A); }
.fw-toast--error   .fw-toast__progress{ background:linear-gradient(90deg, #EF4444, var(--fw-error)); }
@keyframes ggToastProgress{ from{ transform:scaleX(1); } to{ transform:scaleX(0); } }

@media (max-width: 575px){
  .fw-toast-host{
    top:max(12px, env(safe-area-inset-top)) !important;
    right:12px !important;
    left:12px !important;
  }
  .fw-toast{
    min-width:0;
    max-width:none;
    transform:translateY(-120%);
  }
  .fw-toast.is-visible{ transform:translateY(0); }
}


/* ═══════════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce){
  .fw-auth__brand-img,
  .fw-auth__brand-glow,
  .fw-auth__quote,
  .fw-auth__brand-tick,
  .fw-auth__eyebrow::before,
  .fw-auth__btn::after,
  .fw-auth__success-icon,
  .fw-auth__otp-cell.is-invalid{
    animation:none !important;
    transition:none !important;
  }
  .fw-auth__brand-img--0{ opacity:1; transform:scale(1); }
  .fw-auth__brand-img--1,
  .fw-auth__brand-img--2{ opacity:0; }
}

/* ═══════════════════════════════════════════════════════════════════
   FERTILITY FOUNT — medical-professional brand panel redesign
   (keeps gg's split layout; restyles the left panel for FF)
═══════════════════════════════════════════════════════════════════ */
/* deeper, calmer medical gradient + a soft clinical glow */
.fw-auth__brand{background:radial-gradient(120% 90% at 18% 12%, #0d8bd1 0%, #0077B6 38%, #005a8c 72%, #023a5e 100%) !important}
.fw-auth__brand-glow{background:radial-gradient(closest-side, rgba(255,255,255,.16), transparent 70%) !important}
/* subtle medical grid/dot texture over the gradient */
.fw-auth__brand-stage::after{content:"";position:absolute;inset:0;opacity:.5;
	background-image:radial-gradient(rgba(255,255,255,.10) 1px, transparent 1px);background-size:22px 22px;mix-blend-mode:overlay}

/* logo reads white on the blue panel */
.fw-auth__brand .fw-auth__brand-logo-img{filter:brightness(0) invert(1);height:34px;width:auto}

/* brand inner: top logo → hero → features → testimonials, evenly spaced */
.fw-auth__brand-inner{display:flex;flex-direction:column;gap:clamp(18px,3vh,30px);justify-content:center}

.fw-auth__hero{max-width:30ch}
/* Brand-panel eyebrow ("Your fertility journey") — white on the blue panel.
   Scoped to .fw-auth__brand so it no longer overrides the form-panel
   "Welcome back" eyebrow (which is blue on a light-blue badge). */
.fw-auth__brand .fw-auth__eyebrow{display:inline-flex;align-items:center;gap:7px;font-family:'Outfit',sans-serif;
	font-size:11.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:#fff;
	background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:6px 13px;border-radius:100px}
.fw-auth__brand .fw-auth__eyebrow i{font-size:13px}
.fw-auth__brand .fw-auth__eyebrow::before{display:none}   /* brand eyebrow uses its icon, not the pulsing dot */
.fw-auth__headline{font-family:'Fraunces',Georgia,serif;font-weight:600;color:#fff;
	font-size:clamp(26px,2.4vw,40px);line-height:1.12;letter-spacing:-.5px;margin:16px 0 12px;text-wrap:balance}
.fw-auth__lead{color:rgba(255,255,255,.85);font-size:15px;line-height:1.65;margin:0;max-width:42ch}

.fw-auth__features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.fw-auth__features li{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.94);font-size:14.5px;font-weight:500}
.fw-auth__feat-ico{width:32px;height:32px;flex:0 0 32px;border-radius:9px;background:rgba(255,255,255,.15);
	display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff}

/* testimonial quotes — quieter so the hero leads */
.fw-auth__brand-quotes{margin-top:4px}
.fw-auth__quote-text{font-family:'Fraunces',Georgia,serif;font-style:italic}

/* form side: warm, professional heading type */
.fw-auth__title{font-family:'Fraunces',Georgia,serif;font-weight:600;letter-spacing:-.4px}

/* hide the bulky features on short/landscape panels so it never scrolls */
@media (max-height:720px){ .fw-auth__features{display:none} .fw-auth__lead{display:none} }

/* no photos on FF → replace gg's dark/red veil with a clean legibility wash, and center the stack */
.fw-auth__brand-veil{background:linear-gradient(180deg, rgba(2,40,70,.10) 0%, rgba(2,40,70,0) 35%, rgba(2,40,70,.30) 100%) !important}
.fw-auth__brand-inner{justify-content:center !important; gap:clamp(16px,2.6vh,28px) !important}
.fw-auth__brand-logo{margin-bottom:4px}

/* ════ MIRROR: form LEFT, brand RIGHT (form panel is first in DOM) ════ */
.fw-auth.fw-auth-reverse{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr) !important}
@media (max-width:980px){
	.fw-auth.fw-auth-reverse{grid-template-columns:1fr !important}
	.fw-auth-reverse .fw-auth__brand{display:none !important}
}

/* ════════════════════════════════════════════════════════════
   SCALE FORM TO DESKTOP/LAPTOP HEIGHT
   On 15.6" laptops (~768px usable) and shorter, tighten the vertical
   rhythm so every field + button fits without the bottom being hidden.
   Scoped to desktop (≥981px); mobile already scrolls + stacks. The panel
   also scrolls as a final safety net (overflow-y:auto above).
   ════════════════════════════════════════════════════════════ */
@media (min-width:981px) and (max-height:860px){
  .fw-auth__panel{ padding-top:var(--fw-sp-4) !important; padding-bottom:var(--fw-sp-4) !important; }
  .fw-auth__panel-inner{ padding:var(--fw-sp-2) 0 !important; }
  .fw-auth__heading{ margin-bottom:16px !important; }
  .fw-auth__title{ font-size:var(--fw-text-2xl) !important; }
  .fw-auth__subtitle{ margin-top:var(--fw-sp-2) !important; }
  .fw-auth__form{ gap:6px !important; }
  .fw-auth__seg{ margin-bottom:12px !important; }
  .fw-auth__seg-btn{ height:38px !important; }
  .fw-auth__input{ height:48px !important; }
  .fw-auth__field{ padding-bottom:10px !important; }
  .fw-auth__btn{ height:48px !important; }
  .fw-auth__or{ margin:8px 0 !important; }
  .fw-auth__legal{ margin-top:12px !important; }
  .fw-auth__foot{ margin-top:14px !important; }
  .fw-auth__topbar{ margin-bottom:var(--fw-sp-3) !important; }
}
@media (min-width:981px) and (max-height:720px){
  .fw-auth__heading{ margin-bottom:10px !important; }
  .fw-auth__title{ font-size:var(--fw-text-xl) !important; }
  .fw-auth__subtitle{ display:none !important; }
  .fw-auth__form{ gap:4px !important; }
  .fw-auth__seg{ margin-bottom:10px !important; }
  .fw-auth__seg-btn{ height:34px !important; }
  .fw-auth__input{ height:44px !important; }
  .fw-auth__field{ padding-bottom:8px !important; }
  .fw-auth__btn{ height:44px !important; }
  .fw-auth__label{ margin-bottom:4px !important; }
}

/* Flash banner (no-AJAX PRG messages) */
.fw-auth__flash{border-radius:12px;padding:11px 14px;font-size:13.5px;line-height:1.5;margin-bottom:16px}
.fw-auth__flash i{margin-right:6px}
.fw-auth__flash--err{background:rgba(255,140,0,.1);border:1px solid rgba(255,140,0,.3);color:#b35a00}
.fw-auth__flash--ok{background:rgba(0,119,182,.08);border:1px solid rgba(0,119,182,.22);color:#0077B6}


/* ─────────────────────────────────────────────────────────────
   FW design-flow extras — small additions on top of the
   ported ff/gg design (used by the design-flow demo block in
   auth.js so submit-with-errors gives a quick shake feedback).
   ───────────────────────────────────────────────────────────── */
@keyframes fw-auth-shake {
  10%, 90% { transform: translate3d(-1px, 0, 0); }
  20%, 80% { transform: translate3d(2px, 0, 0); }
  30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
  40%, 60% { transform: translate3d(4px, 0, 0); }
}
.fw-auth__form--shake {
  animation: fw-auth-shake .45s cubic-bezier(.36,.07,.19,.97) both;
}


/* ═════════════════════════════════════════════════════════════════════
   NEW SINGLE-PAGE FLOW — additions on top of the ported ff/gg design.
   • Step indicator at the top of the form panel
   • Screen show/hide + fade-up transition
   • Locked-identifier display blocks
   • Compact strength meter (no checklist clutter)
   • Toast notifications
   • Success screen with animated check
   ═════════════════════════════════════════════════════════════════════ */

/* ── Step indicator ── */
.fw-auth__steps {
	display: flex; align-items: center; gap: 6px;
	list-style: none; padding: 0; margin: 0 0 28px;
}
.fw-auth__step {
	display: flex; align-items: center; gap: 8px;
	flex: 1;
	font-size: 12px; font-weight: 600;
	color: var(--fw-gray-500, #8a95a5);
	min-width: 0;
}
.fw-auth__step-num {
	display: inline-flex; align-items: center; justify-content: center;
	width: 26px; height: 26px; flex-shrink: 0;
	border-radius: 50%;
	background: var(--fw-gray-100, #f1f5f9);
	color: var(--fw-gray-600, #667085);
	font-size: 12px; font-weight: 700;
	border: 1.5px solid var(--fw-gray-200, #e8edf3);
	transition: background .25s, color .25s, border-color .25s, transform .25s;
}
.fw-auth__step-label {
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fw-auth__step + .fw-auth__step::before {
	content: ''; height: 2px; flex: 1 1 0;
	background: var(--fw-gray-200, #e8edf3);
	margin-right: 8px; border-radius: 999px;
	transition: background .25s;
}
.fw-auth__step.is-active .fw-auth__step-num {
	background: var(--fw-red, #E9348A);
	color: #fff;
	border-color: var(--fw-red, #E9348A);
	transform: scale(1.06);
	box-shadow: 0 4px 14px rgba(233,52,138,.32);
}
.fw-auth__step.is-active { color: var(--fw-red-deep, #D12A7D); }
.fw-auth__step.is-done .fw-auth__step-num {
	background: var(--fw-success, #198754);
	border-color: var(--fw-success, #198754);
	color: #fff;
}
.fw-auth__step.is-done .fw-auth__step-num::before {
	content: '\F26B'; /* bi-check */
	font-family: 'bootstrap-icons'; font-weight: 400; font-size: 13px;
}
.fw-auth__step.is-done .fw-auth__step-num { font-size: 0; }
.fw-auth__step.is-done + .fw-auth__step::before { background: var(--fw-success, #198754); }
.fw-auth__step.is-active + .fw-auth__step::before { background: linear-gradient(90deg, var(--fw-red, #E9348A), var(--fw-gray-200, #e8edf3)); }
@media (max-width: 520px) {
	.fw-auth__step-label { display: none; }
}


/* ── Screen show/hide + fade-up transition ── */
.fw-auth__screen[hidden] { display: none !important; }
.fw-auth__screen { animation: fw-auth-fadeup .42s cubic-bezier(.22,1,.36,1) both; }
@keyframes fw-auth-fadeup {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}


/* ── Helper text under inputs ── */
.fw-auth__helper {
	font-size: 12px;
	color: var(--fw-gray-500, #8a95a5);
	margin-top: 8px;
	line-height: 1.4;
}
.fw-auth__helper b { color: var(--fw-gray-700, #475467); font-weight: 600; }


/* ── Locked-identifier display block ── */
.fw-auth__locked {
	display: flex; align-items: center; gap: 12px;
	padding: 12px 14px;
	background: var(--fw-gray-50, #f8fafc);
	border: 1.5px solid var(--fw-gray-200, #e8edf3);
	border-radius: var(--fw-r-md, 12px);
	margin-bottom: 20px;
}
.fw-auth__locked > i {
	font-size: 22px;
	color: var(--fw-success, #198754);
	flex-shrink: 0;
}
.fw-auth__locked > div {
	flex: 1; min-width: 0;
	display: flex; flex-direction: column; gap: 2px;
}
.fw-auth__locked b {
	font-size: 11px; font-weight: 600;
	text-transform: uppercase; letter-spacing: .8px;
	color: var(--fw-gray-500, #8a95a5);
}
.fw-auth__locked span {
	font-size: 14px; font-weight: 600;
	color: var(--fw-gray-800, #2d3a4b);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fw-auth__locked-change {
	font-size: 12px; font-weight: 600;
	color: var(--fw-red, #E9348A);
	background: transparent; border: none; cursor: pointer;
	padding: 6px 10px; border-radius: 8px;
	transition: background .2s;
}
.fw-auth__locked-change:hover { background: var(--fw-red-subtle, rgba(233,52,138,.08)); }
.fw-auth__locked--verified {
	background: rgba(25,135,84,.06);
	border-color: rgba(25,135,84,.22);
}


/* ── Compact strength meter (no checklist) ── */
.fw-auth__strength {
	margin-top: 8px;
	display: flex; align-items: center; gap: 10px;
}
.fw-auth__strength-bars {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
	flex: 1; height: 4px;
}
.fw-auth__strength-bars::before,
.fw-auth__strength-bars::after,
.fw-auth__strength-bars > * { display: none; }
.fw-auth__strength-bars {
	background: linear-gradient(to right,
		var(--fw-gray-200, #e8edf3) 0%, var(--fw-gray-200, #e8edf3) 100%);
	border-radius: 999px;
	position: relative;
	overflow: hidden;
}
.fw-auth__strength-bars::before {
	content: ''; display: block;
	position: absolute; top: 0; left: 0; bottom: 0;
	width: 0%; background: var(--fw-gray-300, #d8e0ea);
	transition: width .35s ease, background .35s ease;
	border-radius: 999px;
}
.fw-auth__strength[data-level="1"] .fw-auth__strength-bars::before { width: 25%;  background: #EF4444; }
.fw-auth__strength[data-level="2"] .fw-auth__strength-bars::before { width: 50%;  background: #F59E0B; }
.fw-auth__strength[data-level="3"] .fw-auth__strength-bars::before { width: 75%;  background: #10B981; }
.fw-auth__strength[data-level="4"] .fw-auth__strength-bars::before { width: 100%; background: var(--fw-success, #198754); }
.fw-auth__strength-label {
	font-size: 11px; color: var(--fw-gray-500, #8a95a5);
	white-space: nowrap;
}
.fw-auth__strength-label b {
	color: var(--fw-gray-700, #475467); font-weight: 700;
	text-transform: capitalize;
}


/* ── Toast notifications ── */
.fw-toast-host {
	position: fixed; top: 18px; right: 18px;
	display: flex; flex-direction: column; gap: 8px;
	z-index: 1000; pointer-events: none;
}
.fw-toast {
	pointer-events: auto;
	display: flex; align-items: center; gap: 10px;
	min-width: 280px; max-width: 360px;
	padding: 12px 12px 12px 14px;
	background: #fff;
	border-radius: 12px;
	border: 1px solid var(--fw-gray-200, #e8edf3);
	box-shadow: 0 14px 28px -8px rgba(15,23,42,.16);
	font-size: 13px;
	transform: translateY(-12px) scale(.96);
	opacity: 0;
	transition: opacity .22s, transform .22s cubic-bezier(.22,1,.36,1);
}
.fw-toast.is-in { opacity: 1; transform: translateY(0) scale(1); }
.fw-toast.is-out { opacity: 0; transform: translateY(-8px) scale(.98); }
.fw-toast__ico { font-size: 18px; flex-shrink: 0; line-height: 1; }
.fw-toast__ico--spin { animation: fw-toast-spin 1s linear infinite; }
@keyframes fw-toast-spin { to { transform: rotate(360deg); } }
.fw-toast__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.fw-toast__body b { font-size: 13px; font-weight: 600; color: var(--fw-gray-800, #2d3a4b); }
.fw-toast__body span { font-size: 12px; color: var(--fw-gray-600, #667085); }
.fw-toast__close {
	flex-shrink: 0; width: 22px; height: 22px;
	border: none; background: transparent;
	color: var(--fw-gray-500, #8a95a5);
	border-radius: 6px; cursor: pointer; line-height: 1;
}
.fw-toast__close:hover { background: var(--fw-gray-100, #f1f5f9); color: var(--fw-gray-800, #2d3a4b); }
.fw-toast--success .fw-toast__ico { color: var(--fw-success, #198754); }
.fw-toast--error   .fw-toast__ico { color: var(--fw-error, #D12A4A); }
.fw-toast--info    .fw-toast__ico { color: var(--fw-red, #E9348A); }
.fw-toast--loading .fw-toast__ico { color: var(--fw-red, #E9348A); }
@media (max-width: 480px) {
	.fw-toast-host { top: 10px; left: 10px; right: 10px; }
	.fw-toast { min-width: 0; max-width: 100%; }
}


/* ── Success screen ── */
.fw-auth__screen--success {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 22px; padding: 24px 0;
}
.fw-auth__heading--center { text-align: center; }
.fw-auth__success-ring {
	width: 92px; height: 92px;
	display: flex; align-items: center; justify-content: center;
	border-radius: 50%;
	background: rgba(25,135,84,.08);
	color: var(--fw-success, #198754);
	animation: fw-auth-pop .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes fw-auth-pop {
	0%   { transform: scale(.5); opacity: 0; }
	60%  { transform: scale(1.08); opacity: 1; }
	100% { transform: scale(1); }
}
.fw-auth__success-circle {
	stroke-dasharray: 176;
	stroke-dashoffset: 176;
	animation: fw-auth-draw .55s ease-out .15s forwards;
}
.fw-auth__success-check {
	stroke-dasharray: 60;
	stroke-dashoffset: 60;
	animation: fw-auth-draw .35s ease-out .55s forwards;
}
@keyframes fw-auth-draw { to { stroke-dashoffset: 0; } }


/* ── Misc — split-button "or" divider already exists in the ff CSS;
      no override needed. */


/* ═════════════════════════════════════════════════════════════════════
   POLISH PASS — helper text · Start Over button · strength checklist
   styling that matches the FW brand (pink primary, blue secondary).
   ═════════════════════════════════════════════════════════════════════ */

/* ── Helper text — soft blue-tinted info pill, not a flat gray line ── */
.fw-auth__helper {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 10px;
	padding: 8px 12px;
	font-size: 12px;
	font-weight: 500;
	color: #1068B0;                              /* FW brand --bl-d */
	background: rgba(20,120,200,.07);            /* FW --bl-bg */
	border: 1px solid rgba(20,120,200,.16);
	border-radius: 10px;
	line-height: 1.45;
}
.fw-auth__helper::before {
	content: '\F431';                             /* bi-info-circle */
	font-family: 'bootstrap-icons';
	font-size: 14px;
	color: #1478C8;                               /* FW --bl */
	flex-shrink: 0;
	line-height: 1;
}
.fw-auth__helper b {
	font-weight: 700;
	color: #0F172A;
}


/* ── Strength checklist (4-rule, gg/ff pattern) ── */
.fw-auth__strength-list {
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px 14px;
}
.fw-auth__strength-item {
	display: flex;
	align-items: center;
	gap: 7px;
	font-size: 11.5px;
	color: var(--fw-gray-500, #8a95a5);
	transition: color .25s;
}
.fw-strength-dot {
	width: 14px; height: 14px;
	border-radius: 50%;
	background: var(--fw-gray-100, #f1f5f9);
	border: 1.5px solid var(--fw-gray-300, #d8e0ea);
	display: inline-flex; align-items: center; justify-content: center;
	flex-shrink: 0;
	transition: background .25s, border-color .25s, transform .25s;
}
.fw-strength-dot::before {
	content: ''; width: 5px; height: 5px;
	border-radius: 50%; background: var(--fw-gray-400, #aab4c2);
	transition: background .25s, transform .25s;
}
.fw-auth__strength-item.is-met { color: var(--fw-success, #198754); font-weight: 600; }
.fw-auth__strength-item.is-met .fw-strength-dot {
	background: var(--fw-success, #198754);
	border-color: var(--fw-success, #198754);
	transform: scale(1.08);
}
.fw-auth__strength-item.is-met .fw-strength-dot::before {
	content: '\F26B';                             /* bi-check */
	font-family: 'bootstrap-icons';
	font-size: 9px; color: #fff;
	font-weight: 700;
	width: auto; height: auto; background: transparent;
}
@media (max-width: 420px) {
	.fw-auth__strength-list { grid-template-columns: 1fr; }
}


/* ── Footer back/Start-Over button — premium blue ghost pill ── */
.fw-auth__foot {
	margin-top: 22px;
	text-align: center;
}
.fw-auth__foot .fw-auth__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 600;
	color: #1068B0;                               /* --bl-d */
	background: rgba(20,120,200,.06);
	border: 1.5px solid rgba(20,120,200,.18);
	border-radius: 100px;
	transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s;
	cursor: pointer;
	text-decoration: none !important;
}
.fw-auth__foot .fw-auth__link i {
	font-size: 12px;
	transition: transform .25s;
}
.fw-auth__foot .fw-auth__link:hover {
	background: #1478C8;                          /* --bl */
	color: #FFFFFF;
	border-color: #1478C8;
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(20,120,200,.30);
}
.fw-auth__foot .fw-auth__link:hover i:first-child {
	transform: translateX(-3px);
}


/* ═════════════════════════════════════════════════════════════════════
   ERROR SHAKE — when an input becomes invalid (.is-invalid), the input
   wrap shakes left-right once. JS re-triggers the animation by force-
   reflowing the element so the same error always plays the shake even
   if the class is already present.
   ═════════════════════════════════════════════════════════════════════ */
@keyframes fw-auth-shake {
	0%, 100% { transform: translateX(0); }
	15%      { transform: translateX(-6px); }
	30%      { transform: translateX(6px); }
	45%      { transform: translateX(-5px); }
	60%      { transform: translateX(5px); }
	75%      { transform: translateX(-3px); }
	90%      { transform: translateX(3px); }
}
.fw-auth__input.is-invalid,
.fw-auth__input-wrap.is-invalid,
.fw-auth__otp.is-invalid {
	animation: fw-auth-shake .48s cubic-bezier(.36, .07, .19, .97);
}


/* ═════════════════════════════════════════════════════════════════════
   COMPACT FORM — trim margins so the whole signup flow fits in ~700px
   of vertical space without needing the panel to scroll internally.
   Only adjusts on screens ≥ 540px (mobile still wraps comfortably).
   ═════════════════════════════════════════════════════════════════════ */
@media (min-width: 540px) {
	.fw-auth__steps { margin-bottom: 18px; }
	.fw-auth__step-num { width: 24px; height: 24px; font-size: 11px; }
	.fw-auth__heading { margin-bottom: 18px; }
	.fw-auth__title { font-size: 22px; }
	.fw-auth__subtitle { font-size: 13px; line-height: 1.45; }
	.fw-auth__field { margin-bottom: 12px; }
	.fw-auth__locked { margin-bottom: 14px; padding: 10px 12px; }
	.fw-auth__strength { margin-top: 6px; }
	.fw-auth__strength-list { margin-top: 6px; gap: 4px 12px; }
	.fw-auth__strength-item { font-size: 10.5px; }
	.fw-auth__strength-list .fw-strength-dot { width: 12px; height: 12px; }
	.fw-auth__btn { padding: 12px 18px; }
	.fw-auth__or { margin: 10px 0; }
	.fw-auth__foot { margin-top: 14px; }
	.fw-auth__legal { margin-top: 16px; font-size: 11.5px; }
}
