/* ==========================================================================
   Breadberry — "Square Format" (Direction A)
   Editorial, mobile-first. Edit tokens below to retheme the whole site.
   ========================================================================== */

@font-face {
  font-family: "League Spartan";
  src: url("fonts/LeagueSpartan-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --paper: #FFFEF7;      /* page background */
  --ink: #33322D;        /* body text (brand grey) */
  --plum: #552160;       /* headings, links */
  --butter: #FEDD00;     /* accent rules + highlights only (owner decision) */
  --berry: #F05671;      /* kickers, small labels */
  --teal: #008080;       /* rare secondary accent */
  --hairline: #E9E4D4;   /* slice-grid lines, dividers */
  --faint: #7C796E;      /* captions, muted text */
  --display: "League Spartan", system-ui, -apple-system, sans-serif;
  --body: "Inter", system-ui, -apple-system, sans-serif;
  --wrap: 1060px;
  --gutter: clamp(20px, 5vw, 48px);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; background: var(--paper); }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}

body {
  margin: 0;
  background: transparent;
  color: var(--ink);
  font-family: var(--body);
  font-size: 1.0625rem;
  line-height: 1.7;
  -webkit-text-size-adjust: 100%;
}

img { max-width: 100%; height: auto; display: block; }

/* ---- utilities ---- */
.wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gutter); }

.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--plum); color: #fff; padding: .6rem 1rem; z-index: 10;
}
.skip-link:focus { left: 0; }

:focus-visible { outline: 3px solid var(--teal); outline-offset: 2px; }

