/* NicheAdvice Bridging Pro — Frontend CSS */
*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
/* ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com */
/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/
*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}
::before,
::after {
  --tw-content: '';
}
/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/
html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: Roboto, system-ui, sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}
/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/
body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}
/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/
hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}
/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}
/*
Remove the default font size and weight for headings.
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}
/*
Reset links to optimize for opt-in styling instead of opt-out.
*/
a {
  color: inherit;
  text-decoration: inherit;
}
/*
Add the correct font weight in Edge and Safari.
*/
b,
strong {
  font-weight: bolder;
}
/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}
/*
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}
/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/
table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}
/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}
/*
Remove the inheritance of text transform in Edge and Firefox.
*/
button,
select {
  text-transform: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/
button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}
/*
Use the modern Firefox focus style for all focusable elements.
*/
:-moz-focusring {
  outline: auto;
}
/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/
:-moz-ui-invalid {
  box-shadow: none;
}
/*
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}
/*
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/*
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}
/*
Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}
fieldset {
  margin: 0;
  padding: 0;
}
legend {
  padding: 0;
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}
/*
Prevent resizing textareas horizontally by default.
*/
textarea {
  resize: vertical;
}
/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/
input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
/*
Set the default cursor for buttons.
*/
button,
[role="button"] {
  cursor: pointer;
}
/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}
/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}
/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/
img,
video {
  max-width: 100%;
  height: auto;
}
/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   DEFENSIVE RESET — Magazine Pro / Genesis / WordPress core sitewide-CSS
   isolation, scoped to our React CTA component roots.
   Locked 2026-05-29 (Phase 1 of post-mortem plan). ~25 lines, ~500 bytes
   gzipped, zero render cost.
   ═══════════════════════════════════════════════════════════════════════════
   Targets the EXACT bleed surfaces we hit over the last two days
   (dl/dt/dd margins, figure margins, list defaults, button background bleed,
   font-family inheritance, heading margin). Component-specific rules cascade
   on top — this is only the floor. New bleed surface? Add it HERE, NOT
   another !important. */
.nabp-calc-cta dl, .nabp-calc-cta dt, .nabp-calc-cta dd,
.nabp-home-cta dl, .nabp-home-cta dt, .nabp-home-cta dd { margin: 0; padding: 0; }
.nabp-calc-cta figure, .nabp-home-cta figure { margin: 0; padding: 0; }
.nabp-calc-cta ul, .nabp-calc-cta ol,
.nabp-home-cta ul, .nabp-home-cta ol { list-style: none; padding: 0; margin: 0; }
.nabp-calc-cta button, .nabp-home-cta button { background-image: none; font-family: inherit; }
/* NOTE: NO reset for <a>. Component CSS sets link colors + underlines
   explicitly. Stripping text-decoration sitewide here causes axe WCAG
   1.4.1 (Use of Color) failure on consent + privacy links. */
.nabp-calc-cta input, .nabp-calc-cta select, .nabp-calc-cta textarea,
.nabp-home-cta input, .nabp-home-cta select, .nabp-home-cta textarea { font-family: inherit; }
.nabp-calc-cta h1, .nabp-calc-cta h2, .nabp-calc-cta h3, .nabp-calc-cta h4, .nabp-calc-cta h5, .nabp-calc-cta h6,
.nabp-home-cta h1, .nabp-home-cta h2, .nabp-home-cta h3, .nabp-home-cta h4, .nabp-home-cta h5, .nabp-home-cta h6 {
  margin: 0; font-family: 'Raleway', system-ui, sans-serif;
}
/* ═══════════════════════════════════════════════════════════════════════════ */

/* ── Design foundation tokens (portable to full-site rebuild) ─────────────── */
/* Source of truth: scripts/NICHEADVICE-DESIGN-FOUNDATION.md                  */
:root {
  /* Brand (non-negotiable) */
  --na-pink:       #d63194;
  --na-teal:       #008285;
  --na-dark:       #222222;
  --na-body:       #555555;
  --na-gray:       #888888;
  --na-border:     #eeeeee;
  --na-offwhite:   #f5f5f5;
  --na-white:      #ffffff;

  /* Semantic functional */
  --na-success:            #20b426;
  --na-danger:             #ed5565;
  --na-info:               #428bca;
  --na-warning-bg:         #fffbeb;
  --na-warning-border:     #fde68a;
  --na-warning-accent:     #f59e0b;
  --na-warning-text:       #92400e;
  --na-warning-text-deep:  #78350f;
  --na-google-star:        #fbbc05;

  /* Radius — 4 tiers only */
  --r-sm:   4px;
  --r-md:   6px;
  --r-lg:   12px;
  --r-pill: 99px;

  /* Shadows */
  --shadow-sm:    0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:    0 4px 20px rgba(34,34,34,0.06);
  --shadow-lg:    0 12px 40px rgba(34,34,34,0.08);
  --shadow-focus: 0 0 0 3px rgba(214,49,148,0.12);
  --shadow-pink:  0 4px 16px rgba(214,49,148,0.22);
  --shadow-teal:  0 6px 24px rgba(0,130,133,0.25);

  /* Motion */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in:     cubic-bezier(0.64, 0, 0.78, 0);
  --dur-micro:   150ms;
  --dur-short:   250ms;
  --dur-mid:     400ms;

  /* ── Legacy aliases — existing .nabp-* selectors continue to work ─────── */
  /* New code should reference --na-* directly. These aliases let the current */
  /* stylesheet compile without a mass rename during migration. */
  --nabp-magenta:    var(--na-pink);
  --nabp-magenta-hv: var(--na-teal);
  --nabp-magenta-lt: #fdf2f8;
  --nabp-teal:       var(--na-teal);
  --nabp-gray:       var(--na-gray);
  --nabp-dark:       var(--na-dark);
  --nabp-text:       var(--na-body);
  --nabp-border:     var(--na-border);
  --nabp-bg:         var(--na-offwhite);
  --nabp-white:      var(--na-white);
  --nabp-radius:     var(--r-sm);
  --nabp-radius-lg:  var(--r-md);
  --nabp-shadow:     var(--shadow-sm);
  --nabp-shadow-lg:  var(--shadow-md);
}

/* ── Motion primitives ─────────────────────────────────────────────────── */
@keyframes nabp-fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes nabp-fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Respect reduced-motion — mandatory per foundation */
@media (prefers-reduced-motion: reduce) {
  #nabp-calculator-root *,
  #nabp-calculator-root *::before,
  #nabp-calculator-root *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Focus-visible ring — applied globally inside calculator root */
#nabp-calculator-root button:focus-visible,
#nabp-calculator-root a:focus-visible,
#nabp-calculator-root input:focus-visible,
#nabp-calculator-root [tabindex]:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--r-sm);
}

/* ── Root ────────────────────────────────────────────────────────────────── */

#nabp-calculator-root {
  font-family: 'Roboto', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--na-body);
  box-sizing: border-box;
  background: var(--na-white);
  -webkit-font-smoothing: antialiased;
  /* width/position set by inline \3c style id="nabp-breakout"> in PHP shortcode */
}

#nabp-calculator-root h1,
#nabp-calculator-root h2,
#nabp-calculator-root h3,
#nabp-calculator-root h4,
#nabp-calculator-root .nabp-display,
#nabp-calculator-root .nabp-rate-num {
  font-family: 'Raleway', system-ui, sans-serif;
  color: var(--na-dark);
  letter-spacing: -0.01em;
}

#nabp-calculator-root *, #nabp-calculator-root *::before, #nabp-calculator-root *::after {
  box-sizing: inherit;
}

.nabp-root {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem 3rem;
}

@media (max-width: 640px) {
  .nabp-root { padding: 0 1rem 2rem; }
}

/* ── Hero — foundation pattern (typography-first, no imagery) ──────────── */
.nabp-hero {
  text-align: left;
  max-width: 1280px;           /* Aligned with calc-card + results section */
  margin: 0 auto;
  padding: 1.5rem 1rem 2rem;
  animation: nabp-fadeUp var(--dur-mid) var(--ease-out) both;
}

.nabp-hero__title {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: clamp(2.75rem, 5.5vw, 4.25rem);
  font-weight: 900;
  color: var(--na-dark);
  line-height: 1.04;
  letter-spacing: -0.03em;
  margin: 0 0 1rem;
  max-width: 820px;
}

.nabp-hero__accent { color: var(--na-pink); }

.nabp-hero__sub {
  font-size: 1.125rem;
  color: var(--na-body);
  max-width: 640px;
  line-height: 1.6;
  margin: 0;
  font-weight: 400;
}

@media (max-width: 640px) {
  .nabp-hero { padding: 2.5rem 1rem 1.5rem; }
  .nabp-hero__title { font-size: 2rem; }
}

/* ── Process steps row ───────────────────────────────────────────────────── */
.nabp-steps-row {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   1.25rem;
  /* Full width — no max-width cap */
  margin-bottom:         0.5rem;
  position:              relative;
}

/* Connector line between cards */
.nabp-steps-row::before {
  content:       '';
  position:      absolute;
  top:           30px;               /* aligns with centre of number circle */
  left:          calc(16.66% + 22px); /* starts after first num */
  right:         calc(16.66% + 22px); /* ends before last num */
  height:        2px;
  background:    linear-gradient(90deg, var(--nabp-magenta) 0%, var(--nabp-magenta-lt) 100%);
  pointer-events: none;
  z-index:       0;
}

.nabp-step {
  background:    var(--nabp-white);
  border:        1px solid var(--nabp-border);
  border-radius: var(--nabp-radius-lg);
  padding:       1.75rem 1.5rem;
  box-shadow:    var(--nabp-shadow-lg);
  position:      relative;
  z-index:       1;
  text-align:    center;
  transition:    box-shadow 0.18s, transform 0.18s;
}

.nabp-step:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,0.10);
  transform:  translateY(-2px);
}

.nabp-step__num {
  width:            44px;
  height:           44px;
  background:       var(--nabp-magenta);
  color:            #fff;
  border-radius:    50%;
  font-size:        1.0625rem;
  font-weight:      800;
  display:          flex;
  align-items:      center;
  justify-content:  center;
  margin:           0 auto 0.875rem;
  box-shadow:       0 4px 12px rgba(214,49,148,0.35);
}

.nabp-step__label {
  font-weight:   800;
  font-size:     1.125rem;
  color:         var(--nabp-text);
  margin-bottom: 0.375rem;
}

.nabp-step__desc {
  font-size:   0.875rem;
  color:       var(--nabp-gray);
  line-height: 1.6;
}

@media (max-width: 640px) {
  .nabp-steps-row { grid-template-columns: 1fr; }
  .nabp-steps-row::before { display: none; }
  .nabp-step { padding: 1.25rem 1rem; }
}

/* ── Calculator card — off-white panel (reference pattern) ──────────────── */
.nabp-calc-card {
  background: var(--na-offwhite);
  border: 1px solid var(--na-border);
  border-radius: var(--r-md);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  overflow: visible;
  margin: 0 auto 2.5rem;
  max-width: 1280px;           /* Aligned with hero + results section */
}

/* ── 3-column inputs grid ───────────────────────────────────────────────── */
.nabp-inputs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1.75rem 2.25rem;
  padding: 1.75rem 2rem;
  align-items: start;
}

@media (max-width: 1024px) {
  .nabp-inputs-grid { grid-template-columns: 1fr 1fr; padding: 1.5rem; }
}

@media (max-width: 700px) {
  .nabp-inputs-grid { grid-template-columns: 1fr; padding: 1.25rem; }
}

.nabp-inputs-col { display: flex; flex-direction: column; gap: 1.5rem; }

/* ── Section label (ALL CAPS small gray, reference pattern) ─────────────── */
.nabp-section-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 0.5rem;
  min-height: 20px;
}

.nabp-section-label__text {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--na-gray);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1.2;
  margin: 0;
}

.nabp-section-label__action { flex-shrink: 0; }

