/* The Corral — website styles. Mirrors the iOS design system (Pasture theme):
   cream block cards, 2px ink borders, hard offset shadows, stripe band,
   Sigmar display / Fraunces serif / DM Sans UI. */

:root {
  --canvas: #dee8bc;        /* light pasture sage */
  --paper: #f6efd8;         /* card cream */
  --ink: #1f1812;
  --ink-soft: #5c4733;
  --primary: #5b7a3a;       /* pasture green */
  --primary-deep: #3f5826;
  --highlight: #c9a24a;     /* ochre */
  --butter: #ebd79a;
  --warm: #c76e3f;          /* persimmon */
  --plum: #6b3e5e;
  --sky: #7da3b5;
  --radius: 14px;
  --radius-sm: 10px;
  --border: 2px solid var(--ink);
  --shadow: 3px 3px 0 var(--ink);
  --shadow-sm: 2px 2px 0 var(--ink);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--canvas);
  color: var(--ink);
  font-family: "DM Sans", system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.6;
}

.wrap {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ---------- header ---------- */

header.site {
  padding: 28px 0 18px;
  text-align: center;
}

.wordmark {
  font-family: "Sigmar", "Sigmar One", cursive;
  font-size: clamp(2.4rem, 7vw, 3.4rem);
  color: var(--primary-deep);
  text-decoration: none;
  display: inline-block;
  line-height: 1.05;
}

.wordmark .runner { display: block; font-size: 0.8em; }

.stripes {
  display: flex;
  height: 6px;
}
.stripes span { flex: 1; }
.stripes span:nth-child(1) { background: var(--primary); }
.stripes span:nth-child(2) { background: var(--highlight); }
.stripes span:nth-child(3) { background: var(--warm); }
.stripes span:nth-child(4) { background: var(--plum); }
.stripes span:nth-child(5) { background: var(--sky); }

/* ---------- landing ---------- */

.hero {
  text-align: center;
  padding: 44px 0 10px;
}

.hero h1 {
  font-family: "Sigmar", "Sigmar One", cursive;
  font-weight: 400;
  font-size: clamp(1.7rem, 5vw, 2.6rem);
  color: var(--ink);
  margin: 0 0 14px;
  line-height: 1.15;
}

.hero p.tagline {
  font-family: "Fraunces", Georgia, serif;
  font-style: italic;
  font-size: clamp(1.05rem, 2.6vw, 1.3rem);
  color: var(--ink-soft);
  max-width: 560px;
  margin: 0 auto 26px;
}

.badge {
  display: inline-block;
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--radius-sm);
  border: var(--border);
  box-shadow: var(--shadow-sm);
  padding: 12px 22px;
  font-weight: 700;
  text-decoration: none;
  font-size: 0.95rem;
}

.badge small { display: block; font-weight: 400; font-size: 0.72rem; opacity: 0.85; }

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 18px;
  padding: 40px 0 8px;
}

.card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px 22px;
  text-align: center;
}

.card .emoji { font-size: 2.4rem; display: block; margin-bottom: 8px; }

.card h2 {
  font-family: "Sigmar", "Sigmar One", cursive;
  font-weight: 400;
  font-size: 1.15rem;
  margin: 0 0 8px;
  line-height: 1.25;
}

.card p {
  font-family: "Fraunces", Georgia, serif;
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: 0;
}

.quote {
  text-align: center;
  font-family: "Fraunces", Georgia, serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--primary-deep);
  padding: 34px 0 10px;
}

/* ---------- legal pages ---------- */

main.legal {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 34px clamp(20px, 5vw, 44px);
  margin: 26px auto 0;
}

main.legal h1 {
  font-family: "Sigmar", "Sigmar One", cursive;
  font-weight: 400;
  font-size: 1.7rem;
  margin: 0 0 4px;
}

main.legal .meta {
  font-size: 0.85rem;
  color: var(--ink-soft);
  margin-bottom: 22px;
}

main.legal h2 {
  font-size: 1.08rem;
  margin: 26px 0 8px;
  letter-spacing: 0.01em;
}

main.legal p, main.legal li { font-size: 0.97rem; }

main.legal a { color: var(--primary-deep); }

main.legal strong { color: var(--ink); }

/* ---------- footer ---------- */

footer.site {
  text-align: center;
  padding: 38px 0 30px;
  font-size: 0.85rem;
  color: var(--ink-soft);
}

footer.site nav { margin-bottom: 8px; }

footer.site a {
  color: var(--primary-deep);
  font-weight: 700;
  text-decoration: none;
  margin: 0 10px;
}

footer.site a:hover { text-decoration: underline; }
