/* ============================================================
   WP TAX SUITE - calculator stylesheet
   Translated 1:1 from Claude Design artifact (chat HS1-n-caGIg88KfZn203Yg).
   Theming via :root CSS vars; per-instance overrides come from
   WPTS_Calc_Styles::render_inline_css() in templates.
   ============================================================ */

:root {
  /* Brand-overridable */
  --wpts-accent:       #274c78;   /* primary brand blue */
  --wpts-accent-dark:  #1b3859;   /* hover state */
  --wpts-accent-soft:  #e6ecf3;   /* tinted background for active rows + focus rings */
  --wpts-bg:           #ffffff;
  --wpts-surface:      #f7f9fc;
  --wpts-border:       #d9dde3;
  --wpts-border-soft:  #e6e9ee;
  --wpts-text:         #1b2430;
  --wpts-muted:        #5c6b7a;
  --wpts-title-color:  #274c78;   /* calculator + step titles use brand blue */
  --wpts-radius:       14px;
  --wpts-radius-sm:    8px;
  --wpts-title-font:   inherit;

  /* Status */
  --wpts-good:         #146b3a;
  --wpts-good-soft:    #e6f3ec;
  --wpts-warn:         #8a5a00;
  --wpts-warn-soft:    #fff4dc;
  --wpts-warn-border:  #f0d690;
  --wpts-bad:          #a3201e;
  --wpts-bad-soft:     #fdecec;

  /* Spacing & shadow */
  --wpts-shadow:       0 1px 2px rgba(16,24,40,.04), 0 8px 24px -12px rgba(16,24,40,.10);
  --wpts-shadow-lift:  0 1px 2px rgba(16,24,40,.06), 0 16px 40px -16px rgba(16,24,40,.16);
}

/* ----- base ----- */
.wpts-calc,
.wpts-calc *,
.wpts-calc *::before,
.wpts-calc *::after { box-sizing: border-box; }

.wpts-calc {
  font-family: inherit;
  color: var(--wpts-text);
  background: var(--wpts-bg);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius);
  box-shadow: var(--wpts-shadow);
  max-width: 920px;
  width: 100%;
  margin: 1.5rem auto;
  padding: 28px 32px 32px;
  line-height: 1.45;
  font-size: 16px;
}

.wpts-calc__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--wpts-border-soft);
  margin-bottom: 22px;
}

.wpts-calc__title {
  font-family: var(--wpts-title-font);
  font-size: 1.5rem;        /* 24px */
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--wpts-title-color);
}
.wpts-calc__subtitle {
  margin-top: 4px;
  font-size: 0.9rem;
  color: var(--wpts-muted);
  max-width: 56ch;
}

/* tax-year pill (top-right of head) */
.wpts-yearpill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--wpts-muted);
  background: var(--wpts-surface);
  border: 1px solid var(--wpts-border);
  border-radius: 999px;
  padding: 6px 10px;
  white-space: nowrap;
}
.wpts-yearpill::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--wpts-accent);
}

/* ----- progress (wizards) ----- */
.wpts-progress {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: -4px 0 22px;
}
.wpts-progress__bar {
  flex: 1;
  height: 6px;
  background: var(--wpts-border-soft);
  border-radius: 999px;
  overflow: hidden;
}
.wpts-progress__fill {
  height: 100%;
  background: var(--wpts-accent);
  border-radius: 999px;
  transition: width 250ms ease;
}
.wpts-progress__label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--wpts-muted);
  white-space: nowrap;
}

/* ----- step ----- */
.wpts-step__title {
  font-family: var(--wpts-title-font);
  font-size: 1.17rem;       /* ~19px */
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--wpts-title-color);
}
.wpts-step__hint {
  font-size: 0.875rem;
  color: var(--wpts-muted);
  margin-bottom: 18px;
  max-width: 60ch;
}

/* ----- fields ----- */
.wpts-field { display: block; margin-bottom: 0.75rem; }
.wpts-field:last-child { margin-bottom: 0; }

