/* Texan Permaculture — public site styles
   Earthy palette, serif headings (Playfair Display), sans body (Inter). */

:root {
  --bg: #faf7f1;          /* warm off-white */
  --panel: #ffffff;
  --ink: #2a2418;         /* dark warm brown */
  --ink-soft: #4a4234;
  --muted: #7b7464;
  --line: #e7e1d3;
  --accent: #4a6b3a;      /* mossy green */
  --accent-dark: #34502a;
  --clay: #b8623f;        /* terracotta accent */
  --cream: #f1ead8;
  --shadow: 0 6px 18px rgba(40, 32, 18, 0.08);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent-dark); text-decoration: none; }
a:hover { color: var(--clay); }

h1, h2, h3, h4 {
  font-family: "Playfair Display", Georgia, "Times New Roman", serif;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 .6rem;
}
h1 { font-size: clamp(2.2rem, 4.5vw, 3.6rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); margin-top: 0; }
h3 { font-size: 1.25rem; }
p { margin: 0 0 1rem; }

.muted { color: var(--muted); }
.container { max-width: 1140px; margin: 0 auto; padding: 0 1.25rem; }
.kicker {
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .78rem;
  font-weight: 600;
  color: var(--clay);
  margin: 0 0 .8rem;
}
.lede { font-size: 1.15rem; color: var(--ink-soft); max-width: 60ch; }

/* --- Header / nav ------------------------------------------------ */
.site-header {
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 50;
}
.nav {
  display: flex; align-items: center; gap: 1rem;
  padding: .9rem 1.25rem;
}
.logo {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: "Playfair Display", serif;
  font-weight: 700; font-size: 1.25rem; color: var(--ink);
}
.logo-mark { font-size: 1.4rem; }
.nav-links {
  margin-left: auto;
  display: flex; gap: 1.6rem;
  font-weight: 500; font-size: .98rem;
}
.nav-links a {
  color: var(--ink-soft);
  padding: .25rem 0;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
}
.nav-links a:hover { color: var(--accent-dark); }
.nav-links a.active { color: var(--accent-dark); border-bottom-color: var(--accent); }

.nav-toggle { display: none; }
.nav-burger {
  display: none; cursor: pointer; margin-left: auto;
  width: 28px; height: 22px; flex-direction: column; justify-content: space-between;
}
.nav-burger span {
  display: block; height: 3px; background: var(--ink); border-radius: 2px;
}

@media (max-width: 720px) {
  .nav-burger { display: flex; }
  .nav-links {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; gap: 0;
    background: var(--bg); border-bottom: 1px solid var(--line);
    max-height: 0; overflow: hidden; transition: max-height .25s ease;
  }
  .nav-links a {
    padding: .85rem 1.25rem; border-bottom: 1px solid var(--line);
  }
  .nav-toggle:checked ~ .nav-links { max-height: 360px; }
}

