/* ============================================================
   Khama — products.css
   Styles for /products/ landing (grid + aside cross-links).
   The /products/{kind}/ configurator pages use configurator.css.
   ============================================================ */

.page-products { background: var(--paper); }
.page-products .container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: 22px;
}
@media (min-width: 720px) { .page-products .container { padding-inline: 40px; } }

/* ===== HERO ===== */
.products-hero {
  padding: calc(var(--nav-h) + 32px) 0 28px;
  text-align: center;
}
@media (min-width: 720px) { .products-hero { padding: calc(var(--nav-h) + 56px) 0 40px; } }

.products-eyebrow {
  font-family: var(--font-ui);
  font-size: 12px;
  letter-spacing: .14em;
  color: var(--gold);
  text-transform: none;
  margin: 0 0 14px;
  font-weight: 700;
}
.products-hero h1 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(34px, 7vw, 64px);
  line-height: 1.1;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0 auto 18px;
  max-width: 22ch;
  text-wrap: balance;
}
.products-sub {
  font-family: var(--font-text);
  font-size: clamp(15px, 3.6vw, 18px);
  line-height: 1.7;
  color: var(--gray);
  margin: 0 auto;
  max-width: 56ch;
  text-wrap: pretty;
}

/* ===== Page-level products grid: looser on its own page ===== */
.products--page {
  padding: 24px 0 64px;
  background: var(--paper);
}
@media (min-width: 720px) { .products--page { padding: 32px 0 96px; } }

.products--page .products-grid {
  margin-bottom: 56px;
}
@media (min-width: 720px) {
  .products--page .products-grid { margin-bottom: 80px; }
}

/* ===== Cross-link aside (size calc + class) ===== */
.products-aside {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  max-width: 1100px;
  margin: 0 auto;
}
@media (min-width: 720px) {
  .products-aside { grid-template-columns: 1fr 1fr; gap: 22px; }
}

.products-aside-card {
  background: var(--cream-warm);
  border: 1px solid var(--gray-line);
  border-radius: 24px;
  padding: 28px 24px;
  display: flex; flex-direction: column;
  gap: 12px;
  transition: border-color .35s var(--ease-out), transform .35s var(--ease-out);
}
.products-aside-card:hover {
  border-color: var(--emerald-deep);
  transform: translateY(-2px);
}
.products-aside-card h4 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  margin: 0;
  color: var(--ink);
}
.products-aside-card p {
  font-family: var(--font-text);
  font-size: 15px;
  color: var(--gray);
  margin: 0;
  line-height: 1.6;
}
.products-aside-card .btn-pri,
.products-aside-card .btn-ghost {
  align-self: flex-start;
  margin-top: 4px;
  text-align: center;
  justify-content: center;
}

.products-aside-card--accent {
  background: var(--emerald-deep);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 30px rgba(93,2,42,.18);
}
.products-aside-card--accent h4 { color: #fff; }
.products-aside-card--accent p  { color: rgba(255,255,255,.78); }
