/* ══════════════════════════════════════════════════════
   ltc-query-ui.css — Enhanced Visual Layer
   長照補助查詢精靈 · 美化覆蓋層
   ══════════════════════════════════════════════════════ */

/* ── Design Tokens ── */
:root {
  --q-blue:      #2563EB;
  --q-blue-dk:   #1D4ED8;
  --q-blue-lt:   #EFF6FF;
  --q-blue-mid:  #BFDBFE;
  --q-blue-glow: rgba(37,99,235,.16);
  --q-indigo:    #6366F1;
  --q-green:     #16A34A;
  --q-green-lt:  #F0FDF4;
  --q-amber:     #D97706;
  --q-red:       #DC2626;
  --q-purple:    #7C3AED;

  --q-bg:        #EEF2FF;
  --q-card:      #FFFFFF;
  --q-border:    #E2E8F0;
  --q-border-a:  #93C5FD;
  --q-ink:       #0F172A;
  --q-ink2:      #1E293B;
  --q-muted:     #64748B;
  --q-muted2:    #94A3B8;

  --q-r-sm:  .625rem;
  --q-r:     .875rem;
  --q-r-lg:  1.125rem;

  --q-sh-sm:   0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --q-sh:      0 4px 14px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.04);
  --q-sh-hov:  0 8px 28px rgba(37,99,235,.13), 0 2px 6px rgba(0,0,0,.06);
  --q-sh-blue: 0 4px 16px rgba(37,99,235,.28);
  --q-sh-grn:  0 4px 16px rgba(22,163,74,.28);
}

/* ══════════════════════
   1. Background / Body
   ══════════════════════ */
body {
  background: var(--q-bg);
  background-image:
    radial-gradient(ellipse 90% 60% at  0%   0%, rgba(219,234,254,.65) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 100% 100%, rgba(233,213,255,.35) 0%, transparent 55%),
    radial-gradient(ellipse 50% 30% at  50%  80%, rgba(187,247,208,.25) 0%, transparent 55%);
}

/* ══════════════════════
   2. Topbar
   ══════════════════════ */
.wz-topbar {
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(37,99,235,.1);
  box-shadow: 0 1px 0 var(--q-border), 0 4px 20px rgba(0,0,0,.04);
  padding: .875rem 1.5rem;
}

.wz-brand {
  font-size: .9375rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--q-ink);
}
.wz-brand small {
  font-size: .8125rem;
  font-weight: 500;
  color: var(--q-muted);
}

.wz-back {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .35rem .7rem;
  border-radius: .5rem;
  background: var(--q-blue-lt);
  color: var(--q-blue);
  font-size: .8125rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .15s;
}
.wz-back:hover {
  background: var(--q-blue-mid);
  color: var(--q-blue-dk);
  text-decoration: none;
  gap: .5rem;
}

/* ══════════════════════
   3. Progress Wizard
   ══════════════════════ */
.wz-progress-wrap {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--q-border);
  padding: 1rem 1.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

.wz-progress-labels {
  margin-bottom: .65rem;
  gap: .2rem;
}

.wz-progress-label {
  font-size: .625rem;
  font-weight: 600;
  color: var(--q-muted2);
  padding: .2rem .45rem;
  border-radius: .375rem;
  transition: all .25s;
  white-space: nowrap;
}
.wz-progress-label.active {
  color: var(--q-blue);
  background: var(--q-blue-lt);
  font-weight: 800;
}
.wz-progress-label.done {
  color: var(--q-green);
  background: var(--q-green-lt);
}

.wz-progress-track {
  height: 5px;
  background: #E9EEF6;
  border-radius: 99px;
  overflow: hidden;
}
.wz-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--q-blue), var(--q-indigo));
  border-radius: 99px;
  transition: width .5s cubic-bezier(.4, 0, .2, 1);
  box-shadow: 0 1px 4px rgba(37,99,235,.35);
}

