:root {
  /* Oat */
  --oat-0:#FFFDF8; --oat-50:#FAF5EA; --oat-100:#F4ECDB; --oat-200:#EADDC2;
  --oat-300:#DCC9A4; --oat-400:#C9B086;
  /* Bark */
  --bark-900:#2C2014; --bark-700:#4B3A27; --bark-500:#71583E; --bark-400:#8D7256; --bark-300:#A98E70;
  /* Cinnamon */
  --cinnamon-700:#8C4524; --cinnamon-600:#A5572F; --cinnamon-500:#B96A3F;
  --cinnamon-200:#EBCDB7; --cinnamon-100:#F4E2D3;
  /* Honey */
  --honey-600:#B8862E; --honey-500:#D2A347; --honey-200:#F0DFAE; --honey-100:#F8EDCD;
  /* Sage */
  --sage-700:#4E5C3F; --sage-600:#66754F; --sage-200:#D7DFC6; --sage-100:#E8EDDC;
  /* Jam */
  --jam-600:#99404A; --jam-100:#F2DCDB;

  /* Semantic */
  --surface-page:var(--oat-50); --surface-card:var(--oat-0); --surface-inset:var(--oat-100);
  --surface-accent:var(--cinnamon-100); --surface-dark:var(--bark-900);
  --text-heading:var(--bark-900); --text-body:var(--bark-700); --text-muted:var(--bark-400); --text-faint:var(--bark-300);
  --text-on-accent:var(--oat-0); --text-on-dark:var(--oat-50); --text-accent:var(--cinnamon-600);
  --accent:var(--cinnamon-600); --accent-hover:var(--cinnamon-700); --accent-soft:var(--cinnamon-100);
  --focus-ring:var(--honey-500);
  --border-soft:#E9DCC3; --border-strong:#D4BE99; --border-accent:var(--cinnamon-500);
  --positive:var(--sage-600); --positive-soft:var(--sage-100);
  --warning:var(--honey-600); --warning-soft:var(--honey-100);
  --danger:var(--jam-600); --danger-soft:var(--jam-100);

  /* Type */
  --font-display:"Young Serif","Iowan Old Style",Georgia,serif;
  --font-body:"Karla","Avenir Next","Segoe UI",sans-serif;
  --font-hand:"Caveat","Bradley Hand",cursive;
  --text-xs:13px; --text-sm:14px; --text-base:16px; --text-lg:18px;
  --text-xl:21px; --text-2xl:26px; --text-3xl:34px; --text-4xl:44px; --text-5xl:58px;
  --leading-tight:1.12; --leading-snug:1.3; --leading-normal:1.55;
  --tracking-tight:-0.01em; --tracking-caps:0.12em;

  /* Spacing / shape / motion */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px;
  --radius-sm:8px; --radius-md:14px; --radius-lg:22px; --radius-pill:999px;
  --shadow-card:0 1px 2px rgba(44,32,20,.05), 0 6px 18px rgba(44,32,20,.07);
  --shadow-raised:0 2px 4px rgba(44,32,20,.07), 0 14px 36px rgba(44,32,20,.12);
  --ease-soft:cubic-bezier(.25,.1,.25,1);
  --duration-fast:140ms; --duration-base:220ms;
  --content-max:1120px; --content-pad:clamp(20px, 5vw, 56px);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--surface-page);
  color: var(--text-body);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--text-heading);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
p { margin: 0; }
a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 4px; }
::selection { background: var(--honey-200); color: var(--bark-900); }

