/*
 * CoolThings — Component Styles
 * Product cards, chips, badges, feature cards, recipient rows, etc.
 */

/* ── Chips & Badges ────────────────────────────────────────────────────────── */
.chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  height: 34px; padding: 0 var(--space-4);
  border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border);
  font-size: var(--text-sm); font-weight: 500; color: var(--text);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  user-select: none;
}
.chip:hover { border-color: var(--text); }
.chip.active { background: var(--text); color: var(--bg); border-color: var(--text); }

.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: 4px 10px; border-radius: var(--radius-pill);
  background: var(--surface-alt); color: var(--text-muted);
  font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.04em;
  text-transform: uppercase;
}
.badge-teal { background: color-mix(in srgb, var(--secondary) 12%, transparent); color: var(--secondary); }
.badge-terra { background: color-mix(in srgb, var(--primary) 14%, transparent); color: var(--primary); }
.badge-green { background: color-mix(in srgb, var(--success) 14%, transparent); color: var(--success); }

/* ── Product Card ──────────────────────────────────────────────────────────── */
.product-card {
  display: flex; flex-direction: column; gap: var(--space-3);
  position: relative; text-decoration: none;
}
.product-card .thumb {
  position: relative; width: 100%; aspect-ratio: 4/3;
  border-radius: var(--radius); overflow: hidden;
  background: var(--surface-alt);
  transition: transform var(--t-med) var(--ease);
}
.product-card .thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.product-card:hover .thumb { transform: translateY(-2px); }
.thumb-overlay { position: absolute; top: 10px; right: 10px; z-index: 2; }
.card-body { display: flex; flex-direction: column; gap: 6px; }
.card-meta { display: flex; align-items: center; gap: 8px; font-size: var(--text-xs); color: var(--text-muted); }
.card-title {
  font-family: var(--font-display);
  font-size: var(--text-lg); font-weight: 500;
  line-height: 1.2; letter-spacing: -0.01em;
  color: var(--text);
}
.card-blurb {
  font-size: var(--text-sm); color: var(--text-muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-2); }
.price { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 500; }
.heart-btn {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius-pill);
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-muted);
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.heart-btn:hover { color: var(--primary); border-color: var(--primary); }
.heart-btn.saved { color: var(--primary); border-color: var(--primary); background: color-mix(in srgb, var(--primary) 8%, var(--surface)); }
.heart-btn.saved svg { fill: var(--primary); }
.deal-alert {
  position: absolute; top: 10px; left: 10px; z-index: 2;
  background: var(--primary); color: #fff;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--radius-pill);
}

/* ── Feature card (large editorial) ───────────────────────────────────────── */
.feature-card {
  position: relative; border-radius: var(--radius-lg);
  overflow: hidden; background: var(--surface); border: 1px solid var(--border);
  display: flex; flex-direction: column; min-height: 360px;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.feature-card .thumb { aspect-ratio: 16/10; border-radius: 0; flex: 1 1 auto; min-height: 220px; }
.feature-card-body { padding: var(--space-5) var(--space-5) var(--space-6); }
.feature-card h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); margin: var(--space-2) 0 6px; }
.feature-card .read { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text); margin-top: var(--space-3); }
.feature-card .read .arrow { transition: transform var(--t-fast) var(--ease); }
.feature-card:hover .read .arrow { transform: translateX(4px); }

/* ── Recipient / Occasion row ──────────────────────────────────────────────── */
.recipient-row { padding: var(--space-7) 0; border-bottom: 1px solid var(--border); }
.recipient-row:last-child { border-bottom: none; }
.recipient-row-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }
.recipient-row-head h3 { font-size: clamp(1.3rem, 2.5vw, 1.75rem); }
.recipient-chip {
  display: inline-flex; align-items: center; gap: 8px;
  height: 44px; padding: 0 var(--space-5);
  border-radius: var(--radius-pill); border: 1.5px solid var(--border);
  background: var(--surface); font-weight: 500;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.recipient-chip:hover { background: var(--surface-alt); border-color: var(--border-strong); transform: translateY(-1px); }
.recipient-chip .ic { font-size: 1.2em; }

/* ── Gift Guide hub card ───────────────────────────────────────────────────── */
.guide-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3);
  transition: box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.guide-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.guide-card-icon { font-size: 2rem; }
.guide-card h3 { font-size: var(--text-xl); }
.guide-card p { font-size: var(--text-sm); color: var(--text-muted); flex: 1; }
.guide-card-link { font-size: var(--text-sm); font-weight: 600; color: var(--primary); display: inline-flex; align-items: center; gap: 4px; margin-top: auto; }

/* ── Surprise FAB ──────────────────────────────────────────────────────────── */
.surprise-fab {
  position: fixed; right: 24px; bottom: 24px; z-index: 30;
  height: 54px; padding: 0 22px; border-radius: var(--radius-pill);
  background: var(--primary); color: #fff;
  font-weight: 600; font-size: var(--text-sm); letter-spacing: 0.01em;
  display: inline-flex; align-items: center; gap: 10px;
  box-shadow: 0 12px 28px rgba(200,85,61,0.35), 0 4px 8px rgba(200,85,61,0.2);
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.surprise-fab:hover { background: var(--primary-hover); }
.surprise-fab:active { transform: translateY(1px); }

/* ── Star rating ───────────────────────────────────────────────────────────── */
.star-rating { font-size: 0.9em; letter-spacing: -0.05em; color: #e9a634; }
.star-empty { color: var(--border-strong); }
.rating-count { font-size: var(--text-xs); color: var(--text-muted); }

/* ── Save count ────────────────────────────────────────────────────────────── */
.saves-count { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); color: var(--text-muted); }
.saves-count .ic { color: var(--primary); }

/* ── Pagination ────────────────────────────────────────────────────────────── */
.pagination { display: flex; align-items: center; justify-content: center; gap: var(--space-2); padding: var(--space-7) 0; }
.pagination a, .pagination span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-pill);
  font-size: var(--text-sm); font-weight: 500; border: 1px solid var(--border);
}
.pagination .current { background: var(--text); color: var(--bg); border-color: var(--text); }
.pagination a:hover { background: var(--surface-alt); border-color: var(--border-strong); }

/* ── "What We Love" sidebar ────────────────────────────────────────────────── */
.what-we-love {
  background: color-mix(in srgb, var(--primary) 6%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}
.what-we-love h4 { font-size: var(--text-base); margin-bottom: var(--space-3); }
.what-we-love p { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.6; }

/* ── Editor picks badge ────────────────────────────────────────────────────── */
.editor-pick-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--secondary); color: #fff;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--radius-pill);
}

/* ── Saved page ────────────────────────────────────────────────────────────── */
.saved-empty {
  text-align: center; padding: var(--space-9) var(--space-6);
  border: 2px dashed var(--border); border-radius: var(--radius-lg);
}
.saved-empty h2 { margin-bottom: var(--space-3); font-size: var(--text-2xl); }
.saved-empty p { color: var(--text-muted); margin-bottom: var(--space-5); }
