/* ============================================
   Home Page — Rates Dashboard Styles
   ============================================ */

/* ── Quick Nav ── */
.quick-nav .card { text-align: center; }
.quick-nav .card__icon { margin: 0 auto 1rem; }

/* ── Rates Status Bar ── */
.rates-status {
  display: flex; align-items: center; gap: 0.6rem;
  font-size: 0.85rem; color: var(--color-text-muted);
  margin-bottom: 1.25rem;
}
.rates-status__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--color-text-muted); flex-shrink: 0;
  transition: background var(--transition);
}
.rates-status__dot.live { background: var(--color-success); }
.rates-status__dot.error { background: var(--color-error); }
.btn-refresh {
  background: none; border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); padding: 0.2rem 0.5rem;
  cursor: pointer; font-size: 1rem; color: var(--color-text-muted);
  transition: all var(--transition); margin-left: auto;
}
.btn-refresh:hover { background: var(--color-bg); color: var(--color-primary); border-color: var(--color-primary); }
.btn-refresh.spinning { animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Tabs ── */
.tabs {
  display: flex; gap: 0.5rem; margin-bottom: 1.5rem;
  border-bottom: 2px solid var(--color-border);
}
.tab {
  background: none; border: none; padding: 0.75rem 1.25rem;
  font-family: var(--font-main); font-size: 0.95rem; font-weight: 600;
  color: var(--color-text-muted); cursor: pointer;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  transition: all var(--transition); border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}
.tab:hover { color: var(--color-primary); background: var(--color-bg); }
.tab.active { color: var(--color-primary); border-bottom-color: var(--color-accent); }

/* ── Filter Bar ── */
.filter-bar {
  display: flex; gap: 0.75rem; margin-bottom: 1rem; flex-wrap: wrap;
}
.filter-select {
  padding: 0.45rem 0.85rem; border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); font-family: var(--font-main);
  font-size: 0.875rem; background: var(--color-white); color: var(--color-text);
  cursor: pointer; transition: border-color var(--transition);
}
.filter-select:focus { outline: 2px solid var(--color-accent); outline-offset: 2px; border-color: var(--color-primary); }

/* ── Table Enhancements ── */
.loading-cell { text-align: center; padding: 2rem; color: var(--color-text-muted); }
.rate-value { font-size: 1.05rem; font-weight: 700; color: var(--color-primary); }
.rate-value.best { color: var(--color-success); }
.rate-na { color: var(--color-text-muted); font-style: italic; font-size: 0.85rem; }
.lender-name { font-weight: 600; }
.lender-logo { display: flex; align-items: center; gap: 0.5rem; }
.apply-link {
  display: inline-flex; align-items: center; gap: 0.3rem;
  font-size: 0.8rem; font-weight: 600; color: var(--color-primary);
  border: 1px solid var(--color-primary); border-radius: var(--radius-sm);
  padding: 0.25rem 0.6rem; transition: all var(--transition); white-space: nowrap;
}
.apply-link:hover { background: var(--color-primary); color: var(--color-white); }
.note-cell { font-size: 0.8rem; color: var(--color-text-muted); font-style: italic; }