/* ── Field ──────────────────────────────────────────────────────────────── */
.nabp-field { display: flex; flex-direction: column; gap: 0.375rem; }

/* Legacy .nabp-field__label kept as alias for third-party selectors; primary labels use .nabp-section-label__text */
.nabp-field__label {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--na-gray);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin: 0 0 0.5rem;
}

.nabp-field__badge {
  background: var(--na-pink);
  color: #fff;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 3px;
  letter-spacing: 0.02em;
  text-transform: none;
}

.nabp-field__input-wrap { position: relative; }

.nabp-field__input {
  width: 100%;
  padding: 1rem 1.125rem;       /* Bumped from 0.875rem 1rem for Stitch parity */
  border: 1px solid var(--na-border);
  border-radius: var(--r-sm);
  font-size: 1.0625rem;         /* 17px — slightly larger than 16px */
  font-weight: 600;             /* Heavier weight for value-first feel */
  color: var(--na-dark);
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
  min-height: 52px;
  font-family: 'Roboto', system-ui, sans-serif;
  box-sizing: border-box;
}

.nabp-field__input::-moz-placeholder { color: #bbb; font-weight: 400; }

.nabp-field__input::placeholder { color: #bbb; font-weight: 400; }

.nabp-field__input:focus {
  border-color: var(--na-pink);
  box-shadow: 0 0 0 3px rgba(214, 49, 148, 0.12);
}

.nabp-field__hint {
  font-size: 0.75rem;
  color: var(--na-gray);
  margin: 0;
  font-family: 'Roboto', system-ui, sans-serif;
  line-height: 1.5;
}

.nabp-field-error {
  font-size: 0.8rem;
  color: #dc2626;
  margin: 0;
  font-weight: 500;
}

/* ── Select dropdown (matches input styling + chevron) ──────────────────── */
.nabp-select {
  width: 100%;
  padding: 0.875rem 2.75rem 0.875rem 1rem;
  border: 1px solid var(--na-border);
  border-radius: var(--r-sm);
  font-size: 1rem;
  font-weight: 500;
  color: var(--na-dark);
  background-color: #fff;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%23888%27 stroke-width=%272.5%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3E%3Cpath d=%27M6 9l6 6 6-6%27/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 12px 12px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
  min-height: 52px;
  font-family: 'Roboto', system-ui, sans-serif;
  box-sizing: border-box;
}

.nabp-select:focus {
  border-color: var(--na-pink);
  box-shadow: 0 0 0 3px rgba(214, 49, 148, 0.12);
}

/* ── Radios (Security charge type) ──────────────────────────────────────── */
.nabp-radios {
  display: flex;
  gap: 1.75rem;
  padding: 0.375rem 0;
  flex-wrap: wrap;
}

.nabp-radio {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9375rem;
  color: var(--na-dark);
  cursor: pointer;
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 500;
  line-height: 1.2;
}

.nabp-radio input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--na-pink);
  cursor: pointer;
  margin: 0;
}

/* ── Mini toggle (NET / GROSS sitting inline in the Loan Amount label) ─── */
.nabp-mini-toggle {
  display: inline-flex;
  background: var(--na-dark);
  border-radius: 3px;
  padding: 2px;
  gap: 0;
}

.nabp-mini-toggle__btn {
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  border: none;
  padding: 5px 13px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  border-radius: 2px;
  font-family: 'Roboto', system-ui, sans-serif;
  transition: background 0.15s, color 0.15s;
  line-height: 1;
}

