/* Quote Gate — extends shop.css */

.qg-brand span { color: var(--text-dim); }
.qg-nav-active { color: var(--copper-br) !important; }

.qg-card { transition: border-color .2s; }
.qg-card:hover { border-color: rgba(192,120,120,0.35); }
.qg-title {
  font-size: 1.15rem; font-weight: 600; color: var(--copper-br);
}
.qg-title:hover { color: var(--copper); }

.qg-stat-box .qg-stat-num {
  font-size: 2rem; font-weight: 600; color: var(--copper-br); line-height: 1.1;
}

.qg-pulse-border {
  border-color: rgba(192,120,120,0.45);
  animation: qg-pulse 2.5s ease-in-out infinite;
}
@keyframes qg-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(192,120,120,0); }
  50%      { box-shadow: 0 0 24px rgba(192,120,120,0.12); }
}

.qg-compare-wrap { overflow: hidden; }
.qg-compare-table { font-size: 0.88rem; }
.qg-compare-table th,
.qg-compare-table td { vertical-align: middle; white-space: nowrap; }
.qg-sticky-col {
  position: sticky; left: 0; z-index: 2;
  background: var(--panel); min-width: 140px; white-space: normal !important;
}
.qg-offer-cell { min-width: 88px; }
.qg-price { font-weight: 600; color: var(--text); }
.qg-price.qg-best { color: var(--copper-br); }
.qg-best-badge {
  display: inline-block; font-size: 0.65rem; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--copper); margin-left: 0.25rem;
}
.qg-alt-badge {
  font-size: 0.72rem; color: var(--steel); margin-top: 0.15rem;
}

.qg-preview-table code { color: var(--steel); font-size: 0.82rem; }

/* ── Rolodex compare ── */
.qg-line-card {
  background: var(--panel-2); border-radius: 12px; padding: 1rem 1.25rem;
  border: 1px solid var(--border);
}
.qg-line-title { font-size: 1.05rem; color: var(--copper-br); font-weight: 600; }
.qg-line-title code { color: var(--steel); }

.qg-carousel {
  display: flex; gap: 0.75rem; overflow-x: auto; padding: 0.5rem 0.25rem 1rem;
  scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
}
.qg-offer-card {
  flex: 0 0 160px; scroll-snap-align: center;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 14px;
  padding: 1rem; text-align: center; cursor: pointer; color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}
.qg-offer-card:hover { border-color: rgba(192,120,120,0.4); }
.qg-offer-card.qg-selected {
  border-color: var(--copper); box-shadow: 0 0 0 2px rgba(192,120,120,0.45);
}
.qg-offer-card.qg-cheapest { background: rgba(192,120,120,0.06); }
.qg-offer-label { font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--steel); }
.qg-offer-price { font-size: 1.15rem; font-weight: 600; margin: 0.35rem 0; }
.qg-no-offers { color: var(--text-dim); padding: 2rem; text-align: center; width: 100%; }

.qg-dots { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
.qg-dot {
  width: 10px; height: 10px; border-radius: 50%; padding: 0; border: none;
  background: var(--text-dim); opacity: 0.35; cursor: pointer;
}
.qg-dot.qg-dot-done { background: var(--copper); opacity: 0.85; }
.qg-dot.qg-dot-wait { background: var(--steel); opacity: 0.5; }
.qg-dot.qg-dot-active { box-shadow: 0 0 0 2px var(--copper-br); opacity: 1; }

.qg-sticky-footer {
  position: sticky; bottom: 0; z-index: 50;
  border-color: rgba(192,120,120,0.25);
  background: rgba(19,19,31,0.95); backdrop-filter: blur(8px);
}
.qg-footer-total { font-size: 1.2rem; font-weight: 600; color: var(--copper-br); }
.qg-footer-total span { color: var(--copper-br); }

.qg-grid-pick {
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); padding: 0.35rem 0.5rem; cursor: pointer; font-size: 0.85rem;
}
.qg-grid-pick.qg-selected { border-color: var(--copper); color: var(--copper-br); }