/* ===== Header ===== */
.site-header {
  position: sticky; top: 0; z-index: 10;
  background: var(--surface-page);
  border-bottom: 1px solid var(--border-soft);
}
.site-header__inner {
  max-width: var(--content-max); margin: 0 auto;
  padding: 14px var(--content-pad);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.wordmark { display: inline-block; line-height: 1; }
.wordmark:hover { text-decoration: none; }
.wordmark__name {
  display: block; font-family: var(--font-display); font-size: 24px; color: var(--text-heading);
}
.wordmark__tag {
  display: block; margin-top: 3px;
  font-family: var(--font-hand); font-weight: 500; font-size: 14px; color: var(--text-accent);
}
.nav { display: flex; align-items: center; gap: 22px; }
.nav__link {
  font-size: var(--text-sm); font-weight: 500; color: var(--text-body);
  padding: 6px 2px;
}
.nav__link:hover, .nav__link--active {
  text-decoration: underline; text-underline-offset: 5px;
  text-decoration-thickness: 1.5px; text-decoration-color: var(--cinnamon-500);
}
.nav__link--active { font-weight: 700; color: var(--text-heading); }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-body); font-weight: 600;
  border: 1px solid transparent; border-radius: var(--radius-pill);
  cursor: pointer; transition: background var(--duration-fast) var(--ease-soft),
    color var(--duration-fast) var(--ease-soft), border-color var(--duration-fast) var(--ease-soft);
  text-decoration: none;
}
.btn:hover { text-decoration: none; }
.btn--sm { font-size: var(--text-sm); padding: 8px 16px; }
.btn { font-size: var(--text-base); padding: 10px 20px; }
.btn--lg { font-size: var(--text-lg); padding: 14px 26px; }
.btn--primary { background: var(--accent); color: var(--text-on-accent); }
.btn--primary:hover { background: var(--accent-hover); }
.btn--secondary {
  background: var(--surface-card); color: var(--text-heading); border-color: var(--border-strong);
}
.btn--secondary:hover { background: var(--oat-100); }
.btn--ghost { background: transparent; color: var(--text-heading); }
.btn--ghost:hover { background: var(--oat-100); }

/* ===== Hero ===== */
.eyebrow {
  font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--text-accent);
}
.hero {
  max-width: var(--content-max); margin: 0 auto;
  padding: var(--space-8) var(--content-pad) var(--space-7);
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-7); align-items: center;
}
.hero__copy { display: flex; flex-direction: column; gap: var(--space-5); }
.hero h1 { font-size: var(--text-5xl); max-width: 14ch; }
.hero__lede { font-size: var(--text-lg); max-width: 44ch; }
.hero__ctas { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.hero__media { position: relative; }
.hero__note {
  position: absolute; bottom: -14px; right: 18px;
  background: var(--surface-page); padding: 4px 10px; border-radius: 8px;
  font-size: 24px;
}

/* ===== Placeholders & hand notes ===== */
.placeholder {
  background: var(--oat-200);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  position: relative;
}
.placeholder--portrait { aspect-ratio: 4 / 5; }
.placeholder--card { aspect-ratio: 4 / 3; border-radius: 0; }
.placeholder > svg { width: 100%; height: 100%; display: block; }
.placeholder > .hand-note { position: absolute; bottom: var(--space-3); left: var(--space-3); background: rgba(255,255,255,0.75); padding: 2px 8px; border-radius: 999px; }
.hand-note { font-family: var(--font-hand); font-weight: 500; color: var(--text-heading); }
.hand-note--muted { color: var(--text-muted); font-size: 19px; }

/* ===== "This week's bake" band ===== */
.band { background: var(--surface-inset); }
.band__inner {
  max-width: var(--content-max); margin: 0 auto;
  padding: var(--space-8) var(--content-pad);
}
.band__head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: var(--space-6);
}
.band__head h2 { font-size: var(--text-3xl); }
.band__sub { color: var(--text-muted); margin: calc(var(--space-2) * -1) 0 var(--space-6); }
.band__cta { display: flex; justify-content: flex-end; margin-top: var(--space-6); }

.grid { display: grid; gap: var(--space-5); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

/* ===== Product card ===== */
.product {
  background: var(--surface-card);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--duration-base) var(--ease-soft),
    box-shadow var(--duration-base) var(--ease-soft);
}
.product:hover { transform: translateY(-2px); box-shadow: var(--shadow-raised); }
.product__body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.product__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.product__head h3 { font-size: var(--text-xl); }
.product__desc { font-size: var(--text-sm); color: var(--text-muted); }
.product__foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: auto; padding-top: 8px;
}
.price { font-weight: 700; color: var(--text-heading); }
.price__unit { font-weight: 400; color: var(--text-faint); font-size: var(--text-xs); }

