:root {
  --shadow-warm: 0 10px 24px rgba(199,91,60,0.10);
  --shadow-warm-lg: 0 16px 38px rgba(199,91,60,0.18);
}

body {
  background:
    radial-gradient(820px 520px at 88% -8%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 60%),
    radial-gradient(680px 480px at -6% 110%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 62%),
    var(--bg);
}

.section:nth-of-type(even) {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel-2) 55%, transparent), transparent);
}

/* Headings — Fraunces optical warmth */
.hero-title, h1, h2, h3 {
  font-weight: 700;
  letter-spacing: -0.01em;
  font-style: normal;
}
.hero-title {
  letter-spacing: -0.02em;
}
.hero-title b, .hero-title em {
  font-style: italic;
  color: var(--accent);
}
h2 {
  font-weight: 650;
}

/* Hero — sand wash with hand-made grain */
.hero {
  background:
    radial-gradient(560px 360px at 16% 8%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 58%),
    linear-gradient(165deg, var(--panel) 0%, var(--panel-2) 100%);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  box-shadow: var(--shadow-warm);
}

.facts .fact {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
}
.facts .fact b {
  color: var(--accent);
}

/* Cards — oat on sand with terracotta lift */
.card, .feature, .faq-item {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
  transition: box-shadow .28s ease, transform .28s ease, border-color .28s ease;
}
.card:hover, .feature:hover {
  box-shadow: var(--shadow-warm-lg);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}

.feature .icon {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--panel));
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  border-radius: calc(var(--radius) - 4px);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 40%, transparent);
}

/* Buttons — terracotta, deepen on hover */
.btn-primary {
  background: linear-gradient(180deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 82%, #000) 100%);
  color: var(--on-accent);
  border: 1px solid color-mix(in srgb, var(--accent) 70%, #000);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
  transition: box-shadow .26s ease, transform .26s ease, filter .26s ease;
}
.btn-primary:hover {
  filter: saturate(1.08) brightness(0.96);
  box-shadow: var(--shadow-warm-lg);
  transform: translateY(-2px);
}
.btn-ghost {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: border-color .24s ease, box-shadow .24s ease;
}
.btn-ghost:hover {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--line));
  box-shadow: var(--shadow-warm);
}

/* Tags / badges — muted sage */
.badge {
  background: color-mix(in srgb, var(--accent-2) 18%, var(--panel));
  color: color-mix(in srgb, var(--accent-2) 72%, var(--text));
  border: 1px solid color-mix(in srgb, var(--accent-2) 36%, var(--line));
  border-radius: 999px;
}

/* Catalog tiles */
.tab {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 999px;
  transition: all .22s ease;
}
.tab.active, .tab:hover {
  background: color-mix(in srgb, var(--accent) 14%, var(--panel));
  border-color: color-mix(in srgb, var(--accent) 42%, var(--line));
  color: var(--accent);
}
.tile {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
  overflow: hidden;
  transition: box-shadow .28s ease, transform .28s ease, border-color .28s ease;
}
.tile:hover {
  box-shadow: var(--shadow-warm-lg);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
}
.tile.noimg {
  background:
    radial-gradient(120% 120% at 0% 0%, color-mix(in srgb, var(--accent) 10%, var(--panel)), var(--panel) 60%);
}
.tile .gp { color: var(--accent-2); }
.tile .nm { color: var(--text); font-weight: 600; }

/* Article & tables */
.article p, .article li { color: var(--prose); }
.table {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}
.table th {
  background: color-mix(in srgb, var(--accent) 12%, var(--panel-2));
  color: var(--text);
}
.table tr:nth-child(even) td {
  background: color-mix(in srgb, var(--panel-2) 60%, transparent);
}

/* FAQ */
.faq-item { box-shadow: var(--shadow-warm); }
.faq-q { color: var(--text); font-weight: 600; }
.faq-item:hover { border-color: color-mix(in srgb, var(--accent) 34%, var(--line)); }

/* Header divider */
.site-header {
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}