.nabp-mini-toggle__btn:hover { color: #fff; }

.nabp-mini-toggle__btn--active {
  background: var(--na-pink);
  color: #fff;
}
.nabp-mini-toggle__btn--active:hover { color: #fff; }

/* ── Option card toggle (gross/net loan selector) ────────────────────────── */
.nabp-option-card {
  background: #f9fafb;
  border: 3px solid var(--nabp-border);
  border-radius: 10px;
  transition: all 0.15s ease;
  position: relative;
}
.nabp-option-card:hover {
  border-color: var(--nabp-magenta);
}
.nabp-option-selected,
.nabp-option-selected:hover {
  border-color: var(--nabp-magenta);
  background: var(--nabp-white);
}
.nabp-option-card .nabp-option-heading {
  display: block;
  background: var(--nabp-magenta);
  color: #fff;
  margin: -1rem -1.25rem 0.75rem;
  padding: 0.625rem 1.25rem;
  border-radius: 7px 7px 0 0;
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.02em;
}
.nabp-option-card:not(.nabp-option-selected) .nabp-option-heading {
  background: #9ca3af;
}
.nabp-option-selected::after {
  content: '\2713';
  position: absolute;
  top: 10px;
  right: 12px;
  width: 24px;
  height: 24px;
  background: #fff;
  color: var(--nabp-magenta);
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Estimated LTV bar — inline horizontal display (reference style) ────── */
.nabp-ltv-badge {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto;
  align-items: center;
  gap: 0.5rem 1rem;
  padding: 0.875rem 1rem;
  background: #e8e8e8;
  border: 1px solid var(--na-border);
  border-radius: var(--r-sm);
  min-height: 52px;
  transition: background 0.15s, border-color 0.15s;
}

.nabp-ltv-badge__label {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--na-gray);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1.2;
}

.nabp-ltv-badge__value {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 1.375rem;
  font-weight: 800;
  color: var(--na-dark);
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: baseline;
  gap: 0.4rem;
}

.nabp-ltv-badge__pct {
  font-size: 0.8em;
  font-weight: 700;
  opacity: 0.85;
  margin-left: 1px;
}

.nabp-ltv-badge__net {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.7rem;
  color: var(--na-gray);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  opacity: 0.9;
}

.nabp-ltv-badge__note {
  grid-column: 1 / -1;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.7rem;
  color: var(--na-gray);
  line-height: 1.45;
  font-weight: 500;
}

.nabp-ltv-badge--info {
  background: #fef3c7;
  border-color: #fcd34d;
}
.nabp-ltv-badge--info .nabp-ltv-badge__label,
.nabp-ltv-badge--info .nabp-ltv-badge__note { color: #78350f; }
.nabp-ltv-badge--info .nabp-ltv-badge__value { color: #78350f; }

.nabp-ltv-badge--warn {
  background: #fee2e2;
  border-color: #fca5a5;
}
.nabp-ltv-badge--warn .nabp-ltv-badge__label,
.nabp-ltv-badge--warn .nabp-ltv-badge__note { color: #991b1b; }
.nabp-ltv-badge--warn .nabp-ltv-badge__value { color: #991b1b; }

/* ── Slider ──────────────────────────────────────────────────────────────── */
.nabp-slider {
  width: 100%;
  accent-color: var(--nabp-magenta);
  height: 6px;
  cursor: pointer;
  border-radius: 3px;
}

.nabp-slider__labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--nabp-gray);
  margin-top: 4px;
}

/* ── Toggle group (interest type / charge type) ──────────────────────────── */
.nabp-toggle-group {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.nabp-toggle-btn {
  flex: 1;
  min-width: 80px;
  padding: 0.5rem 0.625rem;
  border: 1.5px solid var(--nabp-border);
  border-radius: var(--nabp-radius);
  background: var(--nabp-white);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--nabp-dark);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
}

.nabp-toggle-btn__sub {
  font-size: 0.7rem;
  font-weight: 400;
  color: var(--nabp-gray);
}

.nabp-toggle-btn:hover { border-color: var(--nabp-magenta); background: var(--nabp-magenta-lt); color: var(--nabp-dark); }

.nabp-toggle-btn--active {
  border-color: var(--nabp-magenta);
  background: var(--nabp-magenta);
  color: #fff;
}

.nabp-toggle-btn--active:hover {
  background: var(--nabp-magenta-hv);
  border-color: var(--nabp-magenta-hv);
  color: #fff;
}

.nabp-toggle-btn--active .nabp-toggle-btn__sub { color: rgba(255,255,255,0.8); }
.nabp-toggle-btn--active:hover .nabp-toggle-btn__sub { color: rgba(255,255,255,0.8); }

/* ── Add security property — subtle pink text link (reference pattern) ── */
.nabp-add-prop-link {
  background: none;
  border: none;
  color: var(--na-pink);
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  cursor: pointer;
  padding: 6px 0;
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: -moz-fit-content;
  width: fit-content;
}
.nabp-add-prop-link:hover { text-decoration: underline; }

.nabp-additional-prop {
  background: #fff;
  border: 1px solid var(--na-border);
  border-radius: var(--r-sm);
  padding: 0.875rem;
}

/* ── Compare Lenders CTA — full-width pink block at bottom of col 3 ────── */
.nabp-compare-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: auto;
}

.nabp-compare-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  padding: 1.125rem 1.5rem;
  background: var(--na-pink);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.9375rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: background 0.15s, transform 0.08s, box-shadow 0.15s;
  box-shadow: 0 2px 8px rgba(214, 49, 148, 0.2);
  min-height: 56px;
  width: 100%;
}

.nabp-compare-btn:hover {
  background: #b92980;
  box-shadow: 0 6px 18px rgba(214, 49, 148, 0.32);
  transform: translateY(-1px);
}
.nabp-compare-btn:active { transform: translateY(0); }
.nabp-compare-btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

.nabp-search-meta {
  font-size: 0.75rem;
  color: var(--na-gray);
  text-align: center;
  margin: 0;
  font-family: 'Roboto', system-ui, sans-serif;
}

/* ── Trust bar ───────────────────────────────────────────────────────────── */
.nabp-trust-bar {
  display:         flex;
  justify-content: center;
  align-items:     center;
  flex-wrap:       wrap;
  gap:             0;
  padding:         0.875rem 1.75rem 1.25rem;
  border-top:      1px solid var(--nabp-border);
}

.nabp-trust-item {
  display:     flex;
  align-items: center;
  gap:         0.4rem;
  font-size:   0.8125rem;
  font-weight: 600;
  color:       var(--nabp-dark);
  padding:     0.375rem 1.25rem;
  border-right: 1px solid var(--nabp-border);
}

.nabp-trust-item:last-child { border-right: none; }

.nabp-trust-icon {
  font-size:  0.875rem;
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .nabp-trust-item { border-right: none; padding: 0.375rem 0.75rem; }
}

.nabp-btn-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: nabp-spin 0.7s linear infinite;
}

/* ── Error banner ────────────────────────────────────────────────────────── */
.nabp-error-banner {
  margin: 0 1.75rem 1.75rem;
  padding: 0.875rem 1rem;
  background: #fff5f5;
  border: 1px solid #fecaca;
  border-radius: var(--nabp-radius);
  color: #dc2626;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
}

/* ── Results section ─────────────────────────────────────────────────────── */
.nabp-results-section {
  margin-top: 1rem;
  max-width: 1280px;           /* Aligned with calc-card + hero */
  margin-left: auto;
  margin-right: auto;
}

/* ── FCA near-claim compliance strip (above rate cards) ───────────────────
   Design intent (2026-04-21): keep the regulated/unregulated context visible
   because it affects statutory protections, but collapse methodology + rep
   example behind an "About these rates" disclosure link — same pattern as
   MoneySuperMarket / Compare the Market. FCA-accepted practice.
   Do not re-expand the details by default without compliance review. */
.nabp-compliance {
  margin: 0 0 16px;
  font-size: 13px;
  line-height: 1.55;
  color: #3a3a3a;
}

/* Always-visible regulated / unregulated chip — stays on one line on desktop.
   Uses padding-left for the dot offset instead of flex so wrap behaviour is
   predictable and the sentence reads as a single line. */
.nabp-compliance__chip {
  position: relative;
  margin: 0 0 10px;
  padding: 8px 14px 8px 28px;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.5;
  white-space: normal;
}
.nabp-compliance__chip strong { font-weight: 700; }
.nabp-compliance__chip-dot {
  position: absolute;
  left: 12px;
  top: 14px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.nabp-compliance__chip-text { display: inline; }
.nabp-compliance__chip.is-regulated {
  background: #eaf6ec;
  color: #1b5e20;
}
.nabp-compliance__chip.is-regulated .nabp-compliance__chip-dot { background: #2e7d32; }
.nabp-compliance__chip.is-unregulated {
  background: #fff4e5;
  color: #5d3600;
}
.nabp-compliance__chip.is-unregulated .nabp-compliance__chip-dot { background: #c97a00; }

/* Disclosure (collapsed methodology + representative example). */
.nabp-compliance__details {
  background: transparent;
  border-top: 1px solid #e3e2e0;
  padding: 8px 0 0;
}
.nabp-compliance__details > summary {
  list-style: none;
  cursor: pointer;
  padding: 4px 0;
  font-size: 12.5px;
  font-weight: 600;
  color: #555;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.nabp-compliance__details > summary::-webkit-details-marker { display: none; }
.nabp-compliance__details > summary::after {
  content: '›';
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  transform: rotate(90deg);
  transition: transform 0.2s ease;
  color: #d63194;
  font-weight: 700;
}
.nabp-compliance__details[open] > summary::after { transform: rotate(-90deg); }
.nabp-compliance__details > summary:hover { color: #d63194; }

.nabp-compliance__details-body {
  padding: 10px 0 4px;
  font-size: 12.5px;
  line-height: 1.6;
  color: #555;
}
.nabp-compliance__details-body > p { margin: 0 0 12px; }
.nabp-compliance__details-body strong { color: #1a1c1a; }

.nabp-compliance__rep-example {
  background: #faf9f6;
  border: 1px solid #e3e2e0;
  border-radius: 6px;
  padding: 10px 12px;
  margin-top: 4px;
}
.nabp-compliance__rep-example h4 {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #d63194;
}
.nabp-compliance__rep-example p {
  margin: 0;
  font-size: 12.5px;
  line-height: 1.55;
  color: #444;
}
.nabp-compliance__rep-example strong { color: #1a1c1a; }

@media (max-width: 640px) {
  .nabp-compliance__chip { font-size: 12px; padding: 8px 12px; }
  .nabp-compliance__rep-example { padding: 10px 12px; }
}

/* ── Sort bar ────────────────────────────────────────────────────────────── */
.nabp-sort-bar {
  display: block;
  margin-bottom: 1rem;
  padding: 0.75rem 1rem;
  background: var(--nabp-white);
  border: 1px solid var(--nabp-border);
  border-radius: var(--nabp-radius);
}

.nabp-sort-bar__explainer {
  margin: 0 0 0.5rem 0;
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--nabp-gray, #555);
}

.nabp-sort-bar__explainer strong {
  color: var(--nabp-dark);
  font-weight: 600;
}

.nabp-sort-bar__label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--nabp-dark);
  margin-right: 0.25rem;
}

.nabp-sort-btn {
  padding: 0.375rem 0.875rem;
  border: 1.5px solid var(--nabp-border);
  border-radius: var(--nabp-radius);
  background: var(--nabp-white);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--nabp-dark);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.nabp-sort-btn:hover { border-color: var(--nabp-magenta); color: var(--nabp-magenta); }

.nabp-sort-btn--active,
.nabp-sort-btn--active:hover,
.nabp-sort-btn--active:focus,
.nabp-sort-btn--active:active {
  background: var(--nabp-magenta);
  border-color: var(--nabp-magenta);
  color: #fff !important;
}

@keyframes nabpFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Desktop result rows ─────────────────────────────────────────────────── */
.nabp-results-desktop { display: none; }
.nabp-results-mobile  { display: block; }

@media (min-width: 960px) {
  .nabp-results-desktop { display: block; }
  .nabp-results-mobile  { display: none; }
}

/* ── Results header (count + params line) ─────────────────────────────── */
.nabp-results-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}

.nabp-results-header__count {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--na-dark);
  margin: 0 0 0.25rem;
  letter-spacing: -0.01em;
}

.nabp-results-header__sub {
  margin: 0;
  font-size: 0.875rem;
  color: var(--na-gray);
}

/* ── 3-zone rate card (giant rate | lender+figures | chunky pink CTA) ───── */
.nabp-rate-card {
  display: grid;
  grid-template-columns: 248px 1fr 220px;
  align-items: stretch;
  gap: 2rem;
  padding: 1.75rem 2rem;
  position: relative;
  background: transparent;
}

.nabp-rate-card__badge {
  position: absolute;
  top: 0;
  left: 0;
  background: var(--na-pink);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 4px 14px 4px 16px;
  border-radius: var(--r-md) 0 var(--r-md) 0;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1;
  font-family: 'Roboto', system-ui, sans-serif;
}

/* Zone 1 — Rate figure */
.nabp-rate-card__rate {
  border-right: 1px solid var(--na-border);
  padding-right: 2rem;
  min-width: 0;
  align-self: center;
}

.nabp-rate-card__rate-figure {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: clamp(2.75rem, 2.5vw + 1.5rem, 3.75rem);
  font-weight: 900;
  line-height: 0.9;
  color: var(--na-pink);
  letter-spacing: -0.03em;
  display: inline-flex;
  align-items: flex-start;
}

.nabp-rate-card__rate-figure span {
  font-size: 0.45em;
  font-weight: 700;
  margin-top: 0.45em;
  margin-left: 2px;
  opacity: 0.9;
}

.nabp-rate-card__rate-label {
  font-size: 0.7rem;
  color: var(--na-gray);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  margin-top: 0.5rem;
  font-family: 'Roboto', system-ui, sans-serif;
}

.nabp-rate-card__rate-meta {
  font-size: 0.75rem;
  color: var(--na-gray);
  margin-top: 0.375rem;
  line-height: 1.5;
}

/* Zone 2 — Body (lender + figures) */
.nabp-rate-card__body {
  min-width: 0;
  align-self: center;
}

.nabp-rate-card__header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.nabp-rate-card__lender {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--na-dark);
  margin: 0;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.nabp-rate-card__tag {
  display: inline-block;
  background: #fdf2f8;
  color: #be185d;
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 3px;
  border: 1px solid #fbcfe8;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-family: 'Roboto', system-ui, sans-serif;
}

/* ── Lender feature badges (Online Valuation, Dual Legal Rep) ───────────── */
.nabp-rate-card__features {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  margin-top: 0.75rem;
  padding-top: 0.625rem;
  border-top: 1px solid var(--na-border);
}

.nabp-feature-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--na-teal);
  background: #f0fafa;
  border: 1px solid #b2e0e0;
  border-radius: 3px;
  padding: 3px 8px;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.nabp-rate-card__figures {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem 1.5rem;
  margin: 0;
}

.nabp-rate-card__figure {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.nabp-rate-card__figure dt {
  font-size: 0.7rem;
  color: var(--na-gray);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  margin: 0 0 3px;
  font-family: 'Roboto', system-ui, sans-serif;
}

.nabp-rate-card__figure dd {
  font-size: 1rem;
  font-weight: 700;
  color: var(--na-dark);
  margin: 0;
  line-height: 1.2;
  font-family: 'Raleway', system-ui, sans-serif;
}

.nabp-rate-card__figure--cost dd {
  color: var(--na-pink);
  font-size: 1.0625rem;
}

.nabp-rate-card__figure-sub {
  display: block;
  font-size: 0.6875rem;
  color: var(--na-gray);
  font-weight: 400;
  font-family: 'Roboto', system-ui, sans-serif;
  margin-top: 2px;
  letter-spacing: 0;
}

/* Zone 3 — Chunky full-height pink CTA (Equity & Rose style but brand pink) */
.nabp-rate-card__cta {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: stretch;
  justify-content: center;
}

.nabp-rate-card__btn {
  background: var(--na-pink);
  color: #fff;
  border: none;
  padding: 1.125rem 1.5rem;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 1.0625rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--r-sm);
  width: 100%;
  min-height: 64px;
  transition: background 0.15s, transform 0.08s, box-shadow 0.15s;
  box-shadow: 0 2px 8px rgba(214, 49, 148, 0.15);
}

.nabp-rate-card__btn:hover {
  background: #b92980;
  box-shadow: 0 6px 18px rgba(214, 49, 148, 0.28);
  transform: translateY(-1px);
}

.nabp-rate-card__btn:active { transform: translateY(0); }

.nabp-rate-card__toggle {
  background: none;
  border: none;
  color: var(--na-pink);
  font-weight: 600;
  font-size: 0.8125rem;
  cursor: pointer;
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  border-radius: var(--r-sm);
  transition: background 0.15s;
  font-family: inherit;
}

.nabp-rate-card__toggle:hover { background: #fce7f3; color: #8a1a5a; }

.nabp-rate-card__toggle svg {
  fill: currentColor;
  transition: transform 0.2s;
}

.nabp-rate-card__toggle[aria-expanded="true"] svg { transform: rotate(180deg); }

/* Result row reveal animation — staggered fadeUp per foundation */
.nabp-result-row-wrap { animation: nabp-fadeUp var(--dur-mid) var(--ease-out) both; }
.nabp-result-row-wrap:nth-child(2) { animation-delay: 40ms; }
.nabp-result-row-wrap:nth-child(3) { animation-delay: 80ms; }
.nabp-result-row-wrap:nth-child(4) { animation-delay: 120ms; }
.nabp-result-row-wrap:nth-child(5) { animation-delay: 160ms; }
.nabp-result-row-wrap:nth-child(n+6) { animation-delay: 200ms; }

/* Responsive — narrower desktop: stack CTA below, 2-col figures */
@media (max-width: 1100px) {
  .nabp-rate-card {
    grid-template-columns: 220px 1fr;
    gap: 1.5rem;
    padding: 1.5rem;
  }
  .nabp-rate-card__cta {
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: flex-end;
    gap: 0.75rem;
    padding-top: 1rem;
    border-top: 1px solid var(--na-border);
  }
  .nabp-rate-card__btn { max-width: 320px; min-height: 56px; }
  .nabp-rate-card__figures {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.875rem 1.25rem;
  }
}

/* ── Mobile cards (existing style) ──────────────────────────────────────── */
.nabp-results-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.nabp-lender-card {
  background: var(--nabp-white);
  border: 1px solid var(--nabp-border);
  border-radius: var(--nabp-radius-lg);
  padding: 1.25rem;
  box-shadow: var(--nabp-shadow);
  transition: box-shadow 0.15s, transform 0.15s;
  position: relative;
  overflow: hidden;
}

.nabp-lender-card:hover {
  box-shadow: 0 4px 20px rgba(214,49,148,0.10);
  transform: translateY(-2px);
}

.nabp-lender-card.nabp-card-top { border-top: 3px solid var(--nabp-magenta); }

.nabp-best-badge {
  position: absolute;
  top: 0; right: 0;
  background: var(--nabp-magenta);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 0 var(--nabp-radius) 0 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.nabp-lender-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--nabp-dark);
  margin-bottom: 0.25rem;
}

.nabp-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.375rem 0;
  border-bottom: 1px solid #f3f4f6;
  font-size: 0.875rem;
}

.nabp-row:last-of-type { border-bottom: none; }
.nabp-row-label { color: var(--nabp-gray); }
.nabp-row-value { font-weight: 600; color: var(--nabp-text); }
.nabp-row-value.nabp-highlight { color: var(--nabp-magenta); font-size: 1rem; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.nabp-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--nabp-magenta);
  color: #fff;
  border: none;
  border-radius: var(--nabp-radius);
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
  width: 100%;
}

.nabp-btn-primary:hover { background: var(--nabp-magenta-hv); }
.nabp-btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }

.nabp-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  background: transparent;
  color: var(--nabp-dark);
  border: 1.5px solid var(--nabp-border);
  border-radius: var(--nabp-radius);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.nabp-btn-secondary:hover { border-color: var(--nabp-gray); background: var(--nabp-bg); }

