/* homebuyer-readiness-score — extracted from inline <style> */
/* ---- Pillar tabs ---- */
.evvy-pillar-tabs {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.evvy-pillar-tab {
  flex: 1;
  min-width: 110px;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  background: var(--bs-body-bg, #fff);
  cursor: pointer;
  text-align: center;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--evvy-text-secondary, #666);
  transition: all 0.2s ease;
  position: relative;
}
.evvy-pillar-tab:hover {
  border-color: var(--cluster-dark);
  color: var(--cluster-dark);
}
.evvy-pillar-tab.active {
  background: var(--cluster-dark);
  color: #fff;
  border-color: var(--cluster-dark);
}
.evvy-pillar-tab .evvy-pillar-icon {
  display: block;
  font-size: 1.25rem;
  margin-bottom: 0.2rem;
}
.evvy-pillar-tab .evvy-pillar-status {
  position: absolute;
  top: -5px;
  right: -5px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--bs-body-bg, #fff);
  display: none;
}
.evvy-pillar-tab .evvy-pillar-status.visible {
  display: block;
}

/* ---- Pillar panels ---- */
.evvy-pillar-panel {
  display: none;
}
.evvy-pillar-panel.active {
  display: block;
}

/* ---- Chip toggles ---- */
.evvy-chip-row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.evvy-chip-row .evvy-chip {
  padding: 0.4rem 1rem;
  border-radius: 99px;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  background: var(--bs-body-bg, #fff);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--evvy-text-secondary, #666);
  cursor: pointer;
  transition: all 0.2s ease;
}
.evvy-chip-row .evvy-chip:hover {
  border-color: var(--cluster-dark);
  color: var(--cluster-dark);
}
.evvy-chip-row .evvy-chip.evvy-chip-active {
  background: var(--cluster-dark);
  border-color: var(--cluster-dark);
  color: #fff;
}

/* ---- Score gauge ---- */
.evvy-score-gauge {
  position: relative;
  width: 200px;
  height: 200px;
  margin: 0 auto 1rem;
}
.evvy-score-gauge svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}
.evvy-score-gauge .gauge-bg {
  fill: none;
  stroke: var(--evvy-border-color, #DEE2E6);
  stroke-width: 12;
}
.evvy-score-gauge .gauge-fill {
  fill: none;
  stroke-width: 12;
  stroke-linecap: round;
  transition: stroke-dashoffset 0.8s ease, stroke 0.4s ease;
}
.evvy-score-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.evvy-score-number {
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  color: var(--cluster-dark);
  font-variant-numeric: tabular-nums;
}
.evvy-score-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--evvy-text-secondary, #666);
  margin-top: 0.15rem;
}
.evvy-score-verdict {
  text-align: center;
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

/* ---- Traffic-light dashboard ---- */
.evvy-tl-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.evvy-tl-card {
  background: var(--bs-body-bg, #fff);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 0.875rem 0.625rem;
  text-align: center;
  transition: border-color 0.2s ease;
}
.evvy-tl-card.green { border-color: #22c55e; }
.evvy-tl-card.yellow { border-color: #eab308; }
.evvy-tl-card.red { border-color: #ef4444; }
.evvy-tl-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  margin: 0 auto 0.375rem;
}
.evvy-tl-dot.green { background: #22c55e; }
.evvy-tl-dot.yellow { background: #eab308; }
.evvy-tl-dot.red { background: #ef4444; }
.evvy-tl-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--evvy-text-secondary, #666);
  margin-bottom: 0.15rem;
}
.evvy-tl-score {
  font-size: 1.125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--evvy-text-primary, #333);
}
.evvy-tl-max {
  font-size: 0.6875rem;
  color: var(--evvy-text-secondary, #999);
}

/* ---- Summary text ---- */
.evvy-summary-text {
  background: var(--cluster-surface);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 1rem 1.25rem;
  font-size: 0.875rem;
  line-height: 1.6;
  margin-bottom: 1.25rem;
  color: var(--evvy-text-primary, #333);
}

/* ---- Action plan table ---- */
.evvy-action-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.8125rem;
  margin-bottom: 1.25rem;
}
.evvy-action-table th {
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
  color: var(--evvy-text-secondary, #666);
  padding: 0.5rem 0.75rem;
  border-bottom: 2px solid var(--evvy-border-color, #DEE2E6);
  text-align: left;
}
.evvy-action-table td {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
  vertical-align: top;
}
.evvy-action-priority {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  border-radius: 99px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
}
.evvy-action-priority.high { background: #fecaca; color: #991b1b; }
.evvy-action-priority.medium { background: #fef08a; color: #854d0e; }
.evvy-action-priority.low { background: #bbf7d0; color: #166534; }

/* ---- Savings roadmap ---- */
.evvy-roadmap-wrap {
  margin-bottom: 1.25rem;
}
.evvy-roadmap-bar-container {
  position: relative;
  height: 32px;
  background: var(--evvy-border-color, #DEE2E6);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.evvy-roadmap-bar-fill {
  height: 100%;
  border-radius: 8px;
  background: linear-gradient(90deg, var(--cluster-dark), color-mix(in srgb, var(--cluster-dark) 70%, #22c55e));
  transition: width 0.6s ease;
  min-width: 2px;
}
.evvy-roadmap-bar-label {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.6875rem;
  font-weight: 700;
  color: #fff;
}
.evvy-roadmap-months {
  display: grid;
  gap: 0.375rem;
  margin-top: 0.75rem;
}
.evvy-roadmap-row {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.8125rem;
}
.evvy-roadmap-row .rm-month {
  min-width: 70px;
  font-weight: 600;
  color: var(--evvy-text-secondary, #666);
  font-size: 0.75rem;
}
.evvy-roadmap-row .rm-bar {
  flex: 1;
  height: 10px;
  background: var(--evvy-border-color, #DEE2E6);
  border-radius: 6px;
  overflow: hidden;
}
.evvy-roadmap-row .rm-bar-fill {
  height: 100%;
  background: var(--cluster-dark);
  border-radius: 6px;
  transition: width 0.5s ease;
}
.evvy-roadmap-row .rm-amount {
  min-width: 80px;
  text-align: right;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  font-size: 0.75rem;
}

/* ---- Dark mode ---- */
[data-bs-theme="dark"] .evvy-pillar-tab {
  background: var(--evvy-gray-100, #1E1E1E);
}
[data-bs-theme="dark"] .evvy-pillar-tab.active {
  background: var(--cluster-dark);
  color: #fff;
}
[data-bs-theme="dark"] .evvy-chip-row .evvy-chip {
  background: var(--evvy-gray-100, #1E1E1E);
}
[data-bs-theme="dark"] .evvy-chip-row .evvy-chip.evvy-chip-active {
  background: var(--cluster-dark);
  color: #fff;
}
[data-bs-theme="dark"] .evvy-tl-card {
  background: var(--evvy-gray-100, #1E1E1E);
}
[data-bs-theme="dark"] .evvy-action-priority.high { background: #7f1d1d; color: #fecaca; }
[data-bs-theme="dark"] .evvy-action-priority.medium { background: #713f12; color: #fef08a; }
[data-bs-theme="dark"] .evvy-action-priority.low { background: #14532d; color: #bbf7d0; }
[data-bs-theme="dark"] .evvy-roadmap-bar-container {
  background: var(--evvy-gray-100, #333);
}
[data-bs-theme="dark"] .evvy-summary-text {
  background: var(--evvy-gray-100, #1E1E1E);
}

/* ---- Mobile ---- */
@media (max-width: 575.98px) {
  .evvy-pillar-tabs {
    gap: 0.35rem;
  }
  .evvy-pillar-tab {
    min-width: 0;
    padding: 0.5rem 0.35rem;
    font-size: 0.625rem;
  }
  .evvy-pillar-tab .evvy-pillar-icon {
    font-size: 1rem;
  }
  .evvy-tl-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .evvy-score-gauge {
    width: 160px;
    height: 160px;
  }
  .evvy-score-number {
    font-size: 2rem;
  }
  .evvy-action-table {
    font-size: 0.75rem;
  }
  .evvy-action-table th,
  .evvy-action-table td {
    padding: 0.375rem 0.5rem;
  }
}
/* ===== Dark-mode contrast fixes (cluster-dark backgrounds) ===== */
[data-bs-theme="dark"] .evvy-pillar-tab.active,
[data-bs-theme="dark"] .evvy-chip-row .evvy-chip.evvy-chip-active,
[data-bs-theme="dark"] .evvy-roadmap-bar-label { color: var(--evvy-dark-text); }
