:root {
  --bg: #edf1e7;
  --bg-soft: #f8f5ef;
  --card: rgba(255, 255, 255, 0.9);
  --text: #292a24;
  --muted: #65685d;
  --line: rgba(48, 56, 38, 0.10);
  --accent: #6f8f45;
  --accent-deep: #46612a;
  --accent-soft: rgba(111, 143, 69, 0.14);
  --accent-warm: #d8c8b0;
  --danger: #b55245;
  --success: #4d6a41;
  --shadow: 0 22px 50px rgba(54, 63, 42, 0.09);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top, rgba(255,255,255,0.85), transparent 28%),
    linear-gradient(180deg, #f5f7f1 0%, #eef2e8 35%, #f4efe7 100%);
}
img {
  display: block;
  width: 100%;
  height: auto;
}
a { color: inherit; }
button, input { font: inherit; }

.page-shell {
  min-height: 100vh;
  padding: 14px 0 24px;
}
.page,
.site-footer {
  width: min(100%, 430px);
  margin: 0 auto;
}
.page {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.hero {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.hero-card {
  position: relative;
  margin: 0 14px;
  overflow: hidden;
  border-radius: 34px;
  min-height: 520px;
  background:
    radial-gradient(circle at 20% 18%, rgba(223, 243, 183, 0.45), transparent 24%),
    radial-gradient(circle at 85% 86%, rgba(255, 247, 229, 0.55), transparent 30%),
    linear-gradient(165deg