/* ══════════════════════
   4. Wrap & Step Container
   ══════════════════════ */
.wz-wrap {
  max-width: 740px;
  padding: 2rem 1.25rem 4.5rem;
}

.wz-step { display: none; }
.wz-step.active {
  display: block;
  animation: qStepIn .3s cubic-bezier(.4, 0, .2, 1);
  position: relative;
}
@keyframes qStepIn {
  from { opacity: 0; transform: translateY(14px) scale(.985); }
  to   { opacity: 1; transform: none; }
}

/* Decorative blur glow behind each step */
.wz-step.active::after {
  content: '';
  position: absolute;
  top: -2rem; right: -1rem;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(37,99,235,.09) 0%, transparent 70%);
  pointer-events: none;
  border-radius: 50%;
  z-index: -1;
}

/* ══════════════════════
   5. Step Header
   ══════════════════════ */
.wz-step-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .6875rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--q-blue);
  background: var(--q-blue-lt);
  padding: .3rem .85rem;
  border-radius: 99px;
  margin-bottom: .75rem;
  border: 1px solid var(--q-blue-mid);
}

/* Step-specific eyebrow icons */
#step1 .wz-step-eyebrow::before { content: '📍 '; }
#step2 .wz-step-eyebrow::before { content: '❤️ '; }
#step3 .wz-step-eyebrow::before { content: '📋 '; }
#step4 .wz-step-eyebrow::before { content: '🏠 '; }
#step5 .wz-step-eyebrow::before { content: '🧮 '; }
#step6 .wz-step-eyebrow::before { content: '✅ '; }

.wz-step-title {
  font-size: clamp(1.25rem, 4.5vw, 1.75rem);
  font-weight: 900;
  color: var(--q-ink);
  margin-bottom: .5rem;
  line-height: 1.2;
  letter-spacing: -.025em;
}

.wz-step-sub {
  font-size: .875rem;
  color: var(--q-muted);
  margin-bottom: 1.75rem;
  line-height: 1.65;
  max-width: 520px;
}

/* ══════════════════════
   6. Step 1 — County
   ══════════════════════ */
.wz-region {
  background: var(--q-card);
  border: 1px solid var(--q-border);
  border-radius: var(--q-r-lg);
  padding: 1.1rem 1.25rem;
  box-shadow: var(--q-sh-sm);
  margin-bottom: .875rem;
  transition: box-shadow .2s;
}
.wz-region:hover {
  box-shadow: var(--q-sh);
}

