/*
  SNAP ELIGIBILITY CALCULATOR 2026 — snap-calculator.css
  Paste into: Appearance > Customize > Additional CSS
  OR enqueue via child theme functions.php
*/

/* ── Reset scoped to calculator only ─────────────────────── */
.snap-calc-wrap *,
.snap-calc-wrap *::before,
.snap-calc-wrap *::after {
  box-sizing: border-box;
}

/* ── Design tokens ────────────────────────────────────────── */
:root {
  --snap-g900: #0D2318;
  --snap-g800: #173A29;
  --snap-g700: #1C4D34;
  --snap-g600: #1F6040;
  --snap-g500: #1A7A4C;
  --snap-g400: #22A066;
  --snap-g300: #4DC48A;
  --snap-g200: #A8E6C3;
  --snap-g100: #D6F5E7;
  --snap-g50:  #EEF9F4;
  --snap-n900: #0F1512;
  --snap-n700: #2E3D35;
  --snap-n500: #5A7065;
  --snap-n400: #7A9080;
  --snap-n300: #B0C4B8;
  --snap-n200: #D8E6DC;
  --snap-n100: #EDF3EF;
  --snap-n50:  #F7FAF8;
  --snap-red:  #D94040;
  --snap-r:    14px;
  --snap-rsm:  8px;
  --snap-sh-sm: 0 1px 3px rgba(0,0,0,.08);
  --snap-sh-md: 0 4px 16px rgba(0,0,0,.10);
}

/* ── Wrapper ──────────────────────────────────────────────── */
.snap-calc-wrap {
  max-width: 780px;
  margin: 0 auto;
  padding: 32px 20px 64px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
               'Helvetica Neue', Arial, sans-serif;
  font-size: 16px;
  color: var(--snap-n900);
  line-height: 1.5;
}

/* ── Header ───────────────────────────────────────────────── */
.snap-header {
  text-align: center;
  margin-bottom: 32px;
}
.snap-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--snap-g100);
  color: var(--snap-g600);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
}
.snap-badge::before { content: '●'; font-size: 7px; }

.snap-calc-wrap .snap-header h2 {
  font-size: clamp(1.55rem, 4vw, 2.15rem) !important;
  font-weight: 800 !important;
  letter-spacing: -.03em;
  color: var(--snap-g900) !important;
  line-height: 1.15 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
}
.snap-header h2 em { font-style: normal; color: var(--snap-g500); }

.snap-header p {
  font-size: 15px;
  color: var(--snap-n500);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.65;
}

/* ── Progress ─────────────────────────────────────────────── */
.snap-progress-meta {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--snap-n400);
  font-weight: 500;
  margin-bottom: 8px;
}
.snap-progress-meta strong { color: var(--snap-g600); }
.snap-progress-track {
  display: flex;
  gap: 6px;
  margin-bottom: 22px;
}
.snap-dot {
  flex: 1;
  height: 4px;
  background: var(--snap-n200);
  border-radius: 999px;
  transition: background .3s ease;
}
.snap-dot--done   { background: var(--snap-g400); }
.snap-dot--active { background: var(--snap-g500); }

/* ── Cards ────────────────────────────────────────────────── */
.snap-card {
  background: #fff;
  border: 1px solid var(--snap-n200);
  border-radius: var(--snap-r);
  padding: 28px 32px;
  box-shadow: var(--snap-sh-sm);
  display: none;
  animation: snapSlideUp .25s ease both;
}
.snap-card--active { display: block; }
@keyframes snapSlideUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.snap-card-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--snap-g500);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.snap-card-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--snap-g100);
}
.snap-card h2,
.snap-card > h2 {
  font-size: 19px !important;
  font-weight: 700 !important;
  color: var(--snap-g900) !important;
  letter-spacing: -.02em;
  line-height: 1.3 !important;
  margin: 0 0 20px !important;
  padding: 0 !important;
}
.snap-hint {
  font-size: 13px;
  color: var(--snap-n500);
  line-height: 1.6;
  margin: -8px 0 20px;
  padding: 10px 14px;
  background: var(--snap-g50);
  border-left: 3px solid var(--snap-g300);
  border-radius: 0 var(--snap-rsm) var(--snap-rsm) 0;
}

/* ── Fields ───────────────────────────────────────────────── */
.snap-field { margin-bottom: 18px; }
.snap-field:last-child { margin-bottom: 0; }
.snap-label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--snap-g900);
  line-height: 1.45;
  margin-bottom: 7px;
}
.snap-label-sub {
  display: block;
  font-weight: 400;
  font-size: 12px;
  color: var(--snap-n500);
  margin-top: 3px;
  line-height: 1.5;
}
.snap-req { color: var(--snap-red); margin-left: 2px; }

/* ── Select ───────────────────────────────────────────────── */
.snap-select-wrap { position: relative; }
.snap-select-wrap::after {
  content: '';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--snap-n500);
  pointer-events: none;
}

