/* credit-card-payoff-calculator — extracted from inline <style> */
.ccpo-mode-inputs { margin-top: 1rem; }
.ccpo-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.ccpo-callout {
  background: #FFF3CD;
  border: 1px solid #FFECB5;
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 1.25rem 1.5rem;
  margin-top: 1.25rem;
  display: none;
}
.ccpo-callout-icon {
  font-size: 1.25rem;
  margin-right: 0.5rem;
  vertical-align: -2px;
}
.ccpo-callout-title {
  font-weight: 700;
  font-size: 0.9375rem;
  color: #664D03;
  margin-bottom: 0.5rem;
}
.ccpo-callout-body {
  font-size: 0.8125rem;
  color: #664D03;
  line-height: 1.5;
}
.ccpo-callout-body strong {
  font-weight: 700;
}
[data-bs-theme="dark"] .ccpo-callout {
  background: color-mix(in srgb, #FFC107 12%, var(--evvy-gray-100, #1E1E1E));
  border-color: color-mix(in srgb, #FFC107 25%, transparent);
}
[data-bs-theme="dark"] .ccpo-callout-title,
[data-bs-theme="dark"] .ccpo-callout-body { color: #FFE69C; }
.ccpo-impact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-top: 1.25rem;
}
.ccpo-impact-card {
  background: var(--cluster-surface, #F8EDEB);
  border: 1px solid color-mix(in srgb, var(--cluster-dark) 15%, transparent);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 0.875rem;
  text-align: center;
}
.ccpo-impact-card-title {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--evvy-text-secondary);
  margin-bottom: 0.35rem;
}
.ccpo-impact-card-value {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--cluster-dark);
}
.ccpo-impact-card-sub {
  font-size: 0.6875rem;
  color: var(--evvy-text-secondary);
  margin-top: 0.15rem;
}
[data-bs-theme="dark"] .ccpo-impact-card {
  background: color-mix(in srgb, var(--cluster-dark) 12%, var(--evvy-gray-100, #1E1E1E));
}
/* Amortization table (premium) */
.ccpo-amort-wrap {
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  margin-top: 1.25rem;
}
.ccpo-amort-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}
.ccpo-amort-table thead { position: sticky; top: 0; z-index: 1; }
.ccpo-amort-table th {
  background: var(--cluster-dark);
  color: var(--cluster-text, #fff);
  padding: 0.5rem 0.6rem;
  text-align: right;
  font-weight: 600;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ccpo-amort-table th:first-child { text-align: center; border-radius: 8px 0 0 0; }
.ccpo-amort-table th:last-child { border-radius: 0 8px 0 0; }
.ccpo-amort-table td {
  padding: 0.4rem 0.6rem;
  text-align: right;
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
  font-variant-numeric: tabular-nums;
}
.ccpo-amort-table td:first-child { text-align: center; font-weight: 600; }
.ccpo-amort-table tbody tr:hover {
  background: color-mix(in srgb, var(--cluster-dark) 4%, transparent);
}
[data-bs-theme="dark"] .ccpo-amort-table th { color: #1a1a2e; }
/* Payoff curve SVG (premium) */
.ccpo-chart-wrap {
  margin-top: 1.25rem;
  background: var(--bs-body-bg, #fff);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 1rem 1rem 0.5rem;
}
.ccpo-chart-wrap svg { width: 100%; height: auto; display: block; }
[data-bs-theme="dark"] .ccpo-chart-wrap {
  background: var(--evvy-gray-100, #1E1E1E);
}
/* Multi-card comparison (premium) */
.ccpo-card-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr auto;
  gap: 0.5rem;
  align-items: end;
  margin-bottom: 0.5rem;
}
.ccpo-card-row input {
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: 8px;
  font-size: 0.8125rem;
  background: var(--bs-body-bg, #fff);
  color: var(--evvy-text-primary, #1B1B1B);
}
.ccpo-card-row input:focus {
  outline: none;
  border-color: var(--cluster-dark);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cluster-dark) 15%, transparent);
}
.ccpo-card-header {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr auto;
  gap: 0.5rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--evvy-text-secondary);
  padding-bottom: 0.25rem;
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
  margin-bottom: 0.5rem;
}
.ccpo-card-remove {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: none;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: 6px;
  color: var(--evvy-text-secondary);
  cursor: pointer;
  font-size: 0.875rem;
  transition: all 0.15s ease;
}
.ccpo-card-remove:hover { color: #dc3545; border-color: #dc3545; }
.ccpo-mc-add-btn {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.4rem 1rem;
  font-size: 0.8125rem; font-weight: 600;
  border: 1.5px dashed var(--cluster-dark);
  border-radius: var(--bs-border-radius-pill);
  background: none; color: var(--cluster-dark);
  cursor: pointer; transition: all 0.15s ease;
}
.ccpo-mc-add-btn:hover { background: color-mix(in srgb, var(--cluster-dark) 8%, transparent); }
.ccpo-mc-result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 1rem;
}
.ccpo-mc-result-card {
  background: var(--bs-body-bg, #fff);
  border: 1.5px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 1rem;
  text-align: center;
}
.ccpo-mc-result-card.winner { border-color: var(--cluster-dark); }
.ccpo-mc-result-title {
  font-size: 0.75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
  color: var(--evvy-text-secondary);
  margin-bottom: 0.5rem;
}
.ccpo-mc-result-value {
  font-size: 1.35rem; font-weight: 800;
  color: var(--cluster-dark);
}
.ccpo-mc-result-sub {
  font-size: 0.75rem;
  color: var(--evvy-text-secondary);
  margin-top: 0.25rem;
}
[data-bs-theme="dark"] .ccpo-mc-result-card { background: var(--evvy-gray-100, #1E1E1E); }
.ccpo-error-msg {
  background: #F8D7DA;
  border: 1px solid #F5C2C7;
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 0.875rem 1.25rem;
  font-size: 0.8125rem;
  color: #842029;
  display: none;
  margin-top: 1rem;
}
[data-bs-theme="dark"] .ccpo-error-msg {
  background: color-mix(in srgb, #dc3545 12%, var(--evvy-gray-100, #1E1E1E));
  border-color: color-mix(in srgb, #dc3545 25%, transparent);
  color: #EA868F;
}
@media (max-width: 575.98px) {
  .ccpo-stat-grid { grid-template-columns: 1fr 1fr; }
  .ccpo-impact-grid { grid-template-columns: 1fr; }
  .ccpo-card-row { grid-template-columns: 1fr 1fr; }
  .ccpo-card-header { display: none; }
  .ccpo-mc-result-grid { grid-template-columns: 1fr; }
}