/* ---- type ---- */
h1, h2, h3 { font-family: var(--display); color: var(--plum); line-height: 1.08; margin: 0 0 .6em; }
h1 {
  font-family: "League Spartan", var(--body);
  font-size: clamp(2.3rem, 6.5vw, 4rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 0.98;
  max-width: 16ch;
}
h2 { font-size: clamp(1.6rem, 3.6vw, 2.3rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 700; }

p { margin: 0 0 1.1em; max-width: 62ch; }

.kicker {
  font-size: .72rem; font-weight: 600; letter-spacing: .16em;
  text-transform: uppercase; color: var(--berry); margin: 0 0 1rem;
}

.lede { font-size: clamp(1.1rem, 2vw, 1.25rem); }

.muted { color: var(--faint); font-size: .9rem; }

a { color: var(--plum); text-decoration-color: var(--butter); text-decoration-thickness: 2px; text-underline-offset: 3px; }
a:hover { text-decoration-thickness: 3px; }

.handoff {
  display: inline-block;
  font-family: var(--display); font-weight: 700;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  margin: 3rem 0 4rem;
}

mark { background: var(--butter); padding: 0 .15em; }

/* ---- header ---- */
.site-header { border-bottom: 3px solid var(--butter); }
.masthead {
  display: flex; flex-wrap: wrap; align-items: center;
  justify-content: space-between; gap: .8rem 2rem;
  padding-block: 1.1rem;
}
.masthead .logo img { width: clamp(160px, 22vw, 230px); }
.site-nav ul { display: flex; flex-wrap: wrap; gap: .25rem 1.4rem; list-style: none; margin: 0; padding: 0; }
.site-nav a {
  font-size: .92rem; font-weight: 500; text-decoration: none;
  padding-bottom: .35rem; border-bottom: 3px solid transparent;
}
.site-nav a:hover { border-bottom-color: var(--hairline); }
.site-nav a[aria-current="page"] { border-bottom-color: var(--butter); }

/* ---- hero / editorial split ---- */
.hero { padding-block: clamp(2.5rem, 7vw, 5.5rem) clamp(2rem, 5vw, 4rem); }
.split { display: grid; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }
@media (min-width: 760px) { .split { grid-template-columns: 1.15fr .85fr; } }
.split img { border: 1px solid var(--hairline); }

/* ---- the square motif ---- */
.sq-stats {
  display: grid; gap: 1px; background: var(--hairline);
  border-block: 1px solid var(--hairline);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .sq-stats { grid-template-columns: repeat(3, 1fr); } }
.sq-stats > div { background: var(--paper); padding: clamp(1.4rem, 3vw, 2.2rem) var(--gutter); }
.sq-stats strong {
  display: block; font-family: var(--display); font-weight: 700;
  font-size: clamp(1.9rem, 4vw, 2.6rem); color: var(--plum); line-height: 1.1;
}
.sq-stats span { color: var(--faint); font-size: .9rem; }

/* ---- slice grid (products) ---- */
.slice-grid {
  display: grid; gap: 1px; background: var(--hairline);
  border: 1px solid var(--hairline);
  grid-template-columns: repeat(2, 1fr);
  list-style: none; margin: 0; padding: 0;
}
@media (min-width: 760px) { .slice-grid { grid-template-columns: repeat(4, 1fr); } }
.slice-grid li { background: var(--paper); }
.slice-grid a { display: flex; flex-direction: column; height: 100%; padding: 1rem; text-decoration: none; }
.slice-grid a:hover { background: #FFFBE8; }
.slice-grid img { border: 0; }
.slice-grid .name {
  font-family: var(--display); font-weight: 700; color: var(--plum);
  font-size: 1.1rem; margin-top: .8rem;
}
.slice-grid .price { color: var(--faint); font-size: .9rem; }

/* ---- sections ---- */
.section { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.section + .section { border-top: 1px solid var(--hairline); }

/* ---- ingredient teaser / big list ---- */
.ing-line { font-family: var(--display); font-weight: 700; font-size: clamp(1.2rem, 2.6vw, 1.6rem); color: var(--plum); max-width: none; }
.big-list { list-style: none; margin: 2rem 0; padding: 0; }
.big-list li {
  font-family: var(--display); font-weight: 700; color: var(--plum);
  font-size: clamp(1.9rem, 5vw, 3.2rem); line-height: 1.22;
}
.big-list .no { font-family: var(--body); font-weight: 600; font-size: .45em; color: var(--berry); vertical-align: .5em; margin-right: .7em; }

/* ---- timeline ---- */
.timeline { list-style: none; margin: 1.5rem 0 0; padding: 0; border-left: 3px solid var(--butter); }
.timeline li { padding: 0 0 1.4rem 1.4rem; max-width: 60ch; }
.timeline time { font-family: var(--display); font-weight: 700; color: var(--plum); font-size: 1.25rem; display: block; }

/* ---- team cards ---- */
.cards { display: grid; gap: clamp(1.2rem, 3vw, 2rem); margin-top: 2rem; }
@media (min-width: 640px) { .cards { grid-template-columns: 1fr 1fr; } }
.card img { border: 1px solid var(--hairline); }
.card .placeholder {
  border: 2px dashed var(--hairline); aspect-ratio: 9/8;
  display: flex; align-items: center; justify-content: center;
  color: var(--faint); font-size: .9rem; text-align: center; padding: 1rem;
}
.card h3 { margin-top: 1rem; }
figure { margin: 0; }
figcaption { color: var(--faint); font-size: .9rem; margin-top: .6rem; }

/* ---- tables ---- */
.table-scroll { overflow-x: auto; }
table { border-collapse: collapse; width: 100%; min-width: 480px; font-size: .95rem; }
th, td { text-align: left; padding: .8rem 1rem .8rem 0; border-bottom: 1px solid var(--hairline); }
th { font-family: var(--display); color: var(--plum); font-weight: 700; }
tbody tr:hover { background: #FFFBE8; }

/* ---- product entries (bread.html) ---- */
.product { display: grid; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; padding-block: clamp(2rem, 5vw, 3.5rem); }
.product + .product { border-top: 1px solid var(--hairline); }
@media (min-width: 760px) {
  .product { grid-template-columns: .8fr 1.2fr; }
  .product:nth-of-type(even) .product-img { order: 2; }
}
.product-img img { border: 1px solid var(--hairline); }
.price-line { font-weight: 600; color: var(--plum); }

/* ---- recipe idea grid ---- */
.idea-grid { display: grid; gap: clamp(1.2rem, 3vw, 2rem); list-style: none; margin: 2rem 0 0; padding: 0; }
@media (min-width: 640px) { .idea-grid { grid-template-columns: 1fr 1fr; } }
.idea-grid img { border: 1px solid var(--hairline); }
.idea-grid h3 { margin: .9rem 0 .2rem; }
.idea-grid p { font-size: .95rem; color: var(--faint); }

.steps { padding-left: 1.3rem; max-width: 62ch; }
.steps li { margin-bottom: .5rem; }

.mascot-line { display: flex; align-items: center; gap: 1.2rem; margin-top: 3rem; }
.mascot-line img { width: 90px; flex-shrink: 0; }
.mascot-line p { font-family: var(--display); font-weight: 700; color: var(--plum); font-size: 1.3rem; margin: 0; }

/* ---- store list ---- */
.store-list { list-style: none; margin: 1.5rem 0 2rem; padding: 0; columns: 1; }
@media (min-width: 640px) { .store-list { columns: 2; column-gap: 3rem; } }
.store-list li { padding: .45rem 0; border-bottom: 1px dotted var(--hairline); break-inside: avoid; }

.map-embed { border: 1px solid var(--hairline); width: 100%; aspect-ratio: 4/3; }
@media (min-width: 760px) { .map-embed { aspect-ratio: 16/9; } }

.badge {
  display: inline-block; font-size: .72rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: .15rem .55rem; border: 1px solid var(--hairline); border-radius: 999px;
  color: var(--faint);
}
.badge.live { color: var(--teal); border-color: var(--teal); }

/* ---- Try Now floating button + popup ---- */
.try-now-btn {
  position: fixed; right: clamp(14px, 3vw, 28px); bottom: clamp(14px, 3vw, 28px);
  z-index: 50;
  font-family: "League Spartan", var(--body); font-weight: 700;
  font-size: 1rem; letter-spacing: .01em;
  background: var(--butter); color: var(--plum);
  border: 2px solid var(--plum); border-radius: 999px;
  padding: .85rem 1.5rem .7rem;
  cursor: pointer;
  box-shadow: 0 4px 0 var(--plum);
  transition: transform .12s ease, box-shadow .12s ease;
}
.try-now-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--plum); }
.try-now-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--plum); }

.try-dialog {
  border: 2px solid var(--plum); border-radius: 14px;
  background: var(--paper); color: var(--ink);
  padding: clamp(1.4rem, 4vw, 2.2rem);
  width: min(92vw, 480px);
  margin: auto;
}
.try-dialog::backdrop { background: rgba(85, 33, 96, .55); }
.try-dialog h2 {
  font-family: "League Spartan", var(--body); font-weight: 700;
  font-size: clamp(1.7rem, 5vw, 2.2rem); line-height: 1; margin-bottom: .4rem;
}
.try-dialog .sub { color: var(--faint); font-size: .95rem; margin-bottom: 1.4rem; }
.try-links { list-style: none; margin: 0 0 1.2rem; padding: 0; display: grid; gap: .6rem; }
.try-links a {
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  border: 1px solid var(--hairline); border-radius: 10px;
  padding: .85rem 1rem; text-decoration: none;
  font-weight: 600;
  transition: border-color .12s ease, background .12s ease;
}
.try-links a:hover { background: #FFFBE8; border-color: var(--plum); }
.try-links .go { color: var(--berry); font-family: var(--display); font-weight: 700; }
.try-links small { display: block; font-weight: 400; color: var(--faint); }
.try-close {
  font-family: var(--body); font-size: .9rem; font-weight: 500;
  background: none; border: none; color: var(--faint);
  cursor: pointer; padding: .4rem .2rem; text-decoration: underline;
  text-decoration-color: var(--butter); text-decoration-thickness: 2px; text-underline-offset: 3px;
}
.try-close:hover { color: var(--plum); }


/* ---- grayscale bakery backdrop (injected by backdrop.js) ---- */
.bakery-backdrop {
  position: fixed; inset: 0; z-index: -1;
  pointer-events: none; overflow: hidden;
  color: #6B6B66;
}
.bakery-backdrop svg {
  position: absolute; fill: none; stroke: currentColor;
  stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
  opacity: calc(.12 * var(--act, 1));
  transition: opacity .4s linear;
}
.bd-1  { top: 5vh;  left: 2vw;   width: 110px; }  /* open flour bag */
.bd-2  { top: 14vh; right: 4vw;  width: 180px; }  /* six ingredients floating */
.bd-3  { top: 32vh; left: 3vw;   width: 150px; }  /* mixer + crescent moon */
.bd-4  { top: 42vh; right: 5vw;  width: 120px; }  /* dough rising in mold */
.bd-5  { top: 56vh; left: 4vw;   width: 74px;  }  /* overnight clock */
.bd-6  { top: 58vh; right: 3vw;  width: 150px; }  /* deck oven */
.bd-7  { top: 74vh; left: 6vw;   width: 185px; }  /* cube loaves lined up */
.bd-8  { top: 76vh; right: 6vw;  width: 105px; }  /* slicing */
.bd-9  { top: 84vh; right: 14vw; width: 85px;  }  /* sunrise */
.bd-10 { bottom: 1vh; left: -240px; width: 210px; } /* truck leaving */
@media (max-width: 700px) {
  .bd-1, .bd-5, .bd-8 { display: none; }
  .bakery-backdrop svg { opacity: .08; }
}

@keyframes bd-rise  { 0%, 15% { transform: scaleY(.45); } 70%, 100% { transform: scaleY(1); } }
@keyframes bd-stir  { 0%, 100% { transform: rotate(-16deg); } 50% { transform: rotate(16deg); } }
@keyframes bd-fall  { 0% { transform: translateY(-14px); opacity: 0; } 25% { opacity: 1; } 80% { opacity: 1; } 100% { transform: translateY(46px); opacity: 0; } }
@keyframes bd-sway  { 0%, 100% { transform: rotate(-6deg); } 50% { transform: rotate(6deg); } }
@keyframes bd-steam { 0% { transform: translateY(6px); opacity: 0; } 30% { opacity: 1; } 100% { transform: translateY(-14px); opacity: 0; } }
@keyframes bd-puff  { 0%, 100% { transform: translateY(0); opacity: .4; } 50% { transform: translateY(-5px); opacity: 1; } }

.bd-anim-rise  { animation: bd-rise 7s ease-in-out infinite alternate; transform-box: fill-box; transform-origin: bottom center; }
.bd-anim-stir  { animation: bd-stir 3.2s ease-in-out infinite; transform-box: fill-box; transform-origin: bottom center; }
.bd-anim-sway  { animation: bd-sway 5s ease-in-out infinite; transform-box: fill-box; transform-origin: bottom center; }
.bd-anim-fall  { animation: bd-fall 4.5s linear infinite; }
.bd-anim-steam { animation: bd-steam 3.8s ease-out infinite; }
.bd-anim-puff  { animation: bd-puff 4s ease-in-out infinite; }

@keyframes bd-wobble { 0%, 100% { transform: scaleX(1); } 50% { transform: scaleX(1.18); } }
@keyframes bd-belt   { from { transform: translateX(0); } to { transform: translateX(-26px); } }
@keyframes bd-chop   { 0%, 100% { transform: translateY(0); } 45% { transform: translateY(11px); } 60% { transform: translateY(11px); } }
@keyframes bd-glow   { 0%, 100% { opacity: .25; } 50% { opacity: .9; } }
@keyframes bd-bob    { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
@keyframes bd-tick   { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes bd-drive  { 0% { transform: translateX(0); } 78% { transform: translateX(calc(100vw + 480px)); } 100% { transform: translateX(calc(100vw + 480px)); } }
@keyframes bd-shine  { 0%, 100% { opacity: .3; transform: scale(1); } 50% { opacity: 1; transform: scale(1.06); } }
@keyframes bd-spill  { 0%, 100% { transform: translate(0,0); opacity: .9; } 50% { transform: translate(4px,-6px); opacity: .3; } }

.bd-anim-spin   { animation: bd-stir 1.6s ease-in-out infinite; transform-box: fill-box; transform-origin: top center; }
.bd-anim-wobble { animation: bd-wobble 1.6s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
.bd-anim-belt   { animation: bd-belt 4s linear infinite; }
.bd-anim-chop   { animation: bd-chop 2.6s ease-in-out infinite; }
.bd-anim-glow   { animation: bd-glow 3s ease-in-out infinite; }
.bd-anim-bob    { animation: bd-bob 4s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
.bd-anim-tick   { animation: bd-tick 9s linear infinite; transform-box: fill-box; transform-origin: bottom center; }
.bd-anim-tick-f { animation: bd-tick 2.2s linear infinite; transform-box: fill-box; transform-origin: bottom center; }
.bd-anim-drive  { animation: bd-drive 16s linear infinite; }
.bd-anim-shine  { animation: bd-shine 3.5s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
.bd-anim-spill  { animation: bd-spill 3s ease-in-out infinite; }
.bd-anim-roll   { animation: bd-tick 1.1s linear infinite; transform-box: fill-box; transform-origin: center; }

@media (prefers-reduced-motion: reduce) {
  .bakery-backdrop * { animation: none !important; }
}

/* ---- footer ---- */
.site-footer {
  border-top: 3px solid var(--butter);
  margin-top: 2rem;
  padding-block: 2.5rem 3rem;
  font-size: .9rem; color: var(--faint);
}
.site-footer img { width: 150px; margin-bottom: 1rem; }
.site-footer p { margin-bottom: .4em; }
.tagline { font-family: var(--display); font-weight: 700; color: var(--plum); font-size: 1.05rem; }
