/* ============================================================
   farm — earthy editorial, organic texture
   Bitter (sturdy slab serif) + Karla (humanist sans)
   Presets: 1 Loam Paper · 2 Meadow Rings · 3 Harvest Dusk · 4 Orchard Stamp
   ============================================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --serif: "Bitter", "Iowan Old Style", Georgia, serif;
  --sans: "Karla", "Segoe UI", sans-serif;
  --wrap: 66rem;
  /* CSS grain: inline SVG turbulence tile */
  --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Preset palettes + feel ---------- */

/* 1 · Loam Paper — cream paper, soil ink, leaf accent; rugged borders */
.preset-1 {
  --bg: #f5efe2;
  --bg-alt: #efe7d4;
  --ink: #3b2e21;
  --muted: #6f6450;
  --accent: #52742d;
  --accent-2: #8a5a2b;
  --on-accent: #f7f3e6;
  --line: #d8cdb2;
  --card-bg: #fbf7ec;
  --radius: 4px;
  --grain-opacity: .35;
}

/* 2 · Meadow Rings — fresh green field, topographic ring hero */
.preset-2 {
  --bg: #f1f4e8;
  --bg-alt: #e8eed9;
  --ink: #2e3a24;
  --muted: #5d6a4c;
  --accent: #3f6d33;
  --accent-2: #7a5a33;
  --on-accent: #f3f7ec;
  --line: #cfd8ba;
  --card-bg: #fafcf3;
  --radius: 10px;
  --grain-opacity: .22;
}

/* 3 · Harvest Dusk — deep umber night, rust + wheat accents */
.preset-3 {
  --bg: #2b2118;
  --bg-alt: #342921;
  --ink: #efe4d2;
  --muted: #c0ad94;
  --accent: #d08648;
  --accent-2: #8c9e57;
  --on-accent: #2b2118;
  --line: #4d4033;
  --card-bg: #382c22;
  --radius: 6px;
  --grain-opacity: .5;
}

/* 4 · Orchard Stamp — bright paper, leaf-green ink, stamp/dashed craft */
.preset-4 {
  --bg: #faf7ef;
  --bg-alt: #f0eddd;
  --ink: #33402a;
  --muted: #67705a;
  --accent: #4a7233;
  --accent-2: #a05727;
  --on-accent: #f8faf2;
  --line: #d6d3bd;
  --card-bg: #ffffff;
  --radius: 2px;
  --grain-opacity: .25;
}

/* ---------- Base ---------- */

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  position: relative;
}

/* organic grain over everything, very faint */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none;
  background: var(--grain);
  opacity: calc(var(--grain-opacity) * .14);
}

.site-header, main, .site-footer { position: relative; z-index: 1; }

.wrap { width: 100%; max-width: var(--wrap); margin: 0 auto; padding: 0 1.25rem; }

h1, h2, h3 { font-family: var(--serif); line-height: 1.2; font-weight: 600; }

a { color: var(--accent); }

.icon { width: 1.25rem; height: 1.25rem; flex: none; }

/* ---------- Header ---------- */

.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 2px solid var(--ink);
}
.header-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 3.75rem; }
.brand {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--serif); font-weight: 800; font-size: 1.05rem;
  color: var(--ink); text-decoration: none; min-height: 2.75rem;
}
.brand-leaf { width: 1.3rem; height: 1.3rem; color: var(--accent); }
.header-cta {
  display: inline-flex; align-items: center; gap: .5rem;
  min-height: 2.75rem; padding: 0 1rem;
  font-weight: 700; font-size: .95rem; text-decoration: none;
  color: var(--on-accent); background: var(--accent);
  border-radius: var(--radius); border: 2px solid var(--accent);
}
.header-cta:hover { background: var(--ink); border-color: var(--ink); color: var(--bg); }

/* ---------- Hero ---------- */

.hero { padding: 4.5rem 0 4rem; position: relative; overflow: hidden; }
.hero-inner { position: relative; }
.hero-kicker {
  display: inline-block;
  font-size: .82rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: var(--accent-2); margin-bottom: 1.1rem;
}
.hero-name { font-size: clamp(2.2rem, 9vw, 3.8rem); font-weight: 800; margin-bottom: 1rem; }
.hero-tagline { font-size: 1.15rem; color: var(--muted); max-width: 36rem; margin-bottom: 2.25rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .75rem; }
.hero-rule { height: 6px; background: repeating-linear-gradient(90deg, var(--accent) 0 18px, transparent 18px 26px); opacity: .65; }
.hero-media { margin-top: 2.5rem; }
.hero-media img {
  display: block; width: 100%; max-height: 26rem; object-fit: cover;
  border: 2px solid var(--ink); border-radius: var(--radius);
  box-shadow: 4px 4px 0 0 var(--line);
}

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 3rem; padding: 0 1.4rem;
  font-family: var(--sans); font-weight: 700; font-size: 1rem;
  text-decoration: none; border-radius: var(--radius);
  transition: background-color .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.btn-primary { background: var(--accent); color: var(--on-accent); border: 2px solid var(--accent); }