.wpts-field__label,
.wpts-field > label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--wpts-text);
  margin-bottom: 6px;
  letter-spacing: -0.005em;
}
.wpts-field__help,
.wpts-field > small {
  display: block;
  font-size: 0.8rem;
  color: var(--wpts-muted);
  margin-top: 6px;
  line-height: 1.4;
}
.wpts-field__help--inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding: 6px 10px;
  border-radius: var(--wpts-radius-sm);
  background: var(--wpts-accent-soft);
  color: var(--wpts-accent-dark);
  font-weight: 500;
}

.wpts-input,
.wpts-select {
  display: block;
  width: 100%;
  height: 44px;
  padding: 0 14px;
  font: inherit;
  font-size: 16px;          /* prevent iOS zoom */
  color: var(--wpts-text);
  background: var(--wpts-bg);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  transition: border-color 120ms ease, box-shadow 120ms ease;
  -webkit-appearance: none;
  appearance: none;
}
.wpts-input::placeholder { color: #98a2b1; }
.wpts-input:focus,
.wpts-select:focus {
  outline: none;
  border-color: var(--wpts-accent);
  box-shadow: 0 0 0 3px var(--wpts-accent-soft);
}

/* Aggressive reset of every red browser-default form-control state.
   Firefox draws a red shadow on `:invalid` inputs; Chrome/Safari paint
   red borders on `:invalid` and `:user-invalid` after submit attempts.
   We handle validation in JS, so nothing here should ever go red unless
   we explicitly set `.wpts-error`. !important on the kill rules so theme
   stylesheets can't reintroduce the red. */
.wpts-calc input,
.wpts-calc select,
.wpts-calc textarea,
.wpts-calc .wpts-input,
.wpts-calc .wpts-select {
  /* Make native checkboxes/radios use brand blue, not browser-default
     accent (varies by OS - sometimes red on Windows). */
  accent-color: var(--wpts-accent);
}
.wpts-calc input:invalid,
.wpts-calc input:user-invalid,
.wpts-calc input:-moz-ui-invalid,
.wpts-calc select:invalid,
.wpts-calc textarea:invalid,
.wpts-calc .wpts-input:invalid,
.wpts-calc .wpts-input:user-invalid,
.wpts-calc .wpts-input:-moz-ui-invalid,
.wpts-calc .wpts-select:invalid {
  border-color: var(--wpts-border) !important;
  box-shadow: none !important;
  outline: none !important;
}
/* Focused invalid input: still show the accent ring (so the field LOOKS
   active), no red. */
.wpts-calc input:focus:invalid,
.wpts-calc input:focus:user-invalid,
.wpts-calc .wpts-input:focus:invalid,
.wpts-calc .wpts-select:focus:invalid {
  border-color: var(--wpts-accent) !important;
  box-shadow: 0 0 0 3px var(--wpts-accent-soft) !important;
}
/* Belt-and-suspenders: any browser-spec hover ring on form controls
   inside the calc card defaults to the accent, never red. */
.wpts-calc input:hover,
.wpts-calc select:hover,
.wpts-calc .wpts-input:hover,
.wpts-calc .wpts-select:hover {
  border-color: var(--wpts-accent);
}

/* Currency input affordance */
.wpts-money {
  position: relative;
}
.wpts-money > .wpts-input {
  padding-left: 28px;
}
.wpts-money::before {
  content: "$";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--wpts-muted);
  font-weight: 600;
  pointer-events: none;
  z-index: 1;
}

/* Custom dropdown: native <select> hidden for forms + a11y, visual replaced
   by .wpts-select-btn enhanced via assets/js/custom-select.js. */
