: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(900px 520px at 88% -8%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 70%),
    radial-gradient(760px 480px at 6% 4%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 72%),
    var(--bg);
}

.section:nth-of-type(even) {
  background:
    radial-gradient(620px 360px at 96% 0%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 70%);
}

/* Headings — Fraunces optical warmth */
.hero-title,
.section h2,
.article h2,
h1, h2 {
  font-weight: 640;
  letter-spacing: -0.01em;
  font-style: normal;
}

.hero-title {
  font-weight: 680;
  letter-spacing: -0.02em;
  background: linear-gradient(120deg, var(--text), color-mix(in srgb, var(--accent) 45%, var(--text)));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero {
  background:
    radial-gradient(700px 420px at 78% 18%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 70%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 60%, transparent), transparent);
  border-bottom: 1px solid var(--line);
}

/* Cards — oat on sand, hairline divider, warm shadow */
.card,
.feature,
.faq-item {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.card {
  position: relative;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  border-radius: var(--radius) var(--radius) 0 0;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  opacity: 0;
  transition: opacity 0.25s ease;
}

.card:hover,
.feature:hover {
  box-shadow: var(--shadow-warm-lg);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
}

.card:hover::before {
  opacity: 1;
}

/* Feature icons */
.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) * 0.7);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 40%, transparent);
}

/* Buttons — terracotta, deepen on hover */
.btn-primary {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, #fff), var(--accent));
  color: var(--on-accent);
  border: 1px solid color-mix(in srgb, var(--accent) 60%, #000);
  border-radius: calc(var(--radius) * 0.8);
  box-shadow: 0 6px 16px rgba(199, 91, 60, 0.22);
  transition: box-shadow 0.22s ease, transform 0.22s ease, background 0.22s ease;
}

.btn-primary:hover {
  background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 70%, #000));
  box-shadow: 0 12px 26px rgba(199, 91, 60, 0.32);
  transform: translateY(-2px);
}

.btn-ghost {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) * 0.8);
  color: var(--text);
  transition: border-color 0.22s ease, background 0.22s ease;
}

.btn-ghost:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--panel));
}

/* Badges & sage tags */
.badge {
  background: color-mix(in srgb, var(--accent-2) 18%, var(--panel));
  color: color-mix(in srgb, var(--accent-2) 60%, var(--text));
  border: 1px solid color-mix(in srgb, var(--accent-2) 34%, var(--line));
  border-radius: 999px;
}

/* Facts */
.fact {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
}

.fact b {
  color: var(--accent);
}

/* Tiles */
.tile {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-warm);
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.tile:hover {
  box-shadow: var(--shadow-warm-lg);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 32%, var(--line));
}

.tile .gp {
  color: var(--accent-2);
}

.tile.noimg {
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--accent) 10%, var(--panel)), var(--panel));
}

.tile.noimg .nm {
  color: var(--text);
  font-weight: 600;
}

/* Tabs */
.tab {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text-2);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.tab:hover {
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
}

.tab.active {
  background: var(--accent);
  color: var(--on-accent);
  border-color: var(--accent);
}

/* FAQ */
.faq-item {
  box-shadow: none;
}

.faq-item:hover {
  border-color: color-mix(in srgb, var(--accent) 28%, var(--line));
}

.faq-q {
  color: var(--text);
  font-weight: 600;
}

.faq-q::after {
  color: var(--accent);
}

/* Article tables */
.article .table {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.article .table th {
  background: color-mix(in srgb, var(--accent) 10%, var(--panel));
  color: var(--text);
  border-bottom: 1px solid var(--line);
}

.article .table td {
  border-bottom: 1px solid var(--line);
}

.site-header {
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(8px);
}

.article a {
  color: var(--accent);
  text-decoration-color: color-mix(in srgb, var(--accent) 40%, transparent);
}