.btn-primary:hover { background: var(--ink); border-color: var(--ink); color: var(--bg); }
.btn-ghost { color: var(--ink); border: 2px solid var(--ink); background: transparent; }
.btn-ghost:hover { background: var(--ink); color: var(--bg); }

/* ---------- Sections ---------- */

section { padding: 4rem 0; }
.section-head { margin-bottom: 2.25rem; }
.section-kicker {
  font-size: .8rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: var(--accent-2); margin-bottom: .5rem;
}
.section-head h2 { font-size: clamp(1.7rem, 6vw, 2.4rem); font-weight: 800; }

/* Services */
.services { background: var(--bg-alt); }
.services-grid { display: grid; grid-template-columns: 1fr; gap: 1.1rem; }
.service-card {
  background: var(--card-bg);
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  padding: 1.5rem 1.4rem;
  box-shadow: 4px 4px 0 0 var(--line);
  transition: transform .25s ease, box-shadow .25s ease;
}
.card-sprout { width: 1.6rem; height: 1.6rem; color: var(--accent); margin-bottom: .8rem; }
.service-card h3 { font-size: 1.25rem; margin-bottom: .4rem; }
.service-card p { color: var(--muted); font-size: 1rem; }

/* What's in season — toggle */
.season-tabs { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.5rem; }
.season-tab {
  font-family: var(--sans); font-weight: 700; font-size: .95rem;
  min-height: 2.75rem; padding: 0 1.2rem; cursor: pointer;
  color: var(--ink); background: var(--card-bg);
  border: 2px solid var(--ink); border-radius: 999px;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.season-tab:hover { background: var(--bg-alt); }
.season-tab.active { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.season-panel {
  background: var(--card-bg); border: 2px solid var(--ink);
  border-radius: var(--radius); padding: 1.5rem 1.4rem;
  box-shadow: 4px 4px 0 0 var(--line); margin-bottom: 1rem;
}
.season-panel:last-child { margin-bottom: 0; }
.season-name { font-size: 1.2rem; margin-bottom: .35rem; color: var(--accent); }
.season-panel p { color: var(--muted); }
html.js .season-panel { display: none; }
html.js .season-panel.active { display: block; }
html.js .season-panel.active .season-name { display: none; } /* tab already names it */
html:not(.js) .season-tabs { display: none; } /* JS off: all panels stack, no dead buttons */

/* Visit request form — gradient border shell (trend #1) */
.visit-form-shell {
  margin-top: 2rem; padding: 1px; border-radius: calc(var(--radius) + 1px);
  background: linear-gradient(145deg,
    color-mix(in srgb, var(--accent) 38%, transparent),
    rgba(255, 255, 255, .09) 42%, transparent);
}
.visit-form {
  background: var(--card-bg); border-radius: var(--radius);
  padding: 1.75rem 1.4rem; border: 1px solid var(--line);
}
.visit-form h3 { font-size: 1.35rem; margin-bottom: .3rem; }
.form-lede { color: var(--muted); font-size: .98rem; margin-bottom: 1.4rem; }
.form-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; margin-bottom: 1.4rem; }
.visit-form label {
  display: flex; flex-direction: column; gap: .35rem;
  font-weight: 700; font-size: .92rem; color: var(--ink);
}
.visit-form input, .visit-form textarea {
  font: inherit; font-weight: 400; color: var(--ink);
  background: var(--bg); border: 2px solid var(--line);
  border-radius: var(--radius); padding: .65rem .8rem; min-height: 2.75rem;
}
.visit-form textarea { min-height: 5rem; resize: vertical; }
.visit-form input:focus, .visit-form textarea:focus {
  outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent);
}
.visit-form .btn { cursor: pointer; }

/* About */
.about-grid { max-width: 46rem; }
.about-text { font-family: var(--serif); font-size: 1.12rem; line-height: 1.8; margin-bottom: 1.75rem; }
.distinctives { list-style: none; display: flex; flex-wrap: wrap; gap: .6rem; }
.distinctives li {
  font-size: .9rem; font-weight: 700; letter-spacing: .04em;
  color: var(--accent); border: 2px solid var(--accent);
  border-radius: 999px; padding: .45rem 1rem; line-height: 1.4;
  background: var(--card-bg);
}