.wpts-select-wrap {
  position: relative;
}
.wpts-select.wpts-select--native-hidden {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}
.wpts-select-btn {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 44px;
  padding: 0 40px 0 14px;
  font: inherit;
  font-size: 16px;
  color: var(--wpts-text);
  background: var(--wpts-bg);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  text-align: left;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.wpts-select-btn:hover { border-color: #c3cad4; }
.wpts-select-btn:focus,
.wpts-select-wrap.is-open .wpts-select-btn {
  outline: none;
  border-color: var(--wpts-accent);
  box-shadow: 0 0 0 3px var(--wpts-accent-soft);
}
.wpts-select-btn__label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 500;
}
.wpts-select-btn__chev {
  width: 9px;
  height: 9px;
  margin-left: 10px;
  border-right: 1.6px solid var(--wpts-muted);
  border-bottom: 1.6px solid var(--wpts-muted);
  transform: rotate(45deg) translate(-2px, -2px);
  transition: transform 180ms ease;
  flex-shrink: 0;
}
.wpts-select-wrap.is-open .wpts-select-btn__chev {
  transform: rotate(-135deg) translate(-2px, -2px);
}
.wpts-select-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--wpts-bg);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  box-shadow: var(--wpts-shadow-lift);
  padding: 6px;
  z-index: 30;
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition: opacity 140ms ease, transform 140ms ease;
  max-height: 260px;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.wpts-select-wrap.is-open .wpts-select-menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.wpts-select-option {
  padding: 9px 12px;
  border-radius: 6px;
  font-size: 0.93rem;
  cursor: pointer;
  min-height: 40px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--wpts-text);
  line-height: 1.3;
}
.wpts-select-option:hover,
.wpts-select-option.is-focused { background: var(--wpts-surface); }
.wpts-select-option.is-selected {
  background: var(--wpts-accent-soft);
  color: var(--wpts-accent-dark);
  font-weight: 600;
}
.wpts-select-option.is-selected::after {
  content: "";
  margin-left: auto;
  width: 12px; height: 7px;
  border-left: 2px solid var(--wpts-accent-dark);
  border-bottom: 2px solid var(--wpts-accent-dark);
  transform: rotate(-45deg) translate(1px, -1px);
}

/* grids */
.wpts-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px 16px;
}
.wpts-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px 16px;
}
.wpts-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px 16px;
}
.wpts-section {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px dashed var(--wpts-border-soft);
}
.wpts-section:first-of-type,
.wpts-section.wpts-section--first {
  margin-top: 0; padding-top: 0; border-top: 0;
}
.wpts-section__label {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wpts-muted);
  margin-bottom: 12px;
}

/* checkboxes (inline list) - custom styled, real <input> hidden */
.wpts-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin-top: 4px;
}
.wpts-check {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 0.92rem;
  min-height: 44px;
  cursor: pointer;
  user-select: none;
  position: relative;
}
.wpts-check input[type="checkbox"],
.wpts-check input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0; height: 0;
}
.wpts-check__box {
  width: 20px; height: 20px;
  border: 1.5px solid var(--wpts-border);
  border-radius: 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--wpts-bg);
  transition: border-color 120ms ease, background 120ms ease;
  flex-shrink: 0;
}
.wpts-check__box::after {
  content: "";
  width: 10px; height: 6px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translate(1px,-1px);
  opacity: 0;
}
.wpts-check input:checked + .wpts-check__box,
.wpts-check input:checked ~ .wpts-check__box {
  background: var(--wpts-accent);
  border-color: var(--wpts-accent);
}
.wpts-check input:checked + .wpts-check__box::after,
.wpts-check input:checked ~ .wpts-check__box::after { opacity: 1; }
.wpts-check input:focus-visible + .wpts-check__box,
.wpts-check input:focus-visible ~ .wpts-check__box {
  box-shadow: 0 0 0 3px var(--wpts-accent-soft);
}

/* card-style checkboxes (refund step 1) */
.wpts-card-checks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 4px;
}
.wpts-card-check {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1.5px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  background: var(--wpts-bg);
  cursor: pointer;
  min-height: 56px;
  font-size: 0.92rem;
  transition: border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}
.wpts-card-check:hover {
  border-color: #c3cad4;
  background: #fcfdfe;
}
.wpts-card-check input { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }
.wpts-card-check__box {
  width: 20px; height: 20px;
  border: 1.5px solid var(--wpts-border);
  border-radius: 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--wpts-bg);
  flex-shrink: 0;
}
.wpts-card-check__box::after {
  content: "";
  width: 10px; height: 6px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translate(1px,-1px);
  opacity: 0;
}
.wpts-card-check input:checked ~ .wpts-card-check__box {
  background: var(--wpts-accent);
  border-color: var(--wpts-accent);
}
.wpts-card-check input:checked ~ .wpts-card-check__box::after { opacity: 1; }
.wpts-card-check:has(input:checked),
.wpts-card-check.is-checked {
  border-color: var(--wpts-accent);
  background: var(--wpts-accent-soft);
}