/* ── Base inputs ──────────────────────────────────────────── */
.snap-calc-wrap select,
.snap-calc-wrap input[type="number"] {
  display: block;
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--snap-n200);
  border-radius: var(--snap-rsm);
  font-family: inherit;
  font-size: 15px;
  font-weight: 500;
  color: var(--snap-g900);
  background: #fff;
  appearance: none;
  -webkit-appearance: none;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  height: auto;
  line-height: 1.5;
}
.snap-calc-wrap select:focus,
.snap-calc-wrap input[type="number"]:focus {
  border-color: var(--snap-g500);
  box-shadow: 0 0 0 3px rgba(26,122,76,.12);
}
/* Remove number spinners */
.snap-calc-wrap input[type="number"]::-webkit-inner-spin-button,
.snap-calc-wrap input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.snap-calc-wrap input[type="number"] { -moz-appearance: textfield; }

/* ── Dollar prefix input ──────────────────────────────────── */
.snap-input-prefix {
  position: relative;
  display: block;
}
.snap-prefix-sym {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 15px;
  font-weight: 600;
  color: var(--snap-n400);
  pointer-events: none;
  z-index: 1;
  line-height: 1;
}
.snap-input-prefix input {
  padding-left: 26px !important;
  width: 100%;
}

/* ── Income row ───────────────────────────────────────────── */
.snap-income-row {
  display: grid;
  grid-template-columns: 155px 1fr;
  gap: 10px;
  align-items: start;
}

/* ── Radio pills ──────────────────────────────────────────── */
.snap-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.snap-pills input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.snap-pills label {
  flex: 1;
  min-width: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 10px 16px;
  border: 1.5px solid var(--snap-n200);
  border-radius: var(--snap-rsm);
  font-size: 15px;
  font-weight: 600;
  color: var(--snap-n500);
  background: #fff;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  user-select: none;
  line-height: 1.4;
}
.snap-pills input[type="radio"]:checked + label {
  border-color: var(--snap-g500);
  background: var(--snap-g50);
  color: var(--snap-g700);
}
.snap-pills label:hover {
  border-color: var(--snap-g300);
  background: var(--snap-g50);
}
.snap-pills input[type="radio"]:focus-visible + label {
  outline: 2px solid var(--snap-g500);
  outline-offset: 2px;
}

/* ── Checkboxes ───────────────────────────────────────────── */
.snap-check-list { display: flex; flex-direction: column; gap: 8px; }
.snap-check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: #fff;
  border: 1.5px solid var(--snap-n200);
  border-radius: var(--snap-rsm);
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
  line-height: 1.4;
}
.snap-check-item:hover { border-color: var(--snap-g300); }
.snap-check-item.snap-checked {
  border-color: var(--snap-g500);
  background: var(--snap-g50);
}
.snap-checkbox {
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 2px solid var(--snap-n300);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, border-color .15s;
  background: #fff;
  margin-top: 1px;
}
.snap-check-item.snap-checked .snap-checkbox {
  background: var(--snap-g500);
  border-color: var(--snap-g500);
}
.snap-check-title {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--snap-g900);
  line-height: 1.4;
}
.snap-check-desc {
  display: block;
  font-size: 12px;
  color: var(--snap-n500);
  margin-top: 3px;
  line-height: 1.5;
}

/* ── Expense grid ─────────────────────────────────────────── */
.snap-expense-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 14px;
  margin-bottom: 4px;
}
.snap-expense-grid .snap-field { margin-bottom: 0; }

/* ── Info box ─────────────────────────────────────────────── */
.snap-info-box {
  background: var(--snap-g50);
  border: 1px solid var(--snap-g200);
  border-radius: var(--snap-rsm);
  padding: 10px 14px;
  font-size: 13px;
  color: var(--snap-g800);
  line-height: 1.6;
  margin-top: 8px;
}
.snap-info-box strong { color: var(--snap-g600); }

/* ── Errors ───────────────────────────────────────────────── */
.snap-field-error {
  font-size: 12px;
  color: var(--snap-red);
  margin-top: 5px;
  line-height: 1.4;
}
.snap-calc-wrap input.snap-has-error,
.snap-calc-wrap select.snap-has-error {
  border-color: var(--snap-red) !important;
}

/* ── Divider ──────────────────────────────────────────────── */
.snap-divider {
  border: none;
  border-top: 1px solid var(--snap-n100);
  margin: 20px 0;
}

/* ── Navigation ───────────────────────────────────────────── */
.snap-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 26px;
  gap: 10px;
}
.snap-calc-wrap .snap-btn-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--snap-n500);
  background: transparent;
  border: 1.5px solid var(--snap-n200);
  border-radius: var(--snap-rsm);
  padding: 10px 18px;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  line-height: 1;
}

.snap-calc-wrap .snap-btn-back:hover {
  border-color: var(--snap-g300);
  color: var(--snap-g600);
  background: transparent;
}
.snap-btn-next {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  background: var(--snap-g500);
  border: none;
  border-radius: var(--snap-rsm);
  padding: 11px 24px;
  cursor: pointer;
  transition: background .15s, transform .1s;
  box-shadow: 0 3px 10px rgba(26,122,76,.28);
  margin-left: auto;
  line-height: 1;
}
.snap-btn-next:hover  { background: var(--snap-g600); }
.snap-btn-next:active { transform: scale(.98); }
.snap-btn-next--cta   { padding: 12px 28px; font-size: 15px; }