/* Best rate row */
tbody tr.best-rate { background: #f0fdf4 !important; }
tbody tr.best-rate .rate-value { color: var(--color-success); }
tbody tr.best-rate td:nth-child(3)::after {
  content: ' ★ Best'; font-size: 0.7rem; color: var(--color-success);
  font-weight: 700; margin-left: 0.35rem; vertical-align: middle;
}

/* Paused/unavailable row */
tbody tr.paused { opacity: 0.65; }
tbody tr.paused .rate-value { color: var(--color-text-muted); }

/* ── Table Note ── */
.table-note {
  font-size: 0.8rem; color: var(--color-text-muted);
  margin-top: 0.75rem; padding: 0.75rem 1rem;
  background: #fffbeb; border-left: 3px solid var(--color-accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.table-note a { color: var(--color-primary); text-decoration: underline; }

/* ── Disclaimer ── */
.disclaimer { background: var(--color-bg); }
.disclaimer h3 { font-size: 1rem; margin-bottom: 0.5rem; }
.disclaimer p { font-size: 0.85rem; color: var(--color-text-muted); max-width: 800px; margin: 0; }

/* ── Footer ── */
.footer { background: var(--color-primary-dark); color: rgba(255,255,255,0.8); padding: 3rem 0 0; }
.footer__inner { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 2rem; padding-bottom: 2rem; }
.footer__brand .navbar__logo { color: var(--color-white); font-size: 1.1rem; display: inline-flex; margin-bottom: 0.75rem; }
.footer__brand p { font-size: 0.875rem; color: rgba(255,255,255,0.6); margin: 0; }
.footer__links h4 { color: var(--color-white); font-size: 0.9rem; margin-bottom: 0.75rem; }
.footer__links ul { display: flex; flex-direction: column; gap: 0.4rem; }
.footer__links a { color: rgba(255,255,255,0.65); font-size: 0.875rem; transition: color var(--transition); }
.footer__links a:hover { color: var(--color-accent); }
.footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 1rem 1.25rem; text-align: center;
  font-size: 0.8rem; color: rgba(255,255,255,0.4);
}

/* ── Screen reader only ── */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .grid-4 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .tabs { flex-direction: column; border-bottom: none; gap: 0; }
  .tab { border: 1px solid var(--color-border); border-radius: var(--radius-sm); margin-bottom: 0.25rem; }
  .tab.active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
  .footer__inner { grid-template-columns: 1fr; }
}

/* ============================================
   Homepage UX Improvements
   ============================================ */

/* Quick Start cards — 4 column grid */
.quick-start { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.quick-start .card { text-align: center; }
.quick-start .card__icon { margin: 0 auto 0.75rem; }

/* Card hover animation */
.card--hover { transition: transform 0.25s ease, box-shadow 0.25s ease; }
.card--hover:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }

/* Designed For section */
.designed-for { padding: 2.5rem 0; }
.designed-for h2 { font-size: 1.3rem; margin-bottom: 1rem; }
.designed-for__list {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 0.75rem 1.5rem; margin-bottom: 1rem;
}
.designed-for__item {
  font-size: 0.9rem; font-weight: 600; color: var(--color-primary);
  background: #f0fdf4; padding: 0.4rem 0.85rem; border-radius: 20px;
}
.designed-for__text {
  text-align: center; font-size: 0.875rem; color: var(--color-text-muted);
  max-width: 600px; margin: 0 auto;
}

/* Trust bar */
.trust-bar { padding: 1.5rem 0 0.5rem; background: var(--color-bg); border-top: 1px solid var(--color-border); }
.trust-bar__inner {
  display: flex; justify-content: center; gap: 2rem;
  flex-wrap: wrap; margin-bottom: 0.5rem;
}
.trust-item { font-size: 0.9rem; font-weight: 600; color: var(--color-primary); }
.trust-bar__text {
  text-align: center; font-size: 0.8rem; color: var(--color-text-muted);
  max-width: 500px; margin: 0 auto;
}

/* Freshness badge */
.freshness-badge {
  display: inline-block; font-size: 0.72rem; font-weight: 600;
  color: var(--color-text-muted); background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: 20px;
  padding: 0.2rem 0.7rem; margin-top: 0.5rem;
}

/* Sticky table headers */
.table-wrapper { max-height: 600px; overflow-y: auto; }
.table-wrapper thead th { position: sticky; top: 0; z-index: 10; }

/* Responsive */
@media (max-width: 900px) {
  .quick-start { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .quick-start { grid-template-columns: 1fr; }
  .designed-for__list { flex-direction: column; align-items: center; }
  .trust-bar__inner { gap: 1rem; }
}