/* --- Hero -------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 72vh;
  display: flex; align-items: center;
  color: #fff;
  overflow: hidden;
}
.hero.hero-sm { min-height: 44vh; }
.hero-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: saturate(.85) contrast(1.05);
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(30,24,14,.30) 0%, rgba(30,24,14,.65) 100%);
}
.hero-inner {
  position: relative; z-index: 2;
  padding: 5rem 1.25rem;
}
.hero h1 { color: #fff; max-width: 18ch; }
.hero .lede { color: rgba(255,255,255,.92); max-width: 56ch; font-size: 1.2rem; }
.hero .kicker { color: var(--cream); }

.cta-row { margin-top: 1.6rem; display: flex; flex-wrap: wrap; gap: .75rem; }

/* --- Buttons ----------------------------------------------------- */
.btn {
  display: inline-block;
  padding: .8rem 1.4rem;
  font-weight: 600; font-size: .98rem;
  border-radius: 999px;
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform .1s, background .15s, color .15s, border-color .15s;
}
.btn:active { transform: translateY(1px); }
.btn.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn.primary:hover { background: var(--accent-dark); border-color: var(--accent-dark); color: #fff; }
.btn.outline { background: transparent; color: #fff; border-color: rgba(255,255,255,.7); }
.btn.outline:hover { background: rgba(255,255,255,.12); color: #fff; }

/* --- Page head (lighter than hero) ------------------------------- */
.page-head {
  background: var(--cream);
  border-bottom: 1px solid var(--line);
  padding: 4rem 0 3rem;
}
.page-head h1 { margin-bottom: .8rem; }

/* --- Sections ---------------------------------------------------- */
.section { padding: 4rem 1.25rem; }
.section-head { margin-bottom: 2rem; }
.row-between { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: .5rem; }
.band { background: var(--cream); }

/* Features (3-up icons) */
.features {
  display: grid; gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.feature {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 1.6rem;
}
.feature-icon { font-size: 2rem; margin-bottom: .5rem; }
.feature h3 { margin-top: 0; }

/* Card grid */
.cards-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.card-link {
  display: flex; flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  color: var(--ink);
  box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s;
}
.card-link:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(40, 32, 18, 0.12);
  color: var(--ink);
}
.card-media {
  height: 220px;
  background-size: cover; background-position: center;
}
.card-body { padding: 1.25rem 1.4rem 1.4rem; }
.card-body h2, .card-body h3 { margin: .2rem 0 .35rem; }
.post-meta { font-size: .85rem; color: var(--muted); margin: 0 0 .35rem; text-transform: uppercase; letter-spacing: .08em; }

.link-arrow {
  display: inline-block; margin-top: .4rem;
  font-weight: 600; color: var(--accent-dark);
}
.card-link:hover .link-arrow { color: var(--clay); }

/* --- Prose / article body ---------------------------------------- */
.prose { max-width: 72ch; }
.prose h2 { margin-top: 2.2rem; }
.prose h3 { margin-top: 1.6rem; }
.prose p, .prose li { font-size: 1.05rem; }
.prose img { max-width: 100%; border-radius: 8px; margin: 1rem 0; }
.prose blockquote {
  border-left: 4px solid var(--accent);
  padding: .25rem 1rem;
  color: var(--ink-soft);
  font-style: italic;
  margin: 1.2rem 0;
}
.prose pre {
  background: #2a2418; color: #f1ead8;
  padding: .9rem 1rem; border-radius: 8px;
  overflow-x: auto; font-size: .92rem;
}
.prose code {
  background: var(--cream);
  padding: .05rem .35rem; border-radius: 4px;
  font-size: .92em;
}
.prose pre code { background: transparent; padding: 0; }
.prose hr { border: none; border-top: 1px solid var(--line); margin: 2.2rem 0; }
.back { margin-top: 2rem; }

/* --- Contact ----------------------------------------------------- */
.contact-grid {
  display: grid; gap: 1.25rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.contact-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 1.4rem 1.5rem;
}
.contact-card h3 { margin-top: 0; }

/* --- Inventory --------------------------------------------------- */
.group-heading {
  font-family: "Playfair Display", serif;
  font-size: 1.5rem;
  margin: 2.2rem 0 .8rem;
  padding-bottom: .35rem;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
}
.inv-wrap {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
}
.inv-table { width: 100%; border-collapse: collapse; }
.inv-table th, .inv-table td {
  padding: .65rem .9rem;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.inv-table thead th {
  background: var(--cream);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .8rem;
  color: var(--ink-soft);
}
.inv-table tbody tr:last-child td { border-bottom: none; }
.inv-table .num { text-align: right; font-variant-numeric: tabular-nums; }

/* --- Shop -------------------------------------------------------- */
.product-card {
  display: flex; flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow);
}
.product-card .card-media {
  position: relative;
  height: 220px;
}
.product-badge {
  position: absolute; top: .8rem; left: .8rem;
  padding: .25rem .6rem;
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  background: var(--ink); color: #fff;
  border-radius: 999px;
}
.badge-preorder { background: var(--clay); }
.badge-seasonal { background: var(--accent); }
.badge-soldout  { background: var(--muted); }
.product-price {
  font-size: 1.15rem;
  margin: .2rem 0 .8rem;
}
.product-desc { font-size: .98rem; margin-bottom: 1rem; }
.product-desc p:last-child { margin-bottom: 0; }
.product-card .btn { align-self: flex-start; margin-top: auto; }

.shop-faq {
  margin-top: 3rem;
  padding: 1.6rem 1.8rem;
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 12px;
  max-width: 80ch;
}
.shop-faq h2 { margin-top: 0; }

/* --- Footer ------------------------------------------------------ */.site-footer {
  background: #2a2418;
  color: #d8cfb8;
  margin-top: 3rem;
  padding: 3rem 0 1.5rem;
}
.site-footer h3, .site-footer h4 {
  color: #f1ead8;
  font-family: "Playfair Display", serif;
  margin: 0 0 .6rem;
}
.site-footer h4 { font-size: 1rem; letter-spacing: .03em; }
.site-footer .footer-brand { font-size: 1.4rem; }
.site-footer .muted { color: #a39c89; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: .4rem; }
.site-footer a { color: #d8cfb8; }
.site-footer a:hover { color: #fff; }
.footer-grid {
  display: grid; gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  margin-bottom: 2rem;
}
.footer-bottom {
  border-top: 1px solid #3a3326;
  padding-top: 1rem;
  font-size: .9rem;
}

/* --- Cart & checkout ------------------------------------------------- */
.cart-link { position: relative; padding-right: 1.5rem; }
.cart-count {
  position: absolute; top: -4px; right: 0;
  background: var(--clay, #b8623f); color: #fff;
  border-radius: 999px; padding: 1px 7px;
  font-size: .72rem; font-weight: 700;
  min-width: 18px; text-align: center; line-height: 1.4;
}
.add-to-cart {
  display: flex; gap: .5rem; align-items: center; margin-top: .8rem;
}
.add-to-cart .qty-input {
  width: 64px; padding: .45rem .5rem; border: 1px solid #cbbfa4;
  border-radius: 6px; font-size: 1rem;
}
.cart-table {
  width: 100%; border-collapse: collapse; margin: 1rem 0 2rem;
}
.cart-table th, .cart-table td {
  text-align: left; padding: .6rem .5rem; border-bottom: 1px solid #e7dfc9;
}
.cart-table .right { text-align: right; }
.cart-table input[type="number"] { width: 64px; padding: .35rem; }
.cart-form .form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: .8rem 1rem; margin-bottom: 1rem;
}
.cart-form .form-grid label { display: block; font-size: .9rem; }
.cart-form .form-grid input,
.cart-form .form-grid textarea {
  width: 100%; padding: .5rem .6rem; border: 1px solid #cbbfa4; border-radius: 6px;
  font-family: inherit; font-size: 1rem; margin-top: .25rem;
}
.cart-form .span-2 { grid-column: 1 / -1; }
.cart-form .req { color: var(--clay, #b8623f); }
.cart-errors {
  background: #fbeae0; border: 1px solid #d99a73; border-radius: 8px;
  padding: 1rem 1.2rem; margin-bottom: 1.5rem;
}
.cart-errors h3 { margin-top: 0; }
.btn.big { padding: .75rem 1.4rem; font-size: 1.05rem; }
.btn-link {
  background: none; border: none; color: #888; cursor: pointer;
  font-size: 1.1rem; padding: .25rem .4rem;
}
.btn-link:hover { color: var(--clay, #b8623f); }
.checkout-success .order-num {
  font-size: 1.1rem; background: #efe7d2; display: inline-block;
  padding: .4rem .8rem; border-radius: 6px; margin-bottom: 1rem;
}
.pay-block {
  background: #f1ead8; border: 1px solid #d8c99e; border-radius: 8px;
  padding: 1.2rem; margin: 1.5rem 0; text-align: center;
}
.next-steps ol { padding-left: 1.2rem; }
.small { font-size: .85rem; }