/* ── Result ───────────────────────────────────────────────── */
.snap-result {
  background: #fff;
  border: 1px solid var(--snap-n200);
  border-radius: var(--snap-r);
  overflow: hidden;
  box-shadow: var(--snap-sh-md);
  animation: snapSlideUp .3s ease both;
}
.snap-result-hero {
  background: var(--snap-g800);
  padding: 40px 36px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.snap-result-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(26,122,76,.4) 0%, transparent 60%);
  pointer-events: none;
}
.snap-result-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--snap-g300);
  margin-bottom: 10px;
  position: relative;
}
.snap-result-amount {
  font-size: clamp(2.8rem, 9vw, 5rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1;
  margin-bottom: 6px;
  position: relative;
}
.snap-dollar {
  color: var(--snap-g300);
  font-size: .52em;
  vertical-align: super;
}
.snap-result-per {
  font-size: 14px;
  color: rgba(255,255,255,.6);
  position: relative;
}
.snap-result-body { padding: 28px 32px; }
.snap-tests-wrap { text-align: center; margin-bottom: 18px; }
.snap-test-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 12px;
}
.snap-test-pill {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
}
.snap-test-pill--pass { background: var(--snap-g100); color: var(--snap-g700); }
.snap-test-pill--fail { background: #FEE2E2; color: #B91C1C; }
.snap-test-pill--skip { background: var(--snap-n100); color: var(--snap-n500); }
.snap-result-msg {
  font-size: 15px;
  color: var(--snap-n700);
  line-height: 1.65;
  margin: 0;
}
.snap-result-msg--ineligible { color: var(--snap-red); }

/* ── Breakdown ────────────────────────────────────────────── */
.snap-breakdown {
  background: var(--snap-n50);
  border: 1px solid var(--snap-n200);
  border-radius: var(--snap-rsm);
  overflow: hidden;
  margin: 18px 0 16px;
}
.snap-breakdown-header {
  padding: 9px 14px;
  background: var(--snap-n100);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--snap-n500);
}
.snap-breakdown-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 14px;
  font-size: 13px;
  color: var(--snap-n700);
  border-top: 1px solid var(--snap-n200);
}
.snap-breakdown-row:first-child { border-top: none; }
.snap-breakdown-row--total {
  font-weight: 700;
  color: var(--snap-g800);
  background: var(--snap-g50);
  border-top: 1px solid var(--snap-g200) !important;
}
.snap-breakdown-val {
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  margin-left: 8px;
}
.snap-breakdown-row--total .snap-breakdown-val {
  font-size: 13px;
  color: var(--snap-g600);
}
.snap-result-note {
  font-size: 12px;
  color: var(--snap-n500);
  line-height: 1.65;
  margin-bottom: 20px;
  padding: 10px 14px;
  background: var(--snap-n50);
  border-radius: var(--snap-rsm);
  border: 1px solid var(--snap-n200);
}
.snap-result-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none !important;
  font-family: inherit;
  font-size: 15px;
  font-weight: 700;
  color: #fff !important;
  background: var(--snap-g500);
  border-radius: var(--snap-rsm);
  padding: 13px 24px;
  text-align: center;
  box-shadow: 0 3px 12px rgba(26,122,76,.28);
  transition: background .15s;
  margin-bottom: 10px;
}
.snap-result-cta:hover { background: var(--snap-g600); }
.snap-restart {
  display: block;
  width: 100%;
  text-align: center;
  font-family: inherit;
  font-size: 13px;
  color: var(--snap-n400);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: underline;
  padding: 4px 0;
  transition: color .15s;
}
.snap-restart:hover { color: var(--snap-g600); }

#snap-calc-top {
  scroll-margin-top: 80px;
}

.snap-restart {
  background: none;
  border: none;
  padding: 0;
  margin-top: 10px;
  color: #6b7280;
  font-size: 14px;
  cursor: pointer;
  display: inline; /* 👈 important */
}

.snap-restart:hover {
  background: none;   /* 👈 remove gray box */
  color: #111827;     /* darker on hover */
  text-decoration: underline;
}




/* ── Mobile ───────────────────────────────────────────────── */
@media (max-width: 600px) {
  .snap-card       { padding: 20px 16px; }
  .snap-result-body { padding: 20px 16px; }
  .snap-result-hero { padding: 28px 16px; }
  .snap-income-row  { grid-template-columns: 1fr; gap: 8px; }
  .snap-expense-grid { grid-template-columns: 1fr; gap: 12px; }
  .snap-pills       { flex-direction: column; }
  .snap-pills label { justify-content: flex-start; }
  .snap-btn-next    { padding: 11px 18px; }
}
@media (max-width: 380px) {
  .snap-calc-wrap  { padding: 20px 14px 48px; }
  .snap-header h1  { font-size: 1.35rem !important; }
}