/* radio cards (OIC payment) */
.wpts-radio-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  margin-top: 4px;
}
.wpts-radio-card {
  position: relative;
  padding: 16px 18px;
  border: 1.5px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  background: var(--wpts-bg);
  cursor: pointer;
  display: block;
}
.wpts-radio-card input { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }
.wpts-radio-card__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--wpts-text);
  display: flex;
  align-items: center;
  gap: 10px;
}
.wpts-radio-card__title::before {
  content: "";
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--wpts-border);
  background: var(--wpts-bg);
  flex-shrink: 0;
  transition: border-color 120ms ease, background 120ms ease;
}
.wpts-radio-card__desc {
  font-size: 0.83rem;
  color: var(--wpts-muted);
  margin-top: 6px;
  padding-left: 28px;
}
.wpts-radio-card:has(input:checked),
.wpts-radio-card.is-selected {
  border-color: var(--wpts-accent);
  background: var(--wpts-accent-soft);
}
.wpts-radio-card:has(input:checked) .wpts-radio-card__title::before,
.wpts-radio-card.is-selected .wpts-radio-card__title::before {
  border-color: var(--wpts-accent);
  background: radial-gradient(circle, var(--wpts-accent) 38%, #fff 42%);
}

/* itemized vs standard toggle */
.wpts-segment {
  display: inline-flex;
  background: var(--wpts-surface);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  padding: 4px;
  gap: 2px;
  margin-bottom: 14px;
}
.wpts-segment button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--wpts-muted);
  font: inherit;
  font-weight: 600;
  font-size: 0.88rem;
  padding: 8px 14px;
  border-radius: 6px;
  cursor: pointer;
  min-height: 36px;
}
.wpts-segment button.is-active {
  background: var(--wpts-bg);
  color: var(--wpts-text);
  box-shadow: 0 1px 2px rgba(16,24,40,.06);
}

/* ----- buttons & actions ----- */
.wpts-actions,
.wpts-wizard-nav,
.wpts-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid var(--wpts-border-soft);
}
.wpts-actions--right,
.wpts-form-actions {
  justify-content: flex-end;
}
/* When prev button is hidden, push next/calculate to the right alone. */
.wpts-actions > [data-wpts-prev][hidden] + [data-wpts-next] { margin-left: auto; }

/* Buttons. Everything !important to beat WP themes that style native
   <button>, <input type="submit">, or .button with their own colors.
   Increased specificity via `.wpts-calc` ancestor + !important kill
   theme red backgrounds, red borders, and red focus outlines. */
.wpts-calc .wpts-btn,
.wpts-calc button.wpts-btn,
.wpts-calc input[type="submit"].wpts-btn {
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 1px solid transparent !important;
  font: inherit;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  padding: 0 18px !important;
  min-height: 44px !important;
  border-radius: var(--wpts-radius-sm) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  letter-spacing: -0.005em !important;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
  white-space: nowrap !important;
  text-decoration: none !important;
  color: var(--wpts-text) !important;
  background: var(--wpts-bg) !important;
  text-transform: none !important;       /* kill ALL-CAPS theme buttons */
  text-shadow: none !important;
  outline: none !important;
}

