/* =============================================================================
   components.css — reusable Structural Clarity components
   search bar · star rating · Average Price badge · listing card · stepper ·
   locked panel. Loaded after footer.css, before inline page <style>.
   ============================================================================ */

/* ---- ZIP / address search ------------------------------------------------- */
.search {
  display: flex; gap: var(--space-2);
  background: var(--input-bg);
  border: 1.5px solid var(--input-border);
  border-radius: var(--border-radius-full);
  padding: var(--space-2);
  box-shadow: var(--shadow-sm);
}
.search:focus-within { border-color: var(--color-border-focus); box-shadow: var(--shadow-focus); }
.search__field { display: flex; align-items: center; gap: var(--space-2); flex: 1; padding-left: var(--space-3); min-width: 0; }
.search__field svg { color: var(--color-text-tertiary); flex-shrink: 0; }
.search__input { flex: 1; min-width: 0; border: none; background: transparent; padding: var(--space-2) 0; }
.search__input:focus { outline: none; }
.search__select { border: none; background: transparent; color: var(--color-text-secondary); border-left: 1px solid var(--color-border-primary); padding-left: var(--space-3); padding-right: var(--space-2); }
.search__select:focus { outline: none; }
.search--hero { padding: var(--space-2); font-size: var(--font-size-md); }
.search--hero .search__input { padding-block: var(--space-3); }

.search--compact { border-radius: var(--border-radius-md); padding: var(--space-1); box-shadow: none; }
.search--compact .search__input { padding-block: var(--space-2); }

@media (max-width: 560px) {
  .search { flex-direction: column; border-radius: var(--border-radius-lg); }
  .search__field { border-bottom: 1px solid var(--color-border-secondary); padding-bottom: var(--space-2); }
  .search__select { border-left: none; padding-left: var(--space-3); }
  .search .btn { width: 100%; }
}

/* ---- Star rating ---------------------------------------------------------- */
.rating { display: inline-flex; align-items: center; gap: var(--space-2); }
.rating__stars { position: relative; display: inline-block; line-height: 0; color: var(--rating-star-empty); }
.rating__stars svg { display: inline-block; }
.rating__fill { position: absolute; inset: 0; overflow: hidden; white-space: nowrap; color: var(--rating-star); }
.rating__num { font-weight: var(--font-weight-semibold); font-size: var(--font-size-sm); color: var(--color-text-primary); }
.rating__count { font-size: var(--font-size-sm); color: var(--color-text-secondary); }

/* interactive (review form) */
.rating-input { display: inline-flex; gap: var(--space-1); }
.rating-input button { color: var(--rating-star-empty); line-height: 0; padding: var(--space-1); border-radius: var(--border-radius-sm); transition: transform var(--duration-fast) var(--easing-out); }
.rating-input button[aria-pressed="true"], .rating-input button.is-on { color: var(--rating-star); }
.rating-input button:hover { transform: scale(1.12); }

/* ---- Average Price badge -------------------------------------------------- */
.price-band {
  display: inline-flex; flex-direction: column; gap: 2px;
  background: var(--price-band-bg); color: var(--price-band-text);
  border-radius: var(--border-radius-md); padding: var(--space-2) var(--space-3);
}
.price-band__label { font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: var(--letter-spacing-wide); font-weight: var(--font-weight-semibold); opacity: 0.85; }
.price-band__range { font-family: var(--font-family-display); font-weight: var(--font-weight-bold); font-size: var(--font-size-md); line-height: 1.1; }
.price-band__sample { font-size: var(--font-size-xs); color: var(--color-text-secondary); }
.price-band--empty { background: var(--color-bg-tertiary); color: var(--color-text-secondary); }
.price-band--empty .price-band__range { font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); }

.price-breakdown { display: grid; gap: var(--space-3); }
.price-breakdown__row { display: grid; grid-template-columns: 1fr auto; gap: var(--space-3); align-items: center; padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-border-secondary); }
.price-breakdown__row:last-child { border-bottom: 0; padding-bottom: 0; }
.price-breakdown__svc { font-weight: var(--font-weight-medium); }
.price-breakdown__bar { grid-column: 1 / -1; height: 6px; border-radius: var(--border-radius-full); background: var(--color-bg-tertiary); overflow: hidden; }
.price-breakdown__bar span { display: block; height: 100%; background: var(--color-accent-secondary); border-radius: inherit; }