/* ===== Badge ===== */
.badge {
  display: inline-flex; align-items: center;
  font-size: var(--text-xs); font-weight: 600;
  padding: 4px 10px; border-radius: var(--radius-pill);
  white-space: nowrap;
}
.badge--positive { background: var(--positive-soft); color: var(--sage-700); }
.badge--warning  { background: var(--warning-soft);  color: var(--honey-600); }
.badge--accent   { background: var(--accent-soft);   color: var(--cinnamon-700); }
.badge--danger   { background: var(--danger-soft);   color: var(--danger); }

/* ===== How it works ===== */
.how {
  max-width: var(--content-max); margin: 0 auto;
  padding: var(--space-8) var(--content-pad) 0;
}
.step {
  background: var(--surface-inset);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.step__num {
  font-family: var(--font-display); font-size: var(--text-2xl); color: var(--cinnamon-600);
}
.step h3 { font-size: var(--text-xl); margin: 8px 0 6px; }
.step p { font-size: var(--text-sm); color: var(--text-muted); }

/* ===== Footer ===== */
.site-footer {
  background: var(--surface-dark); color: var(--text-on-dark);
  margin-top: var(--space-9);
}
.site-footer__inner {
  max-width: var(--content-max); margin: 0 auto;
  padding: var(--space-7) var(--content-pad);
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 32px; flex-wrap: wrap;
}
.site-footer__name { font-family: var(--font-display); font-size: 22px; }
.site-footer__blurb {
  margin-top: 10px; font-size: var(--text-sm);
  color: var(--oat-300); max-width: 34ch;
}
.site-footer__links {
  display: flex; flex-direction: column; gap: 8px; font-size: var(--text-sm);
}
.site-footer__links a { color: var(--oat-100); }
.site-footer__note { color: var(--honey-500); font-size: 20px; }

/* ===== Responsive ===== */
@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; }
  .hero h1 { font-size: var(--text-4xl); }
  .grid--3 { grid-template-columns: 1fr; }
  .band__head { flex-direction: column; align-items: flex-start; gap: 12px; }
}

/* ===== Order modal ===== */
.order-dialog {
  border: none;
  border-radius: var(--radius-lg);
  padding: 0;
  width: min(520px, calc(100vw - 32px));
  background: var(--surface-card);
  color: var(--text-body);
  box-shadow: 0 30px 80px rgba(44, 32, 20, .25);
}
.order-dialog::backdrop {
  background: rgba(44, 32, 20, .45);
  backdrop-filter: blur(2px);
}
.order-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 28px 28px 24px;
  position: relative;
}
.order-form h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--text-heading);
  margin: 0;
  padding-right: 32px;
}
.order-form__intro {
  margin: -4px 0 4px;
  color: var(--text-muted);
  font-size: var(--text-sm);
}
.order-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: var(--text-sm);
  color: var(--text-body);
  font-weight: 500;
}
.order-form input,
.order-form textarea {
  font: inherit;
  color: var(--text-body);
  background: var(--surface-page);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  width: 100%;
  box-sizing: border-box;
  font-size: var(--text-base);
}
.order-form input:focus,
.order-form textarea:focus {
  outline: 2px solid var(--focus-ring);
  outline-offset: 1px;
  border-color: var(--border-accent);
}
.order-form textarea { resize: vertical; min-height: 90px; }
.order-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.order-form__error {
  margin: 0;
  padding: 8px 10px;
  background: var(--danger-soft);
  color: var(--danger);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}
.order-dialog__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: none;
  background: transparent;
  font-size: 24px;
  line-height: 1;
  color: var(--text-muted);
  cursor: pointer;
}
.order-dialog__close:hover { background: var(--surface-inset); color: var(--text-heading); }