/* Primary buttons (Next / Calculate / See My Results / Save) */
.wpts-calc .wpts-btn--primary,
.wpts-calc .wpts-actions > [data-wpts-next],
.wpts-calc .wpts-form-actions > .wpts-btn,
.wpts-calc button.wpts-btn[type="submit"],
.wpts-calc input[type="submit"].wpts-btn {
  background: var(--wpts-accent) !important;
  color: #fff !important;
  border-color: var(--wpts-accent) !important;
  box-shadow: 0 1px 0 rgba(16,24,40,.05), 0 4px 12px -6px var(--wpts-accent) !important;
}
.wpts-calc .wpts-btn--primary:hover,
.wpts-calc .wpts-btn--primary:focus,
.wpts-calc .wpts-btn--primary:focus-visible,
.wpts-calc .wpts-actions > [data-wpts-next]:hover,
.wpts-calc .wpts-actions > [data-wpts-next]:focus,
.wpts-calc .wpts-actions > [data-wpts-next]:focus-visible,
.wpts-calc .wpts-form-actions > .wpts-btn:hover,
.wpts-calc .wpts-form-actions > .wpts-btn:focus,
.wpts-calc .wpts-form-actions > .wpts-btn:focus-visible,
.wpts-calc button.wpts-btn[type="submit"]:hover,
.wpts-calc button.wpts-btn[type="submit"]:focus,
.wpts-calc button.wpts-btn[type="submit"]:focus-visible,
.wpts-calc input[type="submit"].wpts-btn:hover,
.wpts-calc input[type="submit"].wpts-btn:focus,
.wpts-calc input[type="submit"].wpts-btn:focus-visible {
  background: var(--wpts-accent-dark) !important;
  border-color: var(--wpts-accent-dark) !important;
  color: #fff !important;
  outline: none !important;
}

/* Ghost (Back) buttons */
.wpts-calc .wpts-btn--ghost,
.wpts-calc .wpts-actions > [data-wpts-prev] {
  background: transparent !important;
  color: var(--wpts-accent) !important;
  border: 1px solid var(--wpts-accent) !important;
  box-shadow: none !important;
}
.wpts-calc .wpts-btn--ghost:hover,
.wpts-calc .wpts-btn--ghost:focus,
.wpts-calc .wpts-btn--ghost:focus-visible,
.wpts-calc .wpts-actions > [data-wpts-prev]:hover,
.wpts-calc .wpts-actions > [data-wpts-prev]:focus,
.wpts-calc .wpts-actions > [data-wpts-prev]:focus-visible {
  color: var(--wpts-accent-dark) !important;
  border-color: var(--wpts-accent-dark) !important;
  background: var(--wpts-accent-soft) !important;
  outline: none !important;
}

.wpts-calc .wpts-btn--block { width: 100% !important; }
.wpts-calc .wpts-btn[disabled] { opacity: 0.55 !important; cursor: not-allowed !important; box-shadow: none !important; }

/* ----- warning / info panels ----- */
.wpts-warn {
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  background: var(--wpts-warn-soft);
  border: 1px solid var(--wpts-warn-border);
  border-radius: var(--wpts-radius-sm);
  margin-top: 14px;
}
.wpts-warn__icon {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #f0c764;
  color: #5a3a00;
  font-weight: 700;
  font-size: 0.85rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.wpts-warn__body {
  font-size: 0.88rem;
  color: var(--wpts-warn);
  line-height: 1.45;
}
.wpts-warn__body strong { color: #5a3a00; }

/* Disqualifier (OIC step 2) reuses warn styling. */
.wpts-disqualifier {
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  background: var(--wpts-bad-soft);
  border: 1px solid #f3c5c5;
  border-radius: var(--wpts-radius-sm);
  margin-top: 14px;
  color: var(--wpts-bad);
  font-size: 0.88rem;
  line-height: 1.45;
}

/* ----- loader (center-center, transient) ----- */
.wpts-loader {
  background: var(--wpts-surface);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius);
  padding: 44px 28px 46px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 18px;
  margin-top: 20px;
  min-height: 220px;
}
.wpts-loader[hidden] { display: none; }
.wpts-spinner,
.wpts-loader__spinner {
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 4px solid #d3dbe7;
  border-top-color: var(--wpts-accent);
  animation: wpts-spin 900ms linear infinite;
  flex-shrink: 0;
}
.wpts-loader__title {
  font-weight: 700;
  font-size: 1rem;
  margin: 0 0 2px;
  color: var(--wpts-text);
}
.wpts-loader__text {
  font-size: 1rem;
  font-weight: 700;
  color: var(--wpts-text);
  margin: 0;
}
.wpts-loader__sub {
  font-size: 0.86rem;
  color: var(--wpts-muted);
  max-width: 50ch;
  margin: 0 auto;
  line-height: 1.5;
}
@keyframes wpts-spin {
  to { transform: rotate(360deg); }
}

/* ----- result ----- */
.wpts-result,
.wpts-results {
  margin-top: 22px;
  background: var(--wpts-surface);
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius);
  padding: 24px 26px;
}
.wpts-result__eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--wpts-muted);
  margin-bottom: 6px;
}
.wpts-result__headline,
.wpts-results__headline {
  font-family: var(--wpts-title-font);
  font-size: 1.35rem;       /* ~22px */
  font-weight: 700;
  color: var(--wpts-text);
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin: 0;
}
.wpts-result__amount {
  font-size: 2.1rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  color: var(--wpts-text);
  margin-top: 2px;
  display: block;
  line-height: 1.05;
}
.wpts-result__amount--good { color: var(--wpts-good); }
.wpts-result__amount--bad  { color: var(--wpts-bad); }