/* ---- Listing card --------------------------------------------------------- */
.listing {
  display: grid; gap: var(--space-4);
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: var(--border-radius-md); padding: var(--space-5);
  transition: border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);
}
.listing:hover { border-color: var(--color-accent-primary); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.listing__head { display: flex; gap: var(--space-3); align-items: flex-start; }
.listing__logo {
  width: 52px; height: 52px; flex-shrink: 0; border-radius: var(--border-radius-md);
  background: var(--color-accent-primary-soft); color: var(--coverage-badge-text);
  display: grid; place-items: center; font-family: var(--font-family-display);
  font-weight: var(--font-weight-bold); font-size: var(--font-size-lg);
}
.listing__title { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }
.listing__name { font-family: var(--font-family-display); font-weight: var(--font-weight-bold); font-size: var(--font-size-lg); line-height: var(--line-height-snug); }
.listing__name a { color: var(--color-text-primary); }
.listing__name a:hover { color: var(--color-accent-primary); text-decoration: none; }
.listing__services { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.listing__meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3) var(--space-4); }
.listing__foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-3); }
.listing__actions { display: flex; gap: var(--space-2); margin-left: auto; }

/* ---- Multi-step form shell ------------------------------------------------ */
.stepper { display: grid; gap: var(--space-5); }
.stepper__progress { display: flex; align-items: center; gap: var(--space-2); }
.stepper__dot { flex: 1; height: 6px; border-radius: var(--border-radius-full); background: var(--color-bg-tertiary); transition: background var(--duration-normal) var(--easing-out); }
.stepper__dot.is-done { background: var(--color-accent-primary); }
.stepper__dot.is-current { background: var(--color-accent-secondary); }
.stepper__count { font-size: var(--font-size-sm); color: var(--color-text-secondary); font-weight: var(--font-weight-medium); }
.step { display: none; }
.step.is-active { display: grid; gap: var(--space-4); }
.step__title { font-size: var(--font-size-xl); }
.step__nav { display: flex; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-2); }
.choice-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.choice {
  display: flex; gap: var(--space-3); align-items: center; text-align: left;
  border: 1.5px solid var(--input-border); border-radius: var(--border-radius-md);
  padding: var(--space-4); background: var(--input-bg); transition: border-color var(--duration-fast) var(--easing-out), background var(--duration-fast) var(--easing-out);
}
.choice:hover { border-color: var(--color-accent-primary); }
.choice[aria-pressed="true"], .choice.is-selected { border-color: var(--color-accent-primary); background: var(--color-accent-primary-soft); }
.choice__label { font-weight: var(--font-weight-medium); }
.choice__hint { font-size: var(--font-size-sm); color: var(--color-text-secondary); }

/* ---- Locked contact panel (the pay gate) ---------------------------------- */
.locked {
  position: relative; border: 1.5px solid var(--lock-accent);
  border-radius: var(--border-radius-lg); overflow: hidden;
}
.locked__redacted { padding: var(--space-6); display: grid; gap: var(--space-3); filter: blur(6px); user-select: none; pointer-events: none; }
.locked__redacted .bar { height: 14px; border-radius: var(--border-radius-sm); background: var(--color-bg-tertiary); }
.locked__redacted .bar.w-60 { width: 60%; } .locked__redacted .bar.w-40 { width: 40%; } .locked__redacted .bar.w-80 { width: 80%; }
.locked__overlay {
  position: absolute; inset: 0; background: var(--lock-overlay-bg);
  display: grid; place-items: center; text-align: center; padding: var(--space-5); gap: var(--space-3);
}
.locked__overlay .lock-icon { color: var(--lock-accent); }
.locked__price { font-family: var(--font-family-display); font-weight: var(--font-weight-bold); font-size: var(--font-size-2xl); color: #fff; }
.locked__note { color: color-mix(in srgb, #fff 78%, transparent); font-size: var(--font-size-sm); max-width: 32ch; margin-inline: auto; }

/* ---- How-it-works steps --------------------------------------------------- */
.steps { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); counter-reset: step; }
.step-card { display: grid; gap: var(--space-2); }
.step-card__num { width: 40px; height: 40px; border-radius: var(--border-radius-md); background: var(--color-accent-primary); color: #fff; display: grid; place-items: center; font-family: var(--font-family-display); font-weight: var(--font-weight-bold); }
.step-card h3 { font-size: var(--font-size-md); }
.step-card p { color: var(--color-text-secondary); font-size: var(--font-size-sm); }

/* ---- Trust strip ---------------------------------------------------------- */
.trust-strip { display: flex; flex-wrap: wrap; gap: var(--space-6); justify-content: center; text-align: center; }
.trust-stat { display: grid; gap: 2px; }
.trust-stat__n { font-family: var(--font-family-display); font-weight: var(--font-weight-bold); font-size: var(--font-size-xl); color: var(--color-text-primary); }
.trust-stat__l { font-size: var(--font-size-sm); color: var(--color-text-secondary); }

/* ---- Empty state ---------------------------------------------------------- */
.empty-state { display: grid; gap: var(--space-3); justify-items: center; text-align: center; padding: var(--space-8) var(--space-5); border: 1px dashed var(--color-border-primary); border-radius: var(--border-radius-lg); }
.empty-state__icon { color: var(--color-text-tertiary); }