/* ── Lead form wrapper ───────────────────────────────────────────────────── */
.nabp-lead-wrap {
  margin-top: 2rem;
  background:    #f0f2f5;
  border-radius: var(--nabp-radius-lg);
  padding:       2rem;
}

.nabp-lead-form {
  background:    var(--nabp-white);
  border:        1px solid #d1d5db;
  border-radius: var(--nabp-radius-lg);
  padding:       2rem;
  box-shadow:    0 8px 32px rgba(0,0,0,0.10), 0 2px 8px rgba(0,0,0,0.06);
}

/* 2-column grid inside the form on desktop */
.nabp-lead-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 1.25rem;
}

@media (max-width: 720px) {
  .nabp-lead-form__grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.nabp-lead-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--nabp-text);
  margin-bottom: 0.25rem;
}

.nabp-lead-sub {
  font-size: 0.875rem;
  color: var(--nabp-gray);
  margin-bottom: 1.25rem;
  line-height: 1.5;
}

.nabp-form-group { margin-bottom: 0.875rem; }
.nabp-label { display: block; font-size: 0.875rem; font-weight: 600; color: var(--nabp-dark); margin-bottom: 0.375rem; }

/* Mobile: bigger field labels so they don't get lost vs the bold
   input values (per user 2026-04-30). Targets BOTH label classes
   in use across the calculator:
     - .nabp-section-label__text  (primary, used by App.jsx for "Loan
       amount", "Property value", "Works planned" etc.) — was 10px
       uppercase tracked, near-illegible on phones.
     - .nabp-field__label  (legacy alias)
     - .nabp-label  (used by step components like StepLoanDetails)
   Bump uppercase tracked labels from 0.625rem (10px) to 0.8125rem
   (13px) — enough to read while keeping the all-caps eyebrow style.
   Bump the title-case .nabp-label from 0.875rem (14px) to 1.0625rem
   (17px) bold for the step components that don't use uppercase. */
@media (max-width: 640px) {
  .nabp-section-label__text,
  .nabp-field__label {
    font-size: 0.8125rem;
    letter-spacing: 0.08em;
  }
  .nabp-label { font-size: 1.0625rem; font-weight: 700; }
  .nabp-error-msg { font-size: 0.8125rem; }
}

.nabp-input {
  display: block;
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--nabp-border);
  border-radius: var(--nabp-radius);
  font-size: 1rem;
  color: var(--nabp-text);
  background: var(--nabp-white);
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}

.nabp-input:focus {
  border-color: var(--nabp-magenta);
  box-shadow: 0 0 0 3px rgba(214,49,148,0.10);
}

.nabp-input.nabp-input-error { border-color: #ef4444; }
.nabp-error-msg { color: #ef4444; font-size: 0.8rem; margin-top: 0.25rem; }

.nabp-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-bottom: 0.875rem;
}

@media (max-width: 480px) { .nabp-form-row { grid-template-columns: 1fr; } }

.nabp-checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0.875rem 0;
}

.nabp-checkbox-group input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 1px;
  accent-color: var(--nabp-magenta);
  cursor: pointer;
}

/* ── Success banner ──────────────────────────────────────────────────────── */
.nabp-success-banner {
  padding: 1.25rem;
  background: #f0fdf4;
  border: 1px solid #86efac;
  border-radius: var(--nabp-radius);
  color: #166534;
  font-weight: 600;
  text-align: center;
  margin-top: 1.5rem;
}

/* ── Disclaimer ──────────────────────────────────────────────────────────── */
.nabp-disclaimer {
  margin-top:     1.5rem;
  padding:        1.25rem 1.5rem;
  background:     var(--na-warning-bg);
  border:         1px solid var(--na-warning-border);
  border-left:    4px solid var(--na-warning-accent);
  border-radius:  var(--r-md);
}
.nabp-disclaimer__header {
  display:        flex;
  align-items:    center;
  gap:            0.5rem;
  font-size:      0.9375rem;
  font-weight:    700;
  color:          var(--na-warning-text);
  margin-bottom:  0.625rem;
  font-family:    'Raleway', system-ui, sans-serif;
}
.nabp-disclaimer__icon { width: 18px; height: 18px; fill: var(--na-warning-accent); }
.nabp-disclaimer__body {
  font-size:      0.8125rem;
  color:          var(--na-warning-text-deep);
  line-height:    1.7;
}

/* ── Case Studies ────────────────────────────────────────────────────────── */
.nabp-case-section {
  margin-top: 3rem;
  padding: 0;
}

.nabp-case-header {
  text-align: center;
  margin-bottom: 2rem;
}

.nabp-case-title {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--nabp-dark);
  margin-bottom: 0.375rem;
}

.nabp-case-subtitle {
  font-size: 1rem;
  color: var(--na-body);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.55;
}

.nabp-case-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

@media (max-width: 860px) {
  .nabp-case-grid { grid-template-columns: 1fr; }
}

.nabp-case-card {
  background:    var(--nabp-white);
  border:        1px solid var(--nabp-border);
  border-radius: var(--nabp-radius-lg);
  padding:       1.5rem;
  box-shadow:    var(--nabp-shadow);
  display:       flex;
  flex-direction: column;
  gap:           1rem;
  border-top:    3px solid var(--nabp-magenta);
}

.nabp-case-card__top {
  display:     flex;
  align-items: center;
  gap:         0.625rem;
  flex-wrap:   wrap;
}

.nabp-case-tag {
  background:    var(--nabp-magenta-lt);
  color:         var(--nabp-magenta);
  font-size:     0.7rem;
  font-weight:   700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding:       0.2rem 0.5rem;
  border-radius: 3px;
}

.nabp-case-scenario {
  font-size:   0.875rem;
  font-weight: 700;
  color:       var(--nabp-dark);
}

.nabp-case-quote {
  font-size:   0.9375rem;
  color:       #374151;
  line-height: 1.65;
  font-style:  italic;
  flex:        1;
  margin:      0;
}

.nabp-case-card__foot {
  display:     flex;
  align-items: center;
  gap:         0.75rem;
  padding-top: 0.875rem;
  border-top:  1px solid var(--nabp-border);
}

.nabp-case-avatar {
  width:         40px;
  height:        40px;
  border-radius: 50%;
  background:    var(--nabp-magenta);
  color:         #fff;
  font-size:     0.875rem;
  font-weight:   700;
  display:       flex;
  align-items:   center;
  justify-content: center;
  flex-shrink:   0;
}

.nabp-case-name {
  font-size:   0.8125rem;
  font-weight: 600;
  color:       var(--nabp-dark);
  margin-bottom: 1px;
}

.nabp-case-details {
  font-size: 0.75rem;
  color:     var(--nabp-gray);
}

/* ── Live Reviews Widget ─────────────────────────────────────────────────── */
.nabp-reviews-section {
  margin-top: 3rem;
}

.nabp-reviews-header {
  text-align:    center;
  margin-bottom: 2rem;
}

.nabp-reviews-title {
  font-size:     1.75rem;
  font-weight:   800;
  color:         var(--nabp-dark);
  margin-bottom: 0.375rem;
}

.nabp-reviews-subtitle {
  font-size: 1rem;
  color:     var(--na-body);
  max-width: 520px;
  margin:    0 auto;
  line-height: 1.55;
}

.nabp-reviews-widget-wrap {
  /* Let the Revue widget control its own width and layout.
     We just ensure it sits flush within our container. */
  width: 100%;
  min-height: 260px; /* Reserve space while the widget loads */
}

/* Slight override so the widget feels at home in the page */
.nabp-reviews-widget-wrap * {
  font-family: Inter, system-ui, -apple-system, sans-serif !important;
}

/* ── Knowledge Hub ───────────────────────────────────────────────────────── */
.nabp-hub-section {
  margin-top: 3rem;
}

.nabp-hub-header {
  text-align:    center;
  margin-bottom: 2rem;
}

.nabp-hub-title {
  font-size:   1.75rem;
  font-weight: 800;
  color:       var(--nabp-dark);
  margin-bottom: 0.375rem;
}

.nabp-hub-subtitle {
  font-size: 1rem;
  color:     var(--na-body);
  max-width: 520px;
  margin:    0 auto;
  line-height: 1.55;
}

.nabp-hub-grid {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  gap:                   1rem;
}

@media (max-width: 1024px) {
  .nabp-hub-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 540px) {
  .nabp-hub-grid { grid-template-columns: 1fr; }
}

.nabp-hub-card {
  display:        flex;
  flex-direction: column;
  gap:            0.625rem;
  background:     var(--nabp-white);
  border:         1px solid var(--nabp-border);
  border-radius:  var(--nabp-radius-lg);
  padding:        1.375rem 1.25rem;
  box-shadow:     var(--nabp-shadow);
  text-decoration: none;
  transition:     box-shadow 0.18s, border-color 0.18s, transform 0.18s;
}

.nabp-hub-card:hover {
  box-shadow:    var(--nabp-shadow-lg);
  border-color:  var(--nabp-magenta);
  transform:     translateY(-2px);
  text-decoration: none;
}

.nabp-hub-tag {
  font-size:      0.7rem;
  font-weight:    700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color:          var(--nabp-magenta);
}

.nabp-hub-card-title {
  font-size:   0.9375rem;
  font-weight: 700;
  color:       var(--nabp-dark);
  line-height: 1.4;
}

.nabp-hub-card-desc {
  font-size:   0.8125rem;
  color:       var(--nabp-gray);
  line-height: 1.6;
  flex:        1;
}

.nabp-hub-arrow {
  font-size:   0.8125rem;
  font-weight: 700;
  color:       var(--nabp-magenta);
  margin-top:  auto;
}

/* ── FAQ ─ foundation-aligned: light canvas, dark text, readable ─────────── */
.nabp-faq-section {
  margin-top:    3rem;
  background:    var(--na-offwhite);
  border:        1px solid var(--na-border);
  border-radius: var(--r-lg);
  padding:       3.5rem 3rem;
  box-shadow:    var(--shadow-sm);
}

.nabp-faq-title {
  font-family:    'Raleway', system-ui, sans-serif;
  font-size:      2rem;
  font-weight:    900;
  color:          var(--na-dark);
  margin-bottom:  0.5rem;
  text-align:     center;
  letter-spacing: -0.02em;
}

.nabp-faq-subtitle {
  font-size:     1rem;
  color:         var(--na-body);
  text-align:    center;
  margin-bottom: 2.5rem;
}

.nabp-faq-list { max-width: 100%; }

.nabp-faq-item {
  border-bottom: 1px solid var(--na-border);
  border-radius: var(--r-sm);
  overflow:      hidden;
  margin-bottom: 0.25rem;
  transition:    background 0.2s;
}

.nabp-faq-item:last-child { border-bottom: none; }

.nabp-faq-q {
  width:           100%;
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  gap:             1.5rem;
  padding:         1.25rem 1.5rem;
  background:      #ebebeb;
  border:          none;
  outline:         none;
  font-family:     'Raleway', system-ui, sans-serif;
  font-size:       1.0625rem;
  font-weight:     700;
  color:           var(--na-dark);
  cursor:          pointer;
  text-align:      left;
  transition:      background 0.2s, color 0.2s;
  line-height:     1.4;
}

.nabp-faq-q:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

.nabp-faq-q:hover {
  background: #e0e0e0;
  color:      var(--na-pink);
}

.nabp-faq-icon {
  font-size:   1.5rem;
  color:       var(--na-gray);
  flex-shrink: 0;
  transition:  transform 0.25s, color 0.2s;
  display:     inline-block;
  line-height: 1;
}

.nabp-faq-icon--open {
  transform: rotate(90deg);
  color:     var(--na-pink);
}

.nabp-faq-a {
  padding:     0 1.5rem 1.375rem;
  font-size:   0.9375rem;
  color:       var(--na-body);
  line-height: 1.8;
  background:  transparent;
}