.wpts-result__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1px;
  background: var(--wpts-border-soft);
  border: 1px solid var(--wpts-border-soft);
  border-radius: var(--wpts-radius-sm);
  margin-top: 18px;
  overflow: hidden;
}
.wpts-result__stat {
  background: var(--wpts-bg);
  padding: 12px 14px;
}
.wpts-result__stat-label {
  font-size: 0.74rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wpts-muted);
}
.wpts-result__stat-value {
  font-size: 1.05rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--wpts-text);
  margin-top: 2px;
}

.wpts-result__note {
  margin-top: 16px;
  font-size: 0.82rem;
  color: var(--wpts-muted);
  line-height: 1.5;
}

/* legacy results__row from old templates */
.wpts-results__row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px dashed var(--wpts-border);
  font-variant-numeric: tabular-nums;
}
.wpts-results__row:last-child { border-bottom: 0; }

/* ----- brackets table ----- */
.wpts-brackets,
.wpts-bracket-table-wrap {
  margin-top: 18px;
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  overflow: hidden;
  background: var(--wpts-bg);
}
.wpts-brackets__head,
.wpts-brackets__row {
  display: grid;
  grid-template-columns: 0.6fr 1.5fr 1.1fr 1.1fr;
  gap: 12px;
  padding: 10px 14px;
  align-items: center;
  font-variant-numeric: tabular-nums;
}
.wpts-brackets__head {
  background: var(--wpts-surface);
  border-bottom: 1px solid var(--wpts-border);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wpts-muted);
}
.wpts-brackets__row {
  border-bottom: 1px solid var(--wpts-border-soft);
  font-size: 0.9rem;
}
.wpts-brackets__row:last-child { border-bottom: 0; }
.wpts-brackets__row--active {
  background: var(--wpts-accent-soft);
  position: relative;
}
.wpts-brackets__row--active::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--wpts-accent);
}
.wpts-brackets__rate {
  font-weight: 700;
  color: var(--wpts-text);
}
.wpts-brackets__row--inactive { color: var(--wpts-muted); }
.wpts-brackets__row--inactive .wpts-brackets__rate { color: #5c6b7a; }
.wpts-text-right { text-align: right; }

/* Legacy <table class="wpts-bracket-table"> from prior versions - keep it
   visually compatible while templates migrate to the new bracket grid. */
.wpts-bracket-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0;
  font-variant-numeric: tabular-nums;
  font-size: 0.9rem;
}
.wpts-bracket-table th,
.wpts-bracket-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--wpts-border-soft);
  text-align: right;
}
.wpts-bracket-table th:first-child,
.wpts-bracket-table td:first-child {
  text-align: left;
}
.wpts-bracket-table thead th {
  background: var(--wpts-surface);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wpts-muted);
  border-bottom: 1px solid var(--wpts-border);
}
.wpts-bracket-table tbody tr.is-active {
  background: var(--wpts-accent-soft);
  font-weight: 600;
}

