/* Boulangerie Saint-Géry — warm, floury, deliberately NOT the PayFast console.
   Fraunces (display) over Inter; flour cream, roast-brown ink, a berry CTA. */

:root {
  --paper: #fbf5ea;
  --card: #fffdf8;
  --ink: #2e2018;
  --muted: #927f6d;
  --line: #e7dcc9;
  --crust: #c2622e;
  --jam: #8e2c4d;
  --ok: #2e7d5b;
  --ok-wash: #e7f1ea;
  --bad: #b23a3a;
  --bad-wash: #f6e7e5;
  --amber-wash: #f7ecd6;

  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body: "Inter", ui-sans-serif, system-ui, sans-serif;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--body);
  color: var(--ink);
  background:
    radial-gradient(1200px 480px at 80% -8%, #f5e7cf 0%, transparent 60%),
    var(--paper);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--jam); }

.masthead {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 22px 28px 16px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.brand {
  font-family: var(--display);
  font-weight: 600;
  font-size: 24px;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: -0.01em;
}
.brand .wheat { margin-right: 4px; }
.tagline {
  font-size: 13px;
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.wrap { max-width: 940px; margin: 0 auto; padding: 28px; }

.hero { margin: 14px 0 26px; }
.hero h1 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 38px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
}
.hero p { color: var(--muted); font-size: 16px; margin: 0; }

/* product grid */
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 18px;
  text-align: center;
  box-shadow: 0 12px 30px -22px rgba(46, 32, 24, 0.5);
}
.emoji {
  font-size: 40px;
  line-height: 1;
  margin-bottom: 10px;
}
.pname { font-weight: 600; font-size: 15px; }
.price {
  font-family: var(--display);
  font-weight: 600;
  color: var(--crust);
  margin: 4px 0 12px;
  font-size: 16px;
}
.stepper {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  overflow: hidden;
  background: var(--paper);
}
.stepper .step {
  border: none;
  background: transparent;
  font: inherit;
  font-size: 18px;
  width: 34px;
  height: 34px;
  cursor: pointer;
  color: var(--ink);
}
.stepper .step:hover { background: #f0e6d4; }
.stepper input {
  width: 42px;
  text-align: center;
  border: none;
  background: transparent;
  font: inherit;
  font-size: 15px;
  color: var(--ink);
  -moz-appearance: textfield;
}
.stepper input::-webkit-outer-spin-button,
.stepper input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* cart bar */
.cartbar {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 22px;
  padding: 16px 20px;
  background: var(--ink);
  color: #fbf2e4;
  border-radius: 16px;
}
.cartbar .total { font-size: 15px; }
.cartbar .total strong {
  font-family: var(--display);
  font-size: 22px;
  margin-left: 8px;
}
.cartbar .pay {
  margin-left: auto;
  font: inherit;
  font-weight: 600;
  font-size: 15px;
  color: #fff;
  background: var(--jam);
  border: none;
  border-radius: 999px;
  padding: 12px 22px;
  cursor: pointer;
}
.cartbar .pay:hover { background: #7a2542; }
.cartbar .pay.ghost {
  background: transparent;
  border: 1px solid rgba(251, 242, 228, 0.45);
  color: #fbf2e4;
}
.cartbar .pay.ghost:hover { background: rgba(255, 255, 255, 0.08); }
.mono { font-family: ui-monospace, "SF Mono", Menlo, monospace; }

/* order page */
.order { max-width: 620px; }
.back { font-size: 13px; text-decoration: none; }
.order h1 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 28px;
  margin: 10px 0 18px;
}
.banner {
  border-radius: 14px;
  padding: 16px 18px;
  font-size: 15px;
  margin-bottom: 18px;
  border: 1px solid transparent;
}
.banner.ok { background: var(--ok-wash); color: var(--ok); border-color: #c4e0d2; }
.banner.bad { background: var(--bad-wash); color: var(--bad); border-color: #ecc9c5; }
.banner.wait { background: var(--amber-wash); color: var(--crust); border-color: #ecd6b2; }
.banner.err { background: var(--bad-wash); color: var(--bad); border-color: #ecc9c5; font-size: 13.5px; }

.lines {
  width: 100%;
  border-collapse: collapse;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
}
.lines td { padding: 12px 18px; border-bottom: 1px solid var(--line); }
.lines td.r { text-align: right; font-variant-numeric: tabular-nums; }
.lines .x { color: var(--muted); }
.lines tr:last-child td { border-bottom: none; }
.lines tr.tot td { font-weight: 600; font-family: var(--display); }

.hint { color: var(--muted); font-size: 13px; margin-top: 16px; }

.foot {
  text-align: center;
  color: var(--muted);
  font-size: 12.5px;
  padding: 30px;
  border-top: 1px solid var(--line);
  margin-top: 40px;
}

@media (max-width: 720px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .hero h1 { font-size: 30px; }
}