@media (max-width: 640px) {
  .nabp-faq-section { padding: 2.5rem 1.25rem; }
  .nabp-faq-title   { font-size: 1.5rem; }
  .nabp-faq-q       { font-size: 0.9375rem; padding: 1.125rem 1rem; }
  .nabp-faq-a       { padding: 0 1rem 1.125rem; }
}

/* ── Spinner ─────────────────────────────────────────────────────────────── */
@keyframes nabp-spin { to { transform: rotate(360deg); } }

/* ── Expandable row wrapper — visual container for rate card + detail panel ── */
.nabp-result-row-wrap {
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 0.75rem;
  border: 1px solid var(--na-border);
  background: var(--nabp-white);
  box-shadow: var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, 0.05));
  transition: box-shadow 0.2s, transform 0.1s, border-color 0.2s;
}

.nabp-result-row-wrap:hover {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  transform: translateY(-1px);
}

.nabp-result-row-wrap--top {
  border: 2px solid var(--na-pink);
  box-shadow: 0 2px 14px rgba(214, 49, 148, 0.13);
}

.nabp-result-row-wrap--top:hover {
  box-shadow: 0 6px 22px rgba(214, 49, 148, 0.18);
}

.nabp-result-row-wrap--open {
  box-shadow: 0 4px 20px rgba(214, 49, 148, 0.1);
  border-color: #e8a0c8;
}

/* ── 2nd charge note ─────────────────────────────────────────────────────── */
.nabp-field-error {
  color: #dc2626;
  font-size: 0.8125rem;
  margin-top: 2px;
  margin-bottom: 0.25rem;
}

/* ── Calculator → Zoho CTA form (nabp-calc-cta__*) ────────────────────────────
   7-step lean carousel + .na-cta2-style hero panel + picked-lender banner.
   Scoped to .nabp-calc-cta namespace — ZERO selectors target .na-cta2*
   (that is a LOCKED sitewide component, see CLAUDE.md). Used on
   /bridging-loan-calculator/ (calculator tree) AND on every other
   bridging-vertical page (standalone mount via #nabp-bridging-cta-mount). */

.nabp-calc-cta {
  --nabp-cta-pink:     #d63194;
  --nabp-cta-pink-dk:  #b91f7a;
  --nabp-cta-pink-bg:  rgba(214, 49, 148, 0.06);
  --nabp-cta-teal:     #008285;
  --nabp-cta-dark:     #222222;
  --nabp-cta-body:     #555555;
  --nabp-cta-gray:     #888888;
  --nabp-cta-line:     #eeeeee;
  --nabp-cta-card-bg:  #ececec;             /* 2026-05-29 — was #ffffff (white-on-white made
                                                option cards invisible). Now matches the homepage
                                                CTA prototype-v4 LOCKED palette: #ececec carousel
                                                shell, #ffffff option buttons. White cards pop. */
  --nabp-cta-hero-bg:  #e9e8e5;             /* canonical .na-cta2__card warm gray — hero panel */
  --nabp-cta-bg:       #fafafa;
  --nabp-cta-surface:  #ffffff;
  --nabp-cta-radius:   12px;
  --nabp-cta-radius-i: 8px;
  --nabp-cta-shadow:   0 24px 60px rgba(0, 0, 0, 0.12);  /* canonical .na-cta2__card */
  --nabp-cta-gutter:   20px;

  position:      relative;
  background:    var(--nabp-cta-card-bg); /* warm gray, matches homepage .na-cta2__card */
  border-radius: var(--nabp-cta-radius);
  box-shadow:    var(--nabp-cta-shadow);
  margin:        2rem auto 0;
  width:         100%;
  max-width:     none;
  font-family:   'Roboto', system-ui, sans-serif;
  color:         var(--nabp-cta-dark);
  overflow:      hidden;
}
@media (min-width: 640px) { .nabp-calc-cta { --nabp-cta-gutter: 28px; } }

.nabp-calc-cta__sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ══════════════ HERO PANEL — pinned across all steps ══════════════ */
.nabp-calc-cta__hero {
  display:        grid;
  grid-template-columns: 1fr;
  gap:            24px;
  padding:        14px var(--nabp-cta-gutter);   /* reduced 28 → 14 (-50%) */
  background:     var(--nabp-cta-hero-bg);        /* canonical .na-cta2 warm gray */
  border-bottom:  1px solid rgba(141, 111, 125, 0.18); /* matches .na-cta2__hero divider */
}
@media (min-width: 720px) {
  .nabp-calc-cta__hero {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap:                   28px;
    padding:               16px var(--nabp-cta-gutter);  /* reduced 32 → 16 (-50%) */
    align-items:           center;
  }
}

.nabp-calc-cta__hero-text { min-width: 0; }

.nabp-calc-cta__hero-headline {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size:   26px;
  line-height: 1.1;
  color:       var(--nabp-cta-dark);
  margin:      0 0 10px;
}
@media (min-width: 720px) { .nabp-calc-cta__hero-headline { font-size: 32px; } }
.nabp-calc-cta__hero-accent { color: var(--nabp-cta-pink); }

.nabp-calc-cta__hero-lede {
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 400;
  font-size:   14px;
  line-height: 1.5;
  color:       var(--nabp-cta-body);
  margin:      0 0 14px;
}
@media (min-width: 720px) { .nabp-calc-cta__hero-lede { font-size: 15px; } }

.nabp-calc-cta__hero-bullets {
  list-style: none;
  padding:    0;
  margin:     0 0 14px;
  display:    flex;
  flex-direction: column;
  gap:        10px;
}
.nabp-calc-cta__hero-bullets li {
  display:     flex;
  align-items: flex-start;
  gap:         10px;
  font-size:   13.5px;
  line-height: 1.45;
  color:       var(--nabp-cta-body);
}
.nabp-calc-cta__hero-bullet-icon {
  flex-shrink: 0;
  color:       var(--nabp-cta-pink);
  margin-top:  1px;
}
.nabp-calc-cta__hero-bullets strong { color: var(--nabp-cta-dark); font-weight: 700; }

.nabp-calc-cta__hero-google {
  display:     inline-flex;
  align-items: center;
  flex-wrap:   wrap;
  gap:         8px 12px;
  padding-top: 6px;
  border-top:  1px solid rgba(0,0,0,0.05);
  font-family: 'Roboto', system-ui, sans-serif;
  font-size:   13px;
  color:       var(--nabp-cta-body);
}
.nabp-calc-cta__hero-stars {
  display: inline-flex;
  gap:     1px;
  color:   #fbbc04; /* google yellow */
}
.nabp-calc-cta__hero-stars svg { width: 15px; height: 15px; }
.nabp-calc-cta__hero-rating { font-size: 14px; color: var(--nabp-cta-dark); }
.nabp-calc-cta__hero-rating strong { font-size: 16px; font-weight: 900; font-family: 'Raleway', sans-serif; }
.nabp-calc-cta__hero-rating-denom { color: var(--nabp-cta-gray); font-weight: 500; }
.nabp-calc-cta__hero-rating-on    { color: var(--nabp-cta-gray); font-weight: 400; margin-left: 2px; }
.nabp-calc-cta__hero-rating-count {
  color:        var(--nabp-cta-pink);
  font-weight:  700;
  font-size:    13px;
  padding-left: 4px;
}

/* Portrait column */
.nabp-calc-cta__hero-portrait-col {
  position: relative;
  display:  flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.nabp-calc-cta__hero-portrait {
  margin: 0;
  width:  100%;
  max-width: 280px;
  border-radius: var(--nabp-cta-radius-i);
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  background: var(--nabp-cta-surface);
}
.nabp-calc-cta__hero-portrait img {
  display:    block;
  width:      100%;
  height:     auto;
  aspect-ratio: 1 / 1;
  -o-object-fit: cover;
     object-fit: cover;
}
.nabp-calc-cta__hero-badge {
  position:      absolute;
  right:         -8px;
  bottom:        -16px;
  background:    var(--nabp-cta-surface);
  padding:       10px 14px;
  border-radius: var(--nabp-cta-radius-i);
  box-shadow:    0 10px 22px rgba(0,0,0,0.14);
  display:       flex;
  flex-direction: column;
  gap:           2px;
  max-width:     220px;
}
.nabp-calc-cta__hero-badge-name {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size:   17px;
  color:       var(--nabp-cta-dark);
  line-height: 1.15;
}
.nabp-calc-cta__hero-badge-role {
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 400;
  font-size:   11px;
  color:       var(--nabp-cta-body);
  line-height: 1.3;
}

/* ══════════════ PICKED-LENDER BANNER ══════════════ */
.nabp-calc-cta__picked {
  display:               grid;
  grid-template-columns: 1fr;
  gap:                   12px;
  margin:                14px var(--nabp-cta-gutter) 0;
  padding:               14px 18px;
  background:            var(--nabp-cta-pink-bg);
  border:                1px solid rgba(214, 49, 148, 0.22);
  border-radius:         var(--nabp-cta-radius-i);
}
@media (min-width: 640px) {
  .nabp-calc-cta__picked {
    grid-template-columns: minmax(120px, auto) 1fr;
    gap:                   20px;
    align-items:           center;
  }
}
.nabp-calc-cta__picked-rate-col {
  display:        flex;
  flex-direction: column;
  align-items:    flex-start;
  border-right:   0;
  padding-right:  0;
}
@media (min-width: 640px) {
  .nabp-calc-cta__picked-rate-col {
    border-right:  1px solid rgba(214, 49, 148, 0.2);
    padding-right: 20px;
    min-width:     130px;
  }
}
.nabp-calc-cta__picked-rate {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size:   36px;
  line-height: 1;
  color:       var(--nabp-cta-pink);
}
.nabp-calc-cta__picked-rate-pct {
  font-size: 18px;
  color:     var(--nabp-cta-pink);
  vertical-align: top;
  margin-left: 1px;
}
.nabp-calc-cta__picked-rate-unit {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color:          var(--nabp-cta-gray);
  margin-top:     2px;
}
.nabp-calc-cta__picked-rate-meta {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size:   12px;
  color:       var(--nabp-cta-gray);
  margin-top:  4px;
}
.nabp-calc-cta__picked-body { min-width: 0; }
.nabp-calc-cta__picked-lender-row {
  display:        flex;
  flex-direction: column;
  gap:            2px;
  margin-bottom:  10px;
}
.nabp-calc-cta__picked-eyebrow {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color:          var(--nabp-cta-pink);
}
.nabp-calc-cta__picked-lender {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size:   18px;
  color:       var(--nabp-cta-dark);
  line-height: 1.2;
}
.nabp-calc-cta__picked-figures {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   8px 16px;
  margin:                0;
}
@media (min-width: 640px) {
  .nabp-calc-cta__picked-figures { grid-template-columns: repeat(4, 1fr); }
}
.nabp-calc-cta__picked-figures > div { min-width: 0; }
.nabp-calc-cta__picked-figures dt {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--nabp-cta-gray);
  margin-bottom:  2px;
}
.nabp-calc-cta__picked-figures dd {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 700;
  font-size:   15px;
  color:       var(--nabp-cta-dark);
  margin:      0;
  line-height: 1.2;
}
.nabp-calc-cta__picked-redeem { color: var(--nabp-cta-pink) !important; }

/* ══════════════ TOP BAR — back + slim progress (NO counter) ══════════════ */
.nabp-calc-cta__top-bar {
  display:     flex;
  align-items: center;
  gap:         16px;
  padding:     16px var(--nabp-cta-gutter) 6px;
}
/* Back button — exact Stitch spec: text-brand-gray, flex, gap-1 (4px),
   opacity-50 when disabled. No background, no border, no padding chrome.
   !important across all states because the Genesis MagazinePro theme adds a
   `button:hover { background: highlight-color }` rule that bled through and
   painted a solid pink block over the button on hover. */