/* breakdown list (wizards) */
.wpts-breakdown {
  margin-top: 18px;
  border: 1px solid var(--wpts-border);
  border-radius: var(--wpts-radius-sm);
  background: var(--wpts-bg);
  overflow: hidden;
}
.wpts-breakdown__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 16px;
  font-size: 0.9rem;
  border-bottom: 1px solid var(--wpts-border-soft);
}
.wpts-breakdown__row:last-child { border-bottom: 0; }
.wpts-breakdown__row--total {
  background: var(--wpts-surface);
  font-weight: 700;
  font-size: 0.95rem;
}
.wpts-breakdown__label { color: var(--wpts-text); }
.wpts-breakdown__sub { color: var(--wpts-muted); font-size: 0.78rem; font-weight: 400; margin-top: 2px; display: block; }
.wpts-breakdown__value {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--wpts-text);
  white-space: nowrap;
}
.wpts-breakdown__value--neg { color: var(--wpts-bad); }
.wpts-breakdown__value--pos { color: var(--wpts-good); }

/* ----- lead gate ----- */
.wpts-lead,
.wpts-lead-gate {
  position: relative;
  margin-top: 22px;
  background: var(--wpts-bg);
  border: 1.5px solid var(--wpts-accent);
  border-radius: var(--wpts-radius);
  padding: 24px 26px;
  box-shadow: 0 1px 2px rgba(16,24,40,.04), 0 12px 28px -16px rgba(39,76,120,.35);
}
.wpts-lead-gate[hidden] { display: none; }
.wpts-lead__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--wpts-accent-dark);
  background: var(--wpts-accent-soft);
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 12px;
}
.wpts-lead__eyebrow::before {
  content: "";
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'><path d='M5 7V5a3 3 0 0 1 6 0v2M4 7h8a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V8a1 1 0 0 1 1-1Z' stroke='%23074aa0' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}
.wpts-lead__title,
.wpts-lead-gate__title {
  font-family: var(--wpts-title-font);
  font-size: 1.17rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--wpts-title-color);
  letter-spacing: -0.005em;
}
.wpts-lead__sub {
  font-size: 0.88rem;
  color: var(--wpts-muted);
  margin-bottom: 16px;
  max-width: 56ch;
}
.wpts-lead__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 14px;
}
.wpts-lead__form .wpts-field--full { grid-column: 1 / -1; }
.wpts-lead__legal {
  grid-column: 1 / -1;
  font-size: 0.74rem;
  color: var(--wpts-muted);
  line-height: 1.45;
  margin-top: 4px;
}
.wpts-lead__legal a { color: var(--wpts-accent); text-decoration: underline; }

/* SMS / autodialer consent checkbox (gates the submit button) */
.wpts-lead__consent {
  grid-column: 1 / -1;
  margin-top: 4px;
}
.wpts-consent-check {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  cursor: pointer;
  font-size: 0.74rem;
  color: var(--wpts-muted);
  line-height: 1.45;
}
.wpts-consent-check input[type="checkbox"] {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  margin-top: 1px;
  accent-color: var(--wpts-accent);
  cursor: pointer;
}
.wpts-consent-check__text a { color: var(--wpts-accent); text-decoration: underline; }
/* Submit button, while consent is still required + unchecked */
.wpts-btn[data-wpts-consent-gated][disabled],
.wpts-btn[data-wpts-consent-gated][aria-disabled="true"] {
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(0.25);
}

/* error message */
.wpts-error {
  color: var(--wpts-bad);
  font-size: 0.88rem;
  margin-top: 8px;
}
.wpts-success {
  color: var(--wpts-good);
  font-weight: 600;
}

/* radio-group fallback (older OIC templates) */
.wpts-radio-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}
.wpts-radio-group .wpts-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 0.92rem;
  min-height: 44px;
  cursor: pointer;
}

/* disclaimer */
.wpts-disclaimer {
  font-size: 0.78rem;
  color: var(--wpts-muted);
  margin-top: 1rem;
  line-height: 1.5;
}

/* OIC inline progress label (legacy) - mapped to new progress style */
.wpts-oic-progress {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 1.25rem;
}
.wpts-oic-progress__bar {
  flex: 1;
  height: 6px;
  background: var(--wpts-border-soft);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.wpts-oic-progress__bar::after {
  content: "";
  display: block;
  height: 100%;
  background: var(--wpts-accent);
  border-radius: 999px;
  width: var(--wpts-oic-progress-pct, 0%);
  transition: width 250ms ease;
}
.wpts-oic-progress__label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--wpts-muted);
}

/* small utility */
.wpts-mb-0 { margin-bottom: 0 !important; }