.wz-region-label {
  font-size: .6875rem;
  font-weight: 800;
  color: var(--q-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .65rem;
  padding-bottom: .5rem;
  border-bottom: 1.5px solid #F1F5F9;
}

.wz-county-grid { gap: .5rem; }

.wz-county-btn {
  padding: .45rem .95rem;
  border: 1.5px solid var(--q-border);
  border-radius: .5rem;
  background: #FAFBFF;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--q-ink2);
  cursor: pointer;
  transition: all .15s;
  box-shadow: var(--q-sh-sm);
}
.wz-county-btn:hover {
  border-color: var(--q-border-a);
  color: var(--q-blue);
  background: var(--q-blue-lt);
  transform: translateY(-2px);
  box-shadow: 0 3px 8px rgba(37,99,235,.1);
}
.wz-county-btn.selected {
  border-color: var(--q-blue);
  background: var(--q-blue);
  color: #fff;
  box-shadow: var(--q-sh-blue);
  transform: translateY(-1px);
}

/* ══════════════════════
   7. Step 2 — Care Cards
   ══════════════════════ */
.wz-care-grid { gap: 1rem; }

.wz-care-card {
  border: 1.5px solid var(--q-border);
  border-radius: var(--q-r-lg);
  background: var(--q-card);
  padding: 1.25rem 1.1rem 1.1rem;
  box-shadow: var(--q-sh-sm);
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: all .22s cubic-bezier(.4, 0, .2, 1);
  gap: .45rem;
}

/* Top accent stripe */
.wz-care-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--q-blue-mid), var(--q-indigo));
  opacity: 0;
  transition: opacity .22s;
}
/* Subtle corner glow */
.wz-care-card::after {
  content: '';
  position: absolute;
  top: -30%; right: -20%;
  width: 80px; height: 80px;
  background: radial-gradient(circle, rgba(37,99,235,.06) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

.wz-care-card:hover {
  border-color: var(--q-border-a);
  transform: translateY(-4px);
  box-shadow: var(--q-sh-hov);
}
.wz-care-card:hover::before { opacity: 1; }

.wz-care-card.selected {
  border-color: var(--q-blue);
  background: var(--q-blue-lt);
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), var(--q-sh);
  transform: translateY(-2px);
}
.wz-care-card.selected::before {
  opacity: 1;
  background: linear-gradient(90deg, var(--q-blue), var(--q-indigo));
}

.wz-care-card.multi-selected {
  border-color: var(--q-purple);
  background: #F5F3FF;
  box-shadow: 0 0 0 3px rgba(124,58,237,.12), var(--q-sh);
  transform: translateY(-2px);
}
.wz-care-card.multi-selected::before {
  opacity: 1;
  background: linear-gradient(90deg, var(--q-purple), #A855F7);
}

.wz-care-icon { font-size: 2.25rem; line-height: 1; margin-top: .1rem; }

.wz-care-name {
  font-size: 1rem;
  font-weight: 800;
  color: var(--q-ink);
  letter-spacing: -.01em;
}

.wz-care-desc {
  font-size: .8rem;
  color: var(--q-muted);
  line-height: 1.5;
}

.wz-care-tag {
  display: inline-flex;
  align-items: center;
  font-size: .65rem;
  font-weight: 700;
  background: #F1F5F9;
  color: var(--q-muted);
  padding: .2rem .65rem;
  border-radius: 99px;
  letter-spacing: .03em;
  margin-top: .05rem;
}
.wz-care-card.selected .wz-care-tag { background: #DBEAFE; color: #1D4ED8; }
.wz-care-card.multi-selected .wz-care-tag { background: #EDE9FE; color: #6D28D9; }

/* ══════════════════════
   8. Step 3 — Level Cards
   ══════════════════════ */
.wz-level-grid { gap: .75rem; }

.wz-level-card {
  border: 1.5px solid var(--q-border);
  border-left: 4px solid var(--q-border);
  border-radius: var(--q-r);
  background: var(--q-card);
  padding: 1rem 1.25rem;
  box-shadow: var(--q-sh-sm);
  gap: 1.25rem;
  cursor: pointer;
  transition: all .18s;
}
.wz-level-card:hover {
  transform: translateX(5px);
  box-shadow: var(--q-sh);
}

/* Color-coded left border by severity */
.wz-level-card:has(.wz-badge-light) { border-left-color: #93C5FD; }
.wz-level-card:has(.wz-badge-mid)   { border-left-color: #FCD34D; }
.wz-level-card:has(.wz-badge-heavy) { border-left-color: #FCA5A5; }
.wz-level-card:has(.wz-badge-limit) { border-left-color: #C4B5FD; }

.wz-level-card:hover:has(.wz-badge-light) { border-left-color: #3B82F6; }
.wz-level-card:hover:has(.wz-badge-mid)   { border-left-color: #F59E0B; }
.wz-level-card:hover:has(.wz-badge-heavy) { border-left-color: #EF4444; }
.wz-level-card:hover:has(.wz-badge-limit) { border-left-color: #7C3AED; }

.wz-level-card.selected {
  border-color: var(--q-blue);
  border-left-color: var(--q-blue);
  background: var(--q-blue-lt);
  box-shadow: 0 0 0 3px rgba(37,99,235,.1), var(--q-sh);
  transform: translateX(5px);
}

.wz-level-num {
  width: 46px;
  height: 46px;
  border-radius: .625rem;
  background: #F1F5F9;
  color: var(--q-muted);
  font-size: 1.05rem;
  font-weight: 900;
  flex-shrink: 0;
}
.wz-level-card.selected .wz-level-num {
  background: var(--q-blue);
  color: #fff;
  box-shadow: var(--q-sh-blue);
}

.wz-level-title {
  font-size: .9375rem;
  font-weight: 800;
  color: var(--q-ink);
  margin-bottom: .18rem;
  letter-spacing: -.01em;
}
.wz-level-desc  { font-size: .8125rem; color: var(--q-muted); line-height: 1.4; }

.wz-level-badge { font-size: .7rem; font-weight: 700; padding: .25rem .75rem; border-radius: 99px; }
.wz-badge-light { background: #DBEAFE; color: #1E40AF; }
.wz-badge-mid   { background: #FEF3C7; color: #92400E; }
.wz-badge-heavy { background: #FEE2E2; color: #B91C1C; }
.wz-badge-limit { background: #F3E8FF; color: #6B21A8; }

/* ══════════════════════
   9. Step 4 — Identity Cards
   ══════════════════════ */
.wz-id-grid { gap: .75rem; }

.wz-id-card {
  border: 1.5px solid var(--q-border);
  border-radius: var(--q-r-lg);
  background: var(--q-card);
  padding: 1.1rem 1.25rem;
  box-shadow: var(--q-sh-sm);
  gap: 1.25rem;
  cursor: pointer;
  transition: all .18s;
}
.wz-id-card:hover {
  border-color: var(--q-border-a);
  box-shadow: var(--q-sh-hov);
  transform: translateY(-3px);
}
.wz-id-card.selected {
  border-color: var(--q-blue);
  background: var(--q-blue-lt);
  box-shadow: 0 0 0 3px rgba(37,99,235,.12), var(--q-sh);
  transform: translateY(-2px);
}

.wz-id-icon { font-size: 2rem; }
.wz-id-name {
  font-size: 1rem;
  font-weight: 800;
  color: var(--q-ink);
  margin-bottom: .15rem;
  letter-spacing: -.01em;
}
.wz-id-desc { font-size: .8125rem; color: var(--q-muted); }
.wz-id-rate {
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--q-blue);
  white-space: nowrap;
}
.wz-id-card.selected .wz-id-rate { color: var(--q-blue-dk); }

/* Foreigner toggle */
.wz-extra-box {
  margin-top: 1.25rem;
  border-radius: var(--q-r);
  border: 1.5px solid #FDE68A;
  background: linear-gradient(135deg, #FFFBEB 0%, #FEF9C3 100%);
  padding: 1.1rem 1.25rem;
  box-shadow: 0 2px 8px rgba(217,119,6,.07);
}
.wz-extra-text strong { font-size: .9375rem; font-weight: 800; color: #78350F; }
.wz-extra-text small  { font-size: .8rem; color: #92400E; line-height: 1.45; }

/* ══════════════════════
   10. Step 5 — Service Picker
   ══════════════════════ */
.wz-svc-section {
  background: var(--q-card);
  border: 1px solid var(--q-border);
  border-radius: var(--q-r-lg);
  padding: 1.1rem 1.1rem .8rem;
  box-shadow: var(--q-sh-sm);
  margin-bottom: .875rem;
}
.wz-svc-section-title {
  font-size: .7rem;
  font-weight: 800;
  color: var(--q-muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid #F1F5F9;
}

.wz-svc-row {
  background: #FAFBFF;
  border: 1.5px solid var(--q-border);
  border-radius: .75rem;
  padding: .75rem 1rem;
  transition: all .15s;
}
.wz-svc-row:hover { border-color: var(--q-border-a); background: #F8FBFF; }
.wz-svc-row.has-qty { border-color: var(--q-blue); background: var(--q-blue-lt); }

.wz-svc-code {
  font-size: .65rem;
  color: var(--q-muted2);
  background: #F1F5F9;
  padding: .1rem .4rem;
  border-radius: .3rem;
  font-family: 'Courier New', monospace;
  letter-spacing: .03em;
}
.wz-svc-name-row { font-size: .9rem; font-weight: 700; color: var(--q-ink2); }
.wz-svc-price    { font-size: .8rem; color: var(--q-muted2); }
.wz-svc-subtotal { font-size: .9rem; font-weight: 800; color: var(--q-blue); min-width: 75px; }
.wz-svc-subtotal.zero { color: #CBD5E1; font-weight: 400; }

/* Qty stepper */
.wz-qty-wrap {
  border: 1.5px solid var(--q-border);
  border-radius: .625rem;
  overflow: hidden;
  transition: border-color .15s;
}
.wz-svc-row.has-qty .wz-qty-wrap { border-color: var(--q-blue); }
.wz-qty-btn {
  width: 2rem; height: 2rem;
  background: #F8FAFC;
  color: var(--q-muted);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: all .1s;
  flex-shrink: 0;
}
.wz-qty-btn:hover { background: var(--q-blue-lt); color: var(--q-blue); }
.wz-qty-input {
  width: 2.5rem; height: 2rem;
  border-left: 1.5px solid var(--q-border);
  border-right: 1.5px solid var(--q-border);
  border-top: none; border-bottom: none;
  text-align: center;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 800;
  color: var(--q-ink);
  background: #fff;
  -moz-appearance: textfield;
}
.wz-qty-input::-webkit-outer-spin-button,
.wz-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Running total bar */
.wz-running-total {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  border-top: 2px solid var(--q-border);
  box-shadow: 0 -6px 24px rgba(0,0,0,.08);
  padding: 1rem 1.5rem;
  border-radius: .875rem .875rem 0 0;
}
.wz-rt-label { font-size: .8125rem; font-weight: 600; color: var(--q-muted); margin-bottom: .1rem; }
.wz-rt-amount { font-size: 1.5rem; font-weight: 900; color: var(--q-ink); letter-spacing: -.02em; }

/* ══════════════════════
   11. Step 6 — Result
   ══════════════════════ */
.wz-result-hero {
  background: linear-gradient(135deg, #1E40AF 0%, #2563EB 45%, #6366F1 100%);
  border-radius: var(--q-r-lg);
  padding: 2rem 1.75rem;
  margin-bottom: 1.25rem;
  box-shadow: 0 10px 40px rgba(37,99,235,.32);
  position: relative;
  overflow: hidden;
  color: #fff;
}
/* Decorative blobs */
.wz-result-hero::before {
  content: '';
  position: absolute;
  top: -50%; right: -15%;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(255,255,255,.18) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.wz-result-hero::after {
  content: '';
  position: absolute;
  bottom: -40%; left: -10%;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(99,102,241,.35) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.wz-result-hero h2 {
  font-size: clamp(1.25rem, 4vw, 1.625rem);
  font-weight: 900;
  margin-bottom: .4rem;
  position: relative; z-index: 1;
  letter-spacing: -.025em;
}
.wz-result-hero p {
  font-size: .875rem;
  opacity: .85;
  position: relative; z-index: 1;
}

.wz-result-chips { position: relative; z-index: 1; margin-top: 1rem; gap: .5rem; }
.wz-chip {
  font-size: .7rem;
  font-weight: 700;
  padding: .3rem .85rem;
  background: rgba(255,255,255,.22);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 99px;
  color: #fff;
}

/* Status band */
.wz-status-band {
  border-radius: var(--q-r);
  font-size: .875rem;
  font-weight: 600;
  padding: .9rem 1.25rem;
  margin-bottom: 1.25rem;
}
.wz-status-band.ok   { background: #F0FDF4; border: 1.5px solid #86EFAC; color: #15803D; }
.wz-status-band.over { background: #FFF1F2; border: 1.5px solid #FCA5A5; color: #B91C1C; }
.wz-status-band.info { background: var(--q-blue-lt); border: 1.5px solid var(--q-blue-mid); color: #1D4ED8; }

/* Category result cards */
.wz-cat-cards { gap: 1rem; margin-bottom: 1.25rem; }

.wz-cat-card {
  background: var(--q-card);
  border: 1.5px solid var(--q-border);
  border-radius: var(--q-r-lg);
  padding: 1.1rem;
  box-shadow: var(--q-sh-sm);
  transition: all .2s;
}
.wz-cat-card:hover { transform: translateY(-3px); box-shadow: var(--q-sh); }

.wz-cat-card-icon { font-size: 1.75rem; margin-bottom: .5rem; }
.wz-cat-card-name {
  font-size: .75rem;
  font-weight: 800;
  color: var(--q-muted);
  margin-bottom: .65rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.wz-cat-bar-wrap {
  height: 7px;
  background: #F1F5F9;
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: .5rem;
}
.wz-cat-bar-fill {
  border-radius: 99px;
  background: linear-gradient(90deg, var(--q-blue), var(--q-indigo));
}
.wz-cat-bar-fill.over { background: linear-gradient(90deg, #F59E0B, #EF4444); }

.wz-cat-used  { font-size: 1.125rem; font-weight: 900; color: var(--q-ink); letter-spacing: -.01em; }
.wz-cat-limit { font-size: .75rem; color: var(--q-muted2); }
.wz-cat-remain { font-size: .75rem; margin-top: .25rem; font-weight: 600; }
.wz-cat-remain.ok   { color: var(--q-green); }
.wz-cat-remain.over { color: var(--q-red); }

/* Summary card */
.wz-summary-card {
  background: var(--q-card);
  border: 1.5px solid var(--q-border);
  border-radius: var(--q-r-lg);
  overflow: hidden;
  margin-bottom: 1.5rem;
  box-shadow: var(--q-sh);
}
.wz-summary-head {
  padding: 1rem 1.375rem;
  background: linear-gradient(135deg, #F8FAFF, #EFF6FF);
  border-bottom: 1px solid var(--q-border);
  font-size: .875rem;
  font-weight: 800;
  color: var(--q-ink2);
  letter-spacing: -.01em;
}
.wz-summary-body { padding: 1.25rem 1.375rem; }

.wz-summary-row {
  padding: .7rem 0;
  font-size: .9375rem;
  border-bottom: 1px solid #F8FAFC;
}
.wz-summary-row:last-child { border-bottom: none; }
.wz-summary-label { color: var(--q-muted); font-weight: 500; }
.wz-summary-value { font-weight: 800; color: var(--q-ink); }
.wz-summary-value.gov  { color: var(--q-green); font-size: 1rem; }
.wz-summary-value.self { font-size: 2rem; font-weight: 900; color: var(--q-ink); letter-spacing: -.03em; }
.wz-summary-value.warn { color: var(--q-red); }

/* ══════════════════════
   12. CTAs
   ══════════════════════ */
.wz-cta-grid { gap: .75rem; margin-bottom: 1.75rem; }

.wz-cta {
  padding: 1rem 1.5rem;
  border-radius: var(--q-r);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -.01em;
  text-decoration: none;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  cursor: pointer;
  transition: all .2s cubic-bezier(.4, 0, .2, 1);
}

.wz-cta.primary {
  background: linear-gradient(135deg, #3B82F6, #2563EB);
  color: #fff;
  box-shadow: var(--q-sh-blue);
}
.wz-cta.primary:hover {
  background: linear-gradient(135deg, #2563EB, #1D4ED8);
  box-shadow: 0 6px 22px rgba(37,99,235,.4);
  transform: translateY(-2px);
}

.wz-cta.secondary {
  background: var(--q-card);
  color: var(--q-muted);
  border: 2px solid var(--q-border);
  box-shadow: var(--q-sh-sm);
}
.wz-cta.secondary:hover {
  background: #F8FBFF;
  border-color: var(--q-border-a);
  color: var(--q-blue);
  transform: translateY(-1px);
}

.wz-cta.tel {
  background: linear-gradient(135deg, #22C55E, #16A34A);
  color: #fff;
  box-shadow: var(--q-sh-grn);
}
.wz-cta.tel:hover {
  background: linear-gradient(135deg, #16A34A, #15803D);
  box-shadow: 0 6px 22px rgba(22,163,74,.38);
  transform: translateY(-2px);
}

/* ══════════════════════
   13. Nav Buttons
   ══════════════════════ */
.wz-nav { margin-top: 2rem; gap: .875rem; }

.wz-nav-prev {
  padding: .85rem 1.25rem;
  border-radius: .75rem;
  background: var(--q-card);
  color: var(--q-muted);
  border: 1.5px solid var(--q-border);
  font-family: inherit;
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--q-sh-sm);
  transition: all .15s;
}
.wz-nav-prev:hover { background: #F8FBFF; border-color: var(--q-border-a); color: var(--q-blue); }

.wz-nav-next {
  flex: 1;
  padding: .9rem 1.5rem;
  border-radius: .75rem;
  background: linear-gradient(135deg, #3B82F6, #2563EB);
  color: #fff;
  border: none;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -.01em;
  cursor: pointer;
  box-shadow: var(--q-sh-blue);
  transition: all .2s cubic-bezier(.4, 0, .2, 1);
}
.wz-nav-next:hover:not(:disabled) {
  background: linear-gradient(135deg, #2563EB, #1D4ED8);
  box-shadow: 0 6px 22px rgba(37,99,235,.4);
  transform: translateY(-1px);
}
.wz-nav-next:disabled {
  background: #E2E8F0;
  color: #94A3B8;
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}

.wz-skip {
  font-family: inherit;
  background: none;
  border: none;
  color: var(--q-muted2);
  font-size: .8125rem;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .15s;
}
.wz-skip:hover { color: var(--q-muted); }

/* Restart */
.wz-restart { text-align: center; margin-top: 1rem; }
.wz-restart button {
  background: none;
  border: none;
  font-family: inherit;
  font-size: .875rem;
  color: var(--q-muted2);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .15s;
}
.wz-restart button:hover { color: var(--q-muted); }

/* ══════════════════════
   14. Footer Note
   ══════════════════════ */
#step6 > p:last-child {
  font-size: .75rem;
  color: var(--q-muted2);
  text-align: center;
  line-height: 1.75;
  margin-top: 1.5rem;
  padding: 1rem;
  background: rgba(255,255,255,.6);
  border-radius: var(--q-r);
  border: 1px solid var(--q-border);
}

/* ══════════════════════
   15. Responsive
   ══════════════════════ */
@media (max-width: 640px) {
  .wz-topbar { padding: .75rem 1rem; }
  .wz-progress-wrap { padding: .875rem 1rem; }
  .wz-progress-label { font-size: .55rem; padding: .15rem .3rem; }
  .wz-wrap { padding: 1.25rem 1rem 3.5rem; }
  .wz-step-title { letter-spacing: -.015em; }
  .wz-result-hero { padding: 1.5rem 1.25rem; }
  .wz-result-hero::before { width: 160px; height: 160px; }
  .wz-summary-value.self { font-size: 1.625rem; }
  .wz-running-total { padding: .875rem 1rem; }
}
@media (max-width: 400px) {
  .wz-progress-label { font-size: .5rem; padding: .1rem .25rem; }
  .wz-care-grid { grid-template-columns: 1fr; }
}