.nabp-calc-cta__back,
.nabp-calc-cta__back:hover,
.nabp-calc-cta__back:focus,
.nabp-calc-cta__back:active,
.nabp-calc-cta__back:disabled {
  -moz-appearance:         none !important;
       appearance:         none !important;
  -webkit-appearance: none !important;
  background:         transparent !important;
  background-color:   transparent !important;
  background-image:   none !important;
  border:             0 !important;
  box-shadow:         none !important;
  outline:            none !important;
  text-shadow:        none !important;
}
.nabp-calc-cta__back {
  display:     inline-flex;
  align-items: center;
  gap:         4px;
  padding:     6px 4px;
  color:       var(--nabp-cta-gray);
  font-family: 'Roboto', system-ui, sans-serif;
  font-size:   14px;
  font-weight: 400;
  cursor:      pointer;
  transition:  color 150ms;
  line-height: 1;
}
.nabp-calc-cta__back:hover:not(:disabled) {
  color: var(--nabp-cta-pink) !important;
}
.nabp-calc-cta__back:disabled {
  opacity: 0.5;
  cursor:  not-allowed;
}

/* Material Symbols sizing override — scope to .nabp-calc-cta so the global
   .material-symbols-outlined sitewide rules aren't disturbed. The component
   passes the size via inline style on the span; this rule ensures vertical
   alignment + that any leftover line-height-1 quirks are normalised. */
.nabp-calc-cta .nabp-ms-icon {
  display:               inline-flex;
  align-items:           center;
  justify-content:       center;
  vertical-align:        middle;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.nabp-calc-cta__progress {
  flex:           1;
  max-width:      none;
  margin-left:    auto;
  height:         4px;
  background:     var(--nabp-cta-line);
  border-radius:  999px;
  overflow:       hidden;
}
.nabp-calc-cta__progress-fill {
  height:         100%;
  background:     var(--nabp-cta-pink);
  border-radius:  999px;
  transition:     width 500ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ══════════════ CONTENT HEADER — eyebrow + title + subtitle ══════════════ */
.nabp-calc-cta__content-header {
  padding: 16px var(--nabp-cta-gutter) 6px;
}
.nabp-calc-cta__eyebrow {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--nabp-cta-pink);
  margin:         0 0 6px;
}
.nabp-calc-cta__title {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size:   22px;
  line-height: 1.2;
  color:       var(--nabp-cta-dark);
  margin:      0 0 6px;
}
@media (min-width: 720px) { .nabp-calc-cta__title { font-size: 26px; } }
.nabp-calc-cta__subtitle {
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 400;
  font-size:   14px;
  line-height: 1.5;
  color:       var(--nabp-cta-gray);
  margin:      0;
}

/* ══════════════ STEPS CARRIAGE ══════════════
   Rewritten 2026-05-23: dropped the flex slide-track carousel because the
   wrapper inherited the tallest step's height (Step 7 with notes+consent),
   leaving huge empty space below short steps (loan amount, property value).
   Now each step lives in the same grid cell — only the active one renders
   (display:block); the rest are display:none. React keeps them mounted so
   refs + FormData still capture all values at submit time. */
.nabp-calc-cta__steps {
  position: relative;
  padding:  6px 0 0;
}
.nabp-calc-cta__steps-track {
  display: block;
  width:   100%;
}
.nabp-calc-cta__step {
  display:    none;
  padding:    4px var(--nabp-cta-gutter) 8px;
  box-sizing: border-box;
}
.nabp-calc-cta__step.is-active {
  display: block;
  animation: nabp-cta-step-fade 200ms ease-out;
}
@keyframes nabp-cta-step-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .nabp-calc-cta__step.is-active { animation: none; }
}

/* ══════════════ SELECTION CARDS (steps 1, 4, 5) ══════════════ */
.nabp-calc-cta__cards {
  display:               grid;
  gap:                   10px;
  grid-template-columns: 1fr;
  margin:                0;
}
@media (min-width: 640px) {
  .nabp-calc-cta__cards { grid-template-columns: 1fr 1fr; gap: 12px; }
}
.nabp-calc-cta__cards--region {
  grid-template-columns: 1fr 1fr;
}
@media (min-width: 640px) {
  .nabp-calc-cta__cards--region { grid-template-columns: 1fr 1fr 1fr; }
}

/* Selection card — exact Stitch fidelity. Icon-left flex-row, subtle hover,
   ring-only selected state, kill all browser-default button chrome.
   Scaled UP 2026-05-23 per operator: bigger padding + taller min-height +
   larger title + bigger icon to match the Stitch homepage CTA presence. */
.nabp-calc-cta__card {
  appearance:           none;
  -webkit-appearance:   none;
  -moz-appearance:      none;
  display:              flex;
  align-items:          flex-start;
  gap:                  24px;
  padding:              36px 36px;        /* up from 28x32 — operator 2026-05-23 */
  background:           var(--nabp-cta-surface) !important;
  border:               1px solid var(--nabp-cta-line);
  border-radius:        var(--nabp-cta-radius-i);
  cursor:               pointer;
  text-align:           left;
  font-family:          'Roboto', system-ui, sans-serif;
  color:                var(--nabp-cta-dark);
  min-height:           128px;            /* up from 104px */
  transition:           border-color 200ms ease, background-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
  text-decoration:      none;
  outline:              none;
}
.nabp-calc-cta__card:hover {
  border-color:    var(--nabp-cta-pink);
  background-color: rgba(214, 49, 148, 0.02) !important; /* Stitch-spec subtle */
  transform:       translateY(-1px);
}
.nabp-calc-cta__card:active { transform: scale(0.98); }
.nabp-calc-cta__card:focus-visible {
  outline:        2px solid var(--nabp-cta-pink);
  outline-offset: 2px;
}
.nabp-calc-cta__card.is-selected {
  /* 2026-05-27 EVENING — match LOCAL prototype `.choice.is-active`:
     subtle 5%-opacity pink wash + thin pink border, NO ring glow.
     Previous 50%-opacity pink ring was too strong vs prototype. */
  border-color:     var(--nabp-cta-pink);
  background-color: rgba(214, 49, 148, 0.05) !important;
  box-shadow:       none;
}
.nabp-calc-cta__card-icon {
  flex-shrink:    0;
  display:        inline-flex;
  align-items:    flex-start;
  justify-content: center;
  color:          var(--nabp-cta-pink);
  margin-top:     2px;
}
.nabp-calc-cta__card-icon svg {
  width:  28px;
  height: 28px;
}
.nabp-calc-cta__card-text {
  display:        flex;
  flex-direction: column;
  gap:            4px;
  min-width:      0;
}
.nabp-calc-cta__card-title {
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 700;
  font-size:   18px;
  line-height: 1.25;
  color:       var(--nabp-cta-dark);
}
.nabp-calc-cta__card-sub {
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 400;
  font-size:   14px;
  color:       var(--nabp-cta-gray);
  line-height: 1.4;
}

/* Compact variant for region step (9 small cards, just label + pin) */
.nabp-calc-cta__card--compact {
  align-items:     center;
  justify-content: flex-start;
  gap:             10px;
  min-height:      52px;
  padding:         14px 16px;
}
.nabp-calc-cta__card-pin {
  display:     inline-flex;
  color:       var(--nabp-cta-pink);
  flex-shrink: 0;
}
.nabp-calc-cta__card--compact .nabp-calc-cta__card-title {
  font-size:   14px;
  font-weight: 600;
}

.nabp-calc-cta__cards--error .nabp-calc-cta__card { border-color: #c0392b; }

/* ══════════════ INPUTS / LABELS / FIELDS ══════════════ */
.nabp-calc-cta__field { margin-bottom: 12px; }
.nabp-calc-cta__field:last-child { margin-bottom: 0; }

.nabp-calc-cta__row {
  display:               grid;
  gap:                   12px;
  grid-template-columns: 1fr;
  margin-bottom:         12px;
}
@media (min-width: 640px) {
  .nabp-calc-cta__row { grid-template-columns: 1fr 1fr; }
}

.nabp-calc-cta__label {
  display:       block;
  font-family:   'Roboto', system-ui, sans-serif;
  font-weight:   600;
  font-size:     15px;
  color:         var(--nabp-cta-dark);    /* dark, not body — matches .qsfield__label */
  margin-bottom: 10px;
  letter-spacing: 0;
}
.nabp-calc-cta__label-opt {
  font-weight: 400;
  font-size:   12px;
  color:       var(--nabp-cta-gray);
  margin-left: 4px;
}
.nabp-calc-cta__req {
  color:       var(--nabp-cta-pink);
  margin-left: 2px;
  font-weight: 700;
}

/* Input — matches .qsfield__input from the new design system 2026-05-23
   (scripts/design/calculator-modern-2026-QUICKSOURCE-2026-05-23.html). */
.nabp-calc-cta__input {
  display:       block;
  width:         100%;
  font-family:   'Roboto', system-ui, sans-serif;
  font-size:     17px;            /* up from 15 — design spec base */
  font-weight:   500;
  color:         var(--nabp-cta-dark);
  background:    var(--nabp-cta-surface);
  border:        1.5px solid var(--nabp-cta-line);  /* design spec — was 2px */
  border-radius: var(--nabp-cta-radius-i);
  padding:       18px 20px;       /* up from 12x14 */
  line-height:   1.4;
  min-height:    64px;            /* up from 48 */
  transition:    border-color 150ms, box-shadow 150ms;
  box-sizing:    border-box;
}
.nabp-calc-cta__input:focus {
  outline:      none;
  border-color: var(--nabp-cta-pink);
  box-shadow:   0 0 0 3px rgba(214, 49, 148, 0.18);  /* --shadow-focus spec */
}
/* Big primary input — exact .qsfield__input spec (currency / region select) */
.nabp-calc-cta__input--lg {
  font-size:   22px;              /* design spec — 1.375rem */
  font-weight: 600;
  min-height:  76px;              /* design spec exact */
  padding:     20px 22px;         /* design spec exact */
}
.nabp-calc-cta__select.nabp-calc-cta__input--lg {
  background-size:     16px;
  background-position: right 20px center;
  padding-right:       52px !important;
}
.nabp-calc-cta__textarea {
  resize:      vertical;
  min-height:  90px;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size:   14px;
  line-height: 1.5;
}

/* Big chunky native <select> — kills browser-default chrome, custom down-chevron
   on the right via inline SVG bg. Matches the input--lg sizing so the region
   picker on Step 5 has the same touch-friendly weight as the currency inputs. */
.nabp-calc-cta__select {
  appearance:           none !important;
  -webkit-appearance:   none !important;
  -moz-appearance:      none !important;
  background-image:     url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2714%27 height=%2714%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%23888%27 stroke-width=%272.5%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27><polyline points=%276 9 12 15 18 9%27/></svg>");
  background-repeat:    no-repeat;
  background-position:  right 18px center;
  background-size:      14px;
  padding-right:        48px !important;
  cursor:               pointer;
  text-overflow:        ellipsis;
}
.nabp-calc-cta__select:focus {
  background-image:     url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2714%27 height=%2714%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%23d63194%27 stroke-width=%272.5%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27><polyline points=%276 9 12 15 18 9%27/></svg>");
}

/* Data-usage disclosure panel — light gray with pink left bar.
   Mirrors the .na-cta2 / homepage CTA's "How we use your details" pattern. */
.nabp-calc-cta__data-usage {
  background:    var(--nabp-cta-bg);
  border-left:   4px solid var(--nabp-cta-pink);
  padding:       12px 16px;
  margin:        0 0 14px;
  border-radius: 0 var(--nabp-cta-radius-i) var(--nabp-cta-radius-i) 0;
}
.nabp-calc-cta__data-usage p {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size:   13px;
  line-height: 1.55;
  color:       var(--nabp-cta-body);
  margin:      0;
}
.nabp-calc-cta__data-usage strong {
  color:       var(--nabp-cta-dark);
  font-weight: 700;
}

.nabp-calc-cta__hint {
  font-size:  12.5px;
  font-style: italic;
  color:      var(--nabp-cta-gray);
  margin:     6px 0 0;
}

/* ══════════════ STEP 7 — SUMMARY READ-OUT TILES ══════════════ */
.nabp-calc-cta__summary {
  margin-bottom: 14px;
  padding:       14px 16px;
  background:    var(--nabp-cta-surface);   /* white — pops out on warm gray card */
  border:        1px solid var(--nabp-cta-line);
  border-radius: var(--nabp-cta-radius-i);
}
.nabp-calc-cta__summary-title {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--nabp-cta-pink);
  margin:         0 0 10px;
}
.nabp-calc-cta__summary-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   10px 14px;
  margin:                0;
}
@media (min-width: 640px) {
  .nabp-calc-cta__summary-grid { grid-template-columns: repeat(3, 1fr); }
}
.nabp-calc-cta__summary-tile { min-width: 0; }
.nabp-calc-cta__summary-label {
  font-family:    'Raleway', system-ui, sans-serif;
  font-weight:    700;
  font-size:      10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--nabp-cta-gray);
  margin:         0 0 2px;
}
.nabp-calc-cta__summary-value {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 700;
  font-size:   15px;
  color:       var(--nabp-cta-dark);
  margin:      0;
  line-height: 1.2;
}