/* ============================================================
   Wizard step transitions (defensive - wizard.js drives heights)
   ============================================================ */
[data-wpts-wizard],
.wpts-calc__body {
  position: relative;
  transition: height 280ms cubic-bezier(.2,.6,.2,1);
  will-change: height;
}
[data-wpts-step] {
  transition: opacity 200ms ease, transform 200ms ease;
}
[data-wpts-step].is-leaving { opacity: 0; transform: translateY(-4px); }
[data-wpts-step].is-entering { opacity: 0; transform: translateY(4px); }
.wpts-calc { scroll-margin-top: 24px; }

/* ============================================================
   Responsive
   - 900px: tablet, calc card breathing room
   - 640px: phone, single column, full-width buttons
   - 420px: small phone, tighter type & padding
   - 360px: minimum target
   ============================================================ */
@media (max-width: 900px) {
  .wpts-calc { padding: 26px 24px 28px; }
}
@media (max-width: 640px) {
  .wpts-calc { padding: 22px 18px 24px; border-radius: 12px; font-size: 15.5px; }
  .wpts-calc__head { flex-direction: column; gap: 6px; padding-bottom: 14px; margin-bottom: 18px; }
  .wpts-calc__title { font-size: 1.35rem; }
  .wpts-calc__subtitle { font-size: 0.86rem; }
  .wpts-step__title { font-size: 1.05rem; }
  .wpts-grid-2,
  .wpts-grid-3,
  .wpts-grid-4 { grid-template-columns: 1fr; }
  .wpts-result__stats { grid-template-columns: 1fr; }
  .wpts-radio-cards { grid-template-columns: 1fr; }
  .wpts-card-checks { grid-template-columns: 1fr 1fr; }
  .wpts-lead__form { grid-template-columns: 1fr; }
  .wpts-lead,
  .wpts-lead-gate { padding: 20px 18px; }
  .wpts-result,
  .wpts-results { padding: 20px 18px; }
  .wpts-brackets__head,
  .wpts-brackets__row { grid-template-columns: 0.55fr 1fr 1fr; padding: 10px 12px; gap: 8px; font-size: 0.84rem; }
  .wpts-brackets__cell--range { grid-column: 1 / -1; font-size: 0.78rem; color: var(--wpts-muted); padding-left: 0; }
  .wpts-actions,
  .wpts-wizard-nav,
  .wpts-form-actions { flex-direction: column-reverse; align-items: stretch; gap: 10px; }
  .wpts-actions .wpts-btn,
  .wpts-wizard-nav .wpts-btn,
  .wpts-form-actions .wpts-btn { width: 100%; }
  .wpts-result__headline { font-size: 1.2rem; }
  .wpts-result__amount { font-size: 1.85rem; }
  .wpts-loader { padding: 20px 18px; gap: 14px; min-height: 180px; }
  .wpts-spinner,
  .wpts-loader__spinner { width: 30px; height: 30px; }
  .wpts-breakdown__row { padding: 11px 14px; font-size: 0.86rem; gap: 12px; }
  .wpts-checks { gap: 6px 14px; }
}
@media (max-width: 420px) {
  .wpts-calc { padding: 18px 14px 20px; border-radius: 10px; }
  .wpts-calc__title { font-size: 1.22rem; }
  .wpts-card-checks { grid-template-columns: 1fr; }
  .wpts-result,
  .wpts-results { padding: 18px 14px; }
  .wpts-lead,
  .wpts-lead-gate { padding: 18px 14px; }
  .wpts-result__amount { font-size: 1.6rem; }
  .wpts-yearpill { padding: 5px 9px; font-size: 0.74rem; }
  .wpts-brackets__head,
  .wpts-brackets__row { padding: 9px 10px; font-size: 0.8rem; }
  .wpts-breakdown__row { padding: 10px 12px; }
}
@media (max-width: 360px) {
  .wpts-calc { padding: 16px 12px 18px; }
  .wpts-segment { display: flex; width: 100%; }
  .wpts-segment button { flex: 1; padding: 8px 8px; font-size: 0.84rem; }
  .wpts-result__amount { font-size: 1.45rem; }
}