/* Visit */
.visit { background: var(--bg-alt); }
.visit-grid { display: grid; grid-template-columns: 1fr; gap: 1.1rem; }
.visit-card {
  background: var(--card-bg); border: 2px solid var(--ink);
  border-radius: var(--radius); padding: 1.5rem 1.4rem;
  box-shadow: 4px 4px 0 0 var(--line);
}
.visit-card .icon { width: 1.5rem; height: 1.5rem; color: var(--accent); margin-bottom: .6rem; }
.visit-card h3 { font-size: 1.2rem; margin-bottom: .3rem; }
.visit-card p { color: var(--muted); }
.visit-card a { color: var(--accent); text-underline-offset: 3px; }

/* Contact */
.contact-inner { max-width: 44rem; }
.contact-inner h2 { font-size: clamp(1.7rem, 6vw, 2.2rem); font-weight: 800; margin-bottom: .6rem; }
.contact-lede { color: var(--muted); margin-bottom: 2rem; }
.contact-links { display: flex; flex-direction: column; gap: .7rem; }
.contact-link {
  display: inline-flex; align-items: center; gap: .65rem;
  min-height: 3rem; padding: 0 1.2rem;
  border: 2px solid var(--ink); border-radius: var(--radius);
  background: var(--card-bg); color: var(--ink);
  font-weight: 700; text-decoration: none;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.contact-link .icon { color: var(--accent); }
.contact-link:hover { background: var(--ink); color: var(--bg); }
.contact-link:hover .icon { color: var(--bg); }

/* Footer */
.site-footer {
  border-top: 2px solid var(--ink);
  padding: 2.25rem 0 2.5rem;
  font-size: .95rem; color: var(--muted);
}
.footer-sub { font-size: .88rem; margin-top: .25rem; }

/* ============================================================
   Preset structural personalities
   ============================================================ */

/* — Preset 2: centered hero floating on topographic rings, soft cards — */
.preset-2 .hero { padding: 5rem 0 4.5rem; }
.preset-2 .hero::before {
  content: ""; position: absolute; inset: -40% -20%;
  background: repeating-radial-gradient(circle at 50% 38%,
    transparent 0 34px,
    color-mix(in srgb, var(--accent) 9%, transparent) 34px 35px);
  pointer-events: none;
}
.preset-2 .hero-inner, .preset-2 .section-head,
.preset-2 .contact-inner, .preset-2 .site-footer { text-align: center; }
.preset-2 .about-grid, .preset-2 .contact-inner { margin-left: auto; margin-right: auto; }
.preset-2 .hero-tagline { margin-left: auto; margin-right: auto; }
.preset-2 .hero-actions, .preset-2 .distinctives { justify-content: center; }
.preset-2 .hero-rule { display: none; }
.preset-2 .service-card, .preset-2 .visit-card, .preset-2 .contact-link {
  border-width: 1px; border-color: var(--line);
  box-shadow: 0 3px 12px rgba(46, 58, 36, .08);
}
.preset-2 .site-header { border-bottom-width: 1px; border-bottom-color: var(--line); }
.preset-2 .site-footer { border-top-width: 1px; border-top-color: var(--line); }
.preset-2 .contact-link { justify-content: center; }
.preset-2 .contact-link:hover { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.preset-2 .contact-link:hover .icon { color: var(--on-accent); }

/* — Preset 3: harvest-dusk dark, glowing rust accents, heavier grain — */
.preset-3 { --card-bg: #382c22; }
.preset-3 .hero {
  padding: 5.5rem 0 5rem;
  background:
    radial-gradient(90% 70% at 50% 110%, rgba(196, 118, 58, .28) 0%, transparent 70%),
    linear-gradient(180deg, #241b13 0%, var(--bg) 100%);
}
.preset-3 .hero-kicker { color: var(--accent); }
.preset-3 .hero-name { color: #f5ead6; }
.preset-3 .services { background: #241b13; }
.preset-3 .visit { background: #241b13; }
.preset-3 .service-card, .preset-3 .visit-card {
  border-color: var(--line); box-shadow: none;
}
.preset-3 .btn-ghost { color: var(--ink); border-color: var(--muted); }
.preset-3 .btn-ghost:hover { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.preset-3 .btn-primary:hover { background: #e08b4a; border-color: #e08b4a; color: var(--on-accent); }
.preset-3 .site-header { background: color-mix(in srgb, #241b13 88%, transparent); border-bottom-color: var(--line); }
.preset-3 .header-cta:hover { background: #e08b4a; border-color: #e08b4a; color: var(--on-accent); }
.preset-3 .contact-link { border-color: var(--line); box-shadow: none; }
.preset-3 .contact-link:hover { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.preset-3 .contact-link:hover .icon { color: var(--on-accent); }
.preset-3 .distinctives li { background: transparent; }
.preset-3 .site-footer { border-top-color: var(--line); }
.preset-3 .hero-rule { background: repeating-linear-gradient(90deg, var(--accent) 0 18px, transparent 18px 26px); }

/* — Preset 4: orchard market stamp — dashed craft borders, two-tone bands — */
.preset-4 .hero { padding: 4.5rem 0; }
.preset-4 .hero-inner {
  border: 2px dashed var(--accent);
  border-radius: 2px;
  padding: 2.25rem 1.5rem;
  background: var(--card-bg);
}
.preset-4 .hero-rule { display: none; }
.preset-4 .hero-kicker { color: var(--accent-2); }
.preset-4 .section-head h2 { display: inline-block; border-bottom: 4px solid var(--accent); padding-bottom: .35rem; }
.preset-4 .service-card, .preset-4 .visit-card {
  border: 2px dashed var(--line); box-shadow: none;
}
.preset-4 .service-card:hover { border-color: var(--accent); }
.preset-4 .distinctives li { border-style: dashed; border-radius: 2px; }
.preset-4 .contact-link { border: 2px dashed var(--line); }
.preset-4 .contact-link:hover { background: var(--accent); border-color: var(--accent); color: var(--on-accent); border-style: solid; }
.preset-4 .contact-link:hover .icon { color: var(--on-accent); }
.preset-4 .site-header { border-bottom: 2px dashed var(--line); }
.preset-4 .site-footer { border-top: 2px dashed var(--line); }

/* ============================================================
   Motion (opt-in only)
   ============================================================ */

@media (prefers-reduced-motion: no-preference) {
  html.js .reveal {
    opacity: 0; transform: translateY(20px);
    transition: opacity .65s ease, transform .65s ease;
  }
  html.js .reveal.in { opacity: 1; transform: none; }
  html.js .reveal.d1 { transition-delay: .08s; }
  html.js .reveal.d2 { transition-delay: .16s; }
  html.js .reveal.d3 { transition-delay: .24s; }

  .service-card:hover { transform: translate(-2px, -3px); box-shadow: 7px 8px 0 0 var(--line); }
  .preset-2 .service-card:hover,
  .preset-3 .service-card:hover,
  .preset-4 .service-card:hover { box-shadow: 0 10px 24px rgba(0, 0, 0, .12); }
  .contact-link:hover { transform: translateY(-2px); }
  .btn:hover { transform: translateY(-2px); }
}

/* ============================================================
   Wider screens
   ============================================================ */

@media (min-width: 640px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .visit-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-links { flex-direction: row; flex-wrap: wrap; }
}

@media (min-width: 640px) {
  .form-grid { grid-template-columns: 1fr 1fr; }
  .form-wide { grid-column: span 2; }
}

@media (min-width: 960px) {
  .wrap { padding: 0 2rem; }
  section { padding: 5.5rem 0; }
  .hero { padding: 6rem 0 5.5rem; }
  .services-grid { grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
  .preset-4 .hero-inner { padding: 3rem 2.5rem; }

  /* deliberate grid-break: the lead offering takes the wide row */
  .service-card:first-child { grid-column: span 2; background: var(--bg-alt); }
  .preset-3 .service-card:first-child { background: #241b13; }
}

/* ============================================================
   2026 trends layer (progressive enhancement only)
   ============================================================ */

h1, h2, h3 { text-wrap: balance; }
p { text-wrap: pretty; }

@media (prefers-reduced-motion: no-preference) {
  /* scroll-driven reveals where supported; IO fallback stays for the rest */
  @supports (animation-timeline: view()) {
    html.js .reveal {
      opacity: 1; transform: none; transition: none;
      animation: rise-in both;
      animation-timeline: view();
      animation-range: entry 0% entry 60%;
    }
  }
  /* kinetic moment: the field kicker breathes open on load */
  html.js .hero-kicker { animation: kicker-open 1.1s ease-out both; }
}
@keyframes rise-in { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
@keyframes kicker-open { from { letter-spacing: .06em; opacity: 0; } to { letter-spacing: .2em; opacity: 1; } }