/* ══════════════ CONSENT ══════════════ */
.nabp-calc-cta__consent {
  display:     flex;
  gap:         10px;
  align-items: flex-start;
  font-size:   12.5px;
  line-height: 1.5;
  color:       var(--nabp-cta-body);
  cursor:      pointer;
  padding:     10px 12px;
  background:  var(--nabp-cta-surface);   /* white — pops out on warm gray card */
  border:      1px solid var(--nabp-cta-line);
  border-radius: var(--nabp-cta-radius-i);
}
.nabp-calc-cta__consent input[type="checkbox"] {
  flex-shrink:  0;
  margin-top:   2px;
  width:        18px;
  height:       18px;
  accent-color: var(--nabp-cta-pink);
}
.nabp-calc-cta__consent a {
  color:           var(--nabp-cta-teal);
  text-decoration: underline;
}
.nabp-calc-cta__consent a:hover { color: var(--nabp-cta-pink); }

/* Optional marketing-consent variant — PECR-compliant un-ticked soft opt-in
   per LOCKED spec 2026-05-25 D2. Visually muted from the required T&C above
   so it reads as clearly optional. Stacked beneath with 8px gap. */
.nabp-calc-cta__field--marketing { margin-top: 8px; }
.nabp-calc-cta__consent--optional {
  background: transparent;
  border: 1px dashed var(--nabp-cta-line);
  color: var(--nabp-cta-muted);
  font-size: 12px;
}
.nabp-calc-cta__consent-opt {
  display: inline-block;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--nabp-cta-teal);
  margin-right: 4px;
}

/* ══════════════ v7 CONSENT PANEL — LOCKED 2026-05-27 ══════════════
   Pink-left-border editorial card per general-cta-prototype-v7.html lines 119-132.
   Combines: "How we use your details" body + REQUIRED Privacy Policy checkbox
   + secondary heading + 3-channel un-ticked marketing chips. Mirrors PHP Main
   CTA na_render_enquiry_form() v7 output. */
.nabp-calc-cta__consent-panel {
  background: var(--nabp-cta-surface);
  border-radius: var(--nabp-cta-radius-i, 8px);
  padding: 18px 20px;
  border-left: 3px solid var(--nabp-cta-pink);
  margin-top: 16px;
}
.nabp-calc-cta__consent-heading {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--nabp-cta-dark);
  margin: 0 0 8px;
}
.nabp-calc-cta__consent-heading--secondary {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--nabp-cta-line);
}
.nabp-calc-cta__consent-body {
  font-size: 12px;
  color: var(--nabp-cta-body);
  line-height: 1.55;
  margin: 0 0 10px;
}
.nabp-calc-cta__consent-body strong { color: var(--nabp-cta-dark); font-weight: 600; }
.nabp-calc-cta__consent-sub {
  font-size: 12px;
  color: var(--nabp-cta-body);
  line-height: 1.5;
  margin: 0 0 8px;
}
.nabp-calc-cta__consent-channels {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-top: 8px;
}
@media (max-width: 560px) {
  .nabp-calc-cta__consent-channels { grid-template-columns: 1fr; }
}
.nabp-calc-cta__consent-channel {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 8px 10px;
  background: var(--nabp-cta-off, #f5f5f5);
  border-radius: var(--nabp-cta-radius-i, 6px);
  font-size: 12px;
  font-weight: 500;
  color: var(--nabp-cta-dark);
  cursor: pointer;
}
.nabp-calc-cta__consent-channel input[type="checkbox"] {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  accent-color: var(--nabp-cta-pink);
  cursor: pointer;
}

/* ══════════════ PHONE +44 PREFIX (both variants) ══════════════
   Matches Main CTA visual + behaviour (mu-plugins/niche-advice-utilities.php
   §.na-cta2__phone-wrap). Pre-pended +44 block, input cap 14 chars, leading
   0/44 stripped on input, E.164 rewrite on submit. */
.nabp-calc-cta__phone-wrap,
.nabp-home-cta__phone-wrap {
  position: relative;
  display: flex;
  align-items: stretch;
}
.nabp-calc-cta__phone-prefix,
.nabp-home-cta__phone-prefix {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  background: #f5f5f5;
  border: 1px solid #eeeeee;
  border-right: 0;
  border-radius: 6px 0 0 6px;
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 600;
  color: #222222;
  font-size: 15px;
  line-height: 1;
  min-width: 48px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.nabp-calc-cta__input--phone-prefixed,
.nabp-home-cta__input--phone-prefixed {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  flex: 1;
  min-width: 0;
}
.nabp-calc-cta__help,
.nabp-home-cta__help {
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 12px;
  font-style: italic;
  color: #888;
  margin: 6px 0 0;
}

/* ══════════════ ERRORS ══════════════ */
.nabp-calc-cta__field--error .nabp-calc-cta__input { border-color: #c0392b; }
.nabp-calc-cta__err {
  color:       #c0392b;
  font-size:   13px;
  font-weight: 500;
  margin:      6px 0 0;
}

/* ══════════════ ACTION ROW ══════════════ */
.nabp-calc-cta__action-row {
  display:         flex;
  justify-content: flex-end;
  padding:         4px var(--nabp-cta-gutter) 18px;
}
/* Submit + Continue buttons — matches .qscta from the new design system
   2026-05-23 (scripts/design/calculator-modern-2026-QUICKSOURCE-2026-05-23.html
   :265+). Dark background, white text, Raleway 700, subtle dark shadow, lift
   on hover. Operator switched from pink-gradient → dark per the new UI
   direction the rest of the site is moving towards. */
.nabp-calc-cta__submit {
  -moz-appearance:         none !important;
       appearance:         none !important;
  -webkit-appearance: none !important;
  display:            inline-flex;
  align-items:        center;
  justify-content:    center;
  gap:                10px;
  font-family:        'Raleway', system-ui, sans-serif !important;
  font-weight:        700;
  font-size:          18px;                  /* design spec — 1.125rem */
  letter-spacing:     0.01em;
  text-transform:     none;                  /* no uppercase per new spec */
  color:              #fff !important;
  background:         var(--nabp-cta-dark) !important;   /* #222222 */
  background-image:   none !important;       /* kill any inherited gradient */
  border:             none !important;
  border-radius:      var(--nabp-cta-radius-i);
  padding:            0 32px;
  width:              100%;
  min-height:         76px;                  /* design spec exact */
  min-width:          220px;
  cursor:             pointer;
  box-shadow:         0 4px 16px rgba(34, 34, 34, 0.14);   /* --shadow-dark */
  transition:         box-shadow 250ms cubic-bezier(0.22, 1, 0.36, 1),
                      transform 250ms cubic-bezier(0.22, 1, 0.36, 1);
}
@media (min-width: 640px) { .nabp-calc-cta__submit { width: auto; } }
.nabp-calc-cta__submit svg {
  width:   18px;
  height:  18px;
  transition: transform 150ms;
}
.nabp-calc-cta__submit:hover:not(:disabled) {
  box-shadow: 0 6px 18px rgba(34, 34, 34, 0.22);
  transform:  translateY(-1px);
}
.nabp-calc-cta__submit:hover:not(:disabled) svg {
  transform: translateX(3px);
}
.nabp-calc-cta__submit:active:not(:disabled) {
  transform:  translateY(0);
  box-shadow: 0 4px 16px rgba(34, 34, 34, 0.14);
}
.nabp-calc-cta__submit:focus-visible {
  outline:        2px solid var(--nabp-cta-pink);
  outline-offset: 3px;
}
.nabp-calc-cta__submit:disabled {
  background: #999999 !important;
  box-shadow: none;
  cursor:     not-allowed;
}

/* ══════════════ REDUCED MOTION ══════════════ */
@media (prefers-reduced-motion: reduce) {
  .nabp-calc-cta__steps-track,
  .nabp-calc-cta__progress-fill,
  .nabp-calc-cta__card,
  .nabp-calc-cta__submit { transition: none; }
}


/* ─── AEO answer block — added Phase 1 dispatch 07d Step 4 (2026-05-25 EOD) ─── */
.nabp-qs-answer-block {
  /* 2026-05-27 EVENING: hard-hidden per operator — sandwich between
     hero + calc broke prototype structural flow. !important to defeat
     any downstream override. JSX move-to-after-results queued. */
  display: none !important;
}
.nabp-qs-answer-block__heading {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--na-dark);
  margin: 0 0 10px 0;
  line-height: 1.3;
}
.nabp-qs-answer-block__body {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--na-body);
  margin: 0;
}
.nabp-qs-answer-block__body strong { color: var(--na-dark); font-weight: 600; }
@media (max-width: 720px) {
  .nabp-qs-answer-block { padding: 18px 20px; margin-bottom: 24px; }
  .nabp-qs-answer-block__heading { font-size: 1.0625rem; }
  .nabp-qs-answer-block__body { font-size: 0.9rem; }
}

/* ─── Disclaimer MCOB statutory warning — Phase 1 dispatch 07d Step 5 (2026-05-25 EOD) ─── */
.nabp-disclaimer__body .nabp-disclaimer__mcob {
  font-size: 0.9rem;
  color: var(--na-dark);
  margin: 0 0 12px 0;
  letter-spacing: 0.01em;
  line-height: 1.5;
}
.nabp-disclaimer__body .nabp-disclaimer__mcob strong { font-weight: 700; }

/* ════════════════════════════════════════════════════════════════════════
   HOMEPAGE CTA VARIANT — mounted on #nabp-homepage-cta-mount via
   <CalcCtaForm funnelType="homepage" />.
   Visual spec: scripts/design/homepage-cta-prototype-2026-05-25/
                homepage-cta-prototype-v5.html (operator-signed 2026-05-25 EOD)
   Brand locks honoured:
     - [[button-shape-rectangular-slight-radius]] - rectangular with 6px radius
     - [[no-pink-on-black]] - submit btn dark with white text; pink only on light surfaces
     - [[no-timing-promise-on-cta-copy-locked-2026-05-25]] - no "within X hours" strings
   ════════════════════════════════════════════════════════════════════════ */
.nabp-home-cta {
  /* 2026-05-27 LATE EVENING — match OLD .na-cta2__form-card--home grey #efeeeb
     per operator side-by-side screenshot comparison. Was #ececec which read
     too cool / too neutral. #efeeeb is the warmer grey of the legacy form. */
  --home-cta-card-bg:    #efeeeb;
  --home-cta-pink-bg:    #fdf2f8;
  --home-cta-shadow-md:    0 4px 20px rgba(34,34,34,0.06);
  /* Match OLD .na-cta2__form-card--home layered drop-shadow per operator
     side-by-side comparison 2026-05-27 LATE EVENING. Stronger depth feel. */
  --home-cta-shadow-lg:    0 24px 50px -8px rgba(26,28,26,0.18), 0 4px 12px -4px rgba(26,28,26,0.08);
  --home-cta-shadow-dark:  0 4px 16px rgba(34,34,34,0.14);
  --home-cta-shadow-focus: 0 0 0 3px rgba(214,49,148,0.18);
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-family: 'Roboto', system-ui, sans-serif;
  color: var(--na-body);
}
.nabp-home-cta *,
.nabp-home-cta *::before,
.nabp-home-cta *::after { box-sizing: border-box; }

.nabp-home-cta__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 4px;
}
.nabp-home-cta__step-label {
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--na-gray);
}
.nabp-home-cta__step-label strong { color: var(--na-dark); }
.nabp-home-cta__pct {
  font-weight: 700;
  font-size: 13px;
  color: var(--na-pink);
}

.nabp-home-cta__progress-rail {
  width: 100%;
  height: 4px;
  background: rgba(0,0,0,0.08);
  border-radius: 99px;
  overflow: hidden;
}
.nabp-home-cta__progress-fill {
  height: 100%;
  background: var(--na-pink);
  border-radius: 99px;
  transition: width 300ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Outer carousel shell — was `__card` until 2026-05-27, but that collided
   with the option-button `.nabp-home-cta__card` rule below (same class
   name) which overrode the neutral-grey bg with white, breaking the
   prototype-v4 LOCKED palette (#ececec shell, #ffffff option buttons).
   Renamed to `__shell` so both selectors are independently authoritative. */
.nabp-home-cta__shell {
  width: 100%;
  background: var(--home-cta-card-bg);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--r-md);
  box-shadow: var(--home-cta-shadow-lg);
  padding: 28px 24px 24px;
  /* 2026-05-27 EVENING: operator-requested height-match to portrait. The
     carousel renders one step at a time, naturally short; min-height keeps
     the card aligned with the left-column portrait bottom so the form
     doesn't look boxy/squished. Desktop only; mobile auto. */
}
@media (min-width: 980px) {
  /* Step-1 only: align card height to portrait. Subsequent steps grow
     naturally with their content (operator directive 2026-05-27 EVENING). */
  .nabp-home-cta__shell[data-step="1"] {
    min-height: 560px;
  }
}

.nabp-home-cta__content-header { margin-bottom: 18px; }
.nabp-home-cta__title {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 900;
  font-size: 24px;
  line-height: 1.15;
  color: var(--na-dark);
  margin: 0 0 6px;
}
@media (min-width: 720px) { .nabp-home-cta__title { font-size: 26px; } }
.nabp-home-cta__subtitle {
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--na-body);
  margin: 0;
}

.nabp-home-cta__step { display: none; }
.nabp-home-cta__step.is-active { display: block; animation: nabp-home-fadeIn 250ms ease-out; }
@keyframes nabp-home-fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.nabp-home-cta__cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 480px) {
  .nabp-home-cta__cards { grid-template-columns: 1fr 1fr; gap: 12px; }
}
.nabp-home-cta__cards--two { grid-template-columns: 1fr 1fr !important; }
.nabp-home-cta__cards--error .nabp-home-cta__card:not(.is-selected) { border-color: rgba(214,49,148,0.3); }

.nabp-home-cta__card {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: var(--na-white);
  border: 1.5px solid transparent;
  border-radius: var(--r-md);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  text-align: left;
  transition: border-color 150ms, transform 150ms, box-shadow 150ms;
  font-family: 'Roboto', system-ui, sans-serif;
}
.nabp-home-cta__card:hover {
  border-color: var(--na-pink);
  transform: translateY(-1px);
  box-shadow: var(--home-cta-shadow-md);
}
.nabp-home-cta__card.is-selected {
  border-color: var(--na-pink);
  background: var(--home-cta-pink-bg);
}
.nabp-home-cta__card-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--r-md);
  background: var(--home-cta-pink-bg);
  color: var(--na-pink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.nabp-home-cta__card-icon svg { width: 20px; height: 20px; }
.nabp-home-cta__card-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.nabp-home-cta__card-title { font-weight: 700; font-size: 15px; color: var(--na-dark); }
.nabp-home-cta__card-sub   { font-weight: 400; font-size: 12.5px; color: var(--na-gray); line-height: 1.3; }

.nabp-home-cta__field { margin-bottom: 12px; }
.nabp-home-cta__row {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
  margin-bottom: 12px;
}
@media (min-width: 480px) { .nabp-home-cta__row { grid-template-columns: 1fr 1fr; } }

.nabp-home-cta__label {
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: var(--na-dark);
  margin-bottom: 8px;
}
.nabp-home-cta__req { color: var(--na-pink); margin-left: 2px; font-weight: 700; }

.nabp-home-cta__input {
  display: block;
  width: 100%;
  font-family: 'Roboto', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: var(--na-dark);
  background: var(--na-white);
  border: 1.5px solid transparent;
  border-radius: var(--r-md);
  padding: 16px 18px;
  line-height: 1.4;
  min-height: 56px;
  transition: border-color 150ms, box-shadow 150ms;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.nabp-home-cta__input:focus {
  outline: none;
  border-color: var(--na-pink);
  box-shadow: var(--home-cta-shadow-focus);
}
.nabp-home-cta__input--lg {
  font-size: 22px;
  font-weight: 600;
  min-height: 72px;
  padding: 20px 22px;
}
.nabp-home-cta__field--error .nabp-home-cta__input { border-color: var(--na-pink); }

.nabp-home-cta__applicants {
  display: inline-flex;
  background: var(--na-white);
  border-radius: var(--r-md);
  padding: 4px;
  gap: 4px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.nabp-home-cta__applicant-opt {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  font-family: 'Roboto', system-ui, sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--na-gray);
  padding: 10px 22px;
  border-radius: var(--r-md);
  cursor: pointer;
  transition: background 150ms, color 150ms;
}
.nabp-home-cta__applicant-opt.is-selected {
  background: var(--na-pink);
  color: var(--na-white);
}

.nabp-home-cta__summary {
  margin-bottom: 14px;
  padding: 14px 16px;
  background: var(--na-white);
  border-radius: var(--r-md);
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.nabp-home-cta__summary-title {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--na-pink);
  margin: 0 0 10px;
}
.nabp-home-cta__summary-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 14px;
  margin: 0;
}
.nabp-home-cta__summary-tile { min-width: 0; }
.nabp-home-cta__summary-label {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--na-gray);
  margin: 0 0 2px;
}
.nabp-home-cta__summary-value {
  font-family: 'Raleway', system-ui, sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: var(--na-dark);
  margin: 0;
  line-height: 1.2;
}

.nabp-home-cta__data-usage {
  background: rgba(255,255,255,0.55);
  border-left: 3px solid var(--na-pink);
  padding: 12px 16px;
  margin: 0 0 14px;
  border-radius: 0 var(--r-md) var(--r-md) 0;
}
.nabp-home-cta__data-usage p {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--na-body);
  margin: 0;
}
.nabp-home-cta__data-usage strong { color: var(--na-dark); font-weight: 700; }

.nabp-home-cta__consent {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--na-body);
  cursor: pointer;
  padding: 10px 12px;
  background: var(--na-white);
  border-radius: var(--r-md);
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.nabp-home-cta__consent input[type="checkbox"] {
  flex-shrink: 0;
  margin-top: 2px;
  width: 18px;
  height: 18px;
  accent-color: var(--na-pink);
}
.nabp-home-cta__consent a { color: var(--na-pink); text-decoration: underline; }
.nabp-home-cta__consent a:hover { color: var(--na-dark); }

/* Optional marketing-consent variant — PECR-compliant un-ticked soft opt-in
   per LOCKED spec 2026-05-25 D2. Visually muted from the required T&C above
   so it reads as clearly optional. Stacked beneath with 8px gap. */
.nabp-home-cta__field--marketing { margin-top: 8px; }
.nabp-home-cta__consent--optional {
  background: transparent;
  border: 1px dashed rgba(0,0,0,0.12);
  color: var(--na-gray);
  font-size: 12px;
  box-shadow: none;
}
.nabp-home-cta__consent-opt {
  display: inline-block;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--na-pink);
  margin-right: 4px;
}

/* ══════════════ v7 CONSENT PANEL — LOCKED 2026-05-27 ══════════════
   Mirrors bridging variant + PHP Main CTA v7 output. */
.nabp-home-cta__consent-panel {
  background: var(--na-white, #fff);
  border-radius: var(--r-md, 8px);
  padding: 18px 20px;
  border-left: 3px solid var(--na-pink);
  margin-top: 16px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.nabp-home-cta__consent-heading {
  font-family: 'Raleway', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--na-dark);
  margin: 0 0 8px;
}
.nabp-home-cta__consent-heading--secondary {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,0.08);
}
.nabp-home-cta__consent-body {
  font-size: 12px;
  color: var(--na-body);
  line-height: 1.55;
  margin: 0 0 10px;
}
.nabp-home-cta__consent-body strong { color: var(--na-dark); font-weight: 600; }
.nabp-home-cta__consent-sub {
  font-size: 12px;
  color: var(--na-body);
  line-height: 1.5;
  margin: 0 0 8px;
}
.nabp-home-cta__consent-channels {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-top: 8px;
}
@media (max-width: 560px) {
  .nabp-home-cta__consent-channels { grid-template-columns: 1fr; }
}
.nabp-home-cta__consent-channel {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 8px 10px;
  background: #f5f5f5;
  border-radius: var(--r-md, 6px);
  font-size: 12px;
  font-weight: 500;
  color: var(--na-dark);
  cursor: pointer;
}
.nabp-home-cta__consent-channel input[type="checkbox"] {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  accent-color: var(--na-pink);
  cursor: pointer;
}

.nabp-home-cta__err {
  margin: 8px 0 0;
  font-size: 12.5px;
  color: var(--na-pink);
  font-weight: 600;
}

.nabp-home-cta__action-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
}
.nabp-home-cta__back {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  font-size: 14px;
  color: var(--na-gray);
  cursor: pointer;
  padding: 8px 12px 8px 0;
  border-radius: var(--r-md);
  transition: color 150ms;
}
.nabp-home-cta__back:hover:not(:disabled) { color: var(--na-pink); }
.nabp-home-cta__back:disabled { opacity: 0; pointer-events: none; }
.nabp-home-cta__back svg { width: 16px; height: 16px; }

.nabp-home-cta__submit {
  -webkit-appearance: none !important;
     -moz-appearance: none !important;
          appearance: none !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: 'Raleway', system-ui, sans-serif !important;
  font-weight: 700;
  font-size: 16px;
  color: #fff !important;
  background: var(--na-dark) !important;
  border: none !important;
  border-radius: var(--r-md);
  padding: 0 28px;
  min-width: 160px;
  min-height: 54px;
  cursor: pointer;
  box-shadow: var(--home-cta-shadow-dark);
  transition: box-shadow 250ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 250ms cubic-bezier(0.22, 1, 0.36, 1);
}
.nabp-home-cta__submit svg { width: 16px; height: 16px; transition: transform 150ms; }
.nabp-home-cta__submit:hover:not(:disabled) {
  box-shadow: 0 6px 18px rgba(34, 34, 34, 0.22);
  transform: translateY(-1px);
}
.nabp-home-cta__submit:hover:not(:disabled) svg { transform: translateX(3px); }
.nabp-home-cta__submit:focus-visible {
  outline: 2px solid var(--na-pink);
  outline-offset: 3px;
}
.nabp-home-cta__submit:disabled { opacity: 0.7; cursor: wait; }

.nabp-home-cta__trust-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 4px;
  padding-top: 4px;
}
.nabp-home-cta__trust-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--na-gray);
}
.nabp-home-cta__trust-item svg {
  width: 14px;
  height: 14px;
  color: var(--na-pink);
}

@media (prefers-reduced-motion: reduce) {
  .nabp-home-cta__progress-fill,
  .nabp-home-cta__step,
  .nabp-home-cta__card,
  .nabp-home-cta__submit { transition: none; animation: none; }
}

