/* ==========================================================================
   Jaquelyn's on Main — shared stylesheet
   Coopersburg's Main Street cafe, bakery & coffeehouse (demo site)
   One stylesheet for every page; edit the look in one place.
   Palette + type contrast verified against WCAG AA.
   ========================================================================== */

:root {
  /* paper + ink */
  --paper:    #FBF4E6;   /* warm cream page */
  --paper-2:  #F4E9D2;   /* deeper cream for alternating bands */
  --ink:      #2A1A10;   /* espresso text (15.3:1 on cream) */
  --ink-soft: #6A4A33;   /* muted brown (7.3:1 on cream) */

  /* accents */
  --berry:      #9E2A45; /* raspberry — links, buttons (6.7:1 on cream) */
  --berry-deep: #7C1E36; /* hover */
  --gold:       #C8881F; /* decorative rules & marks only */
  --line:       #E4D3AE; /* hairlines on cream */

  /* type */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Work Sans', system-ui, -apple-system, sans-serif;
  --font-hand:    'Caveat', 'Segoe Script', cursive;

  --fs-13: 0.8125rem;
  --fs-16: 1rem;
  --fs-20: 1.25rem;
  --fs-26: 1.625rem;
  --fs-34: 2.125rem;
  --fs-46: 2.875rem;

  /* spacing — 4px grid */
  --s1: 0.25rem;  --s2: 0.5rem;  --s3: 0.75rem; --s4: 1rem;
  --s5: 1.5rem;   --s6: 2rem;    --s7: 3rem;    --s8: 4rem;  --s9: 6rem;

  --radius: 12px;
  --radius-sm: 8px;
  --maxw: 1120px;
}

/* ----- reset-ish ----- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-16);
  line-height: 1.6;
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    radial-gradient(var(--line) 0.5px, transparent 0.5px),
    radial-gradient(var(--line) 0.5px, transparent 0.5px);
  background-position: 0 0, 16px 16px;
  background-size: 32px 32px;
  -webkit-font-smoothing: antialiased;
}
img, svg { max-width: 100%; height: auto; display: block; }

/* ----- typography ----- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--ink);
  line-height: 1.08;
  margin: 0 0 var(--s4);
  font-weight: 600;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.5rem, 7vw, 4.25rem); font-weight: 900; letter-spacing: -0.025em; }
h2 { font-size: var(--fs-34); }
h3 { font-size: var(--fs-26); }
h4 { font-size: var(--fs-20); }
p  { margin: 0 0 var(--s4); }
a  { color: var(--berry); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--berry-deep); }
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--berry);
  outline-offset: 2px;
  border-radius: 4px;
}
strong { font-weight: 700; }
small { font-size: var(--fs-13); }

.prose { max-width: 68ch; }
.prose p { color: var(--ink); }
.lead { font-size: var(--fs-20); color: var(--ink-soft); max-width: 60ch; }
.muted { color: var(--ink-soft); }
.hand { font-family: var(--font-hand); color: var(--berry); font-size: var(--fs-20); }

/* ----- layout ----- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--s5); }
.section { padding-block: clamp(3rem, 8vw, 5.5rem); }
.section--alt { background-color: var(--paper-2); }
.divider { height: 4px; border: 0; background: repeating-linear-gradient(90deg, var(--gold) 0 18px, transparent 18px 30px); opacity: 0.7; margin: 0; }

.eyebrow {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-13);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--berry);
  margin: 0 0 var(--s3);
  display: flex; align-items: center; gap: var(--s2);
}
.eyebrow svg { width: 20px; height: 20px; flex: none; }

/* ----- buttons ----- */
.btn {
  display: inline-flex; align-items: center; gap: var(--s2);
  font-family: var(--font-body); font-weight: 600; font-size: var(--fs-16);
  background: var(--berry); color: #ffffff;
  padding: var(--s3) var(--s5);
  border: 2px solid var(--berry); border-radius: var(--radius-sm);
  text-decoration: none; cursor: pointer; line-height: 1.2;
  transition: transform .12s ease, background-color .12s ease;
}
.btn:hover { background: var(--berry-deep); color: #ffffff; transform: translateY(-2px); }
.btn--ghost { background: var(--paper); color: var(--berry); }
.btn--ghost:hover { background: var(--paper); color: var(--berry-deep); border-color: var(--berry-deep); }
.btn--small { padding: var(--s2) var(--s4); font-size: var(--fs-13); }
.btn-row { display: flex; flex-wrap: wrap; gap: var(--s3); }

/* ----- header / nav ----- */
.site-header {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--s4);
  padding: var(--s4) var(--s5);
  max-width: var(--maxw); margin-inline: auto;
  border-bottom: 1px solid var(--line);
}
.brand {
  font-family: var(--font-display); font-weight: 900;
  font-size: var(--fs-26); color: var(--ink); text-decoration: none;
  line-height: 1; letter-spacing: -0.02em; margin-right: auto;
}
.brand span { color: var(--berry); font-style: italic; font-weight: 500; }
.site-nav ul { list-style: none; display: flex; flex-wrap: wrap; gap: var(--s2) var(--s5); margin: 0; padding: 0; }
.site-nav a {
  font-family: var(--font-body); font-weight: 600; font-size: var(--fs-16);
  color: var(--ink); text-decoration: none; padding-block: var(--s1);
  border-bottom: 2px solid transparent;
}
.site-nav a:hover { color: var(--berry); border-bottom-color: var(--berry); }
.site-nav a[aria-current="page"] { color: var(--berry); border-bottom-color: var(--gold); }

/* ----- masthead (home opener) ----- */
.masthead { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.masthead .container { display: grid; gap: var(--s7); grid-template-columns: 1fr; align-items: end; }
.masthead h1 { margin-bottom: var(--s4); }
.masthead .tagline { font-family: var(--font-hand); color: var(--berry); font-size: clamp(1.5rem, 3.5vw, 2.125rem); margin: 0 0 var(--s4); }

/* a warm info card (today's hours / address) */
.infocard {
  background: var(--ink); color: var(--paper);
  border-radius: var(--radius); padding: var(--s6);
  box-shadow: 0 18px 40px -28px rgba(42,26,16,0.9);
}
.infocard :is(h1,h2,h3,h4,p,a,li,strong,small,span,dt,dd) { color: inherit; }
.infocard h2 { font-size: var(--fs-20); margin-bottom: var(--s3); display: flex; align-items: center; gap: var(--s2); }
.infocard svg { width: 22px; height: 22px; }
.infocard dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: var(--s2) var(--s4); }
.infocard dt { font-weight: 700; }
.infocard dd { margin: 0; }
.infocard .infocard-foot { margin-top: var(--s5); padding-top: var(--s4); border-top: 1px solid rgba(251,244,230,0.25); }
.infocard a { color: inherit; text-underline-offset: 3px; }

/* ----- generic content grid (asymmetric, no fixed 3-col) ----- */
.split { display: grid; gap: var(--s7); grid-template-columns: 1fr; align-items: start; }
.cards { display: grid; gap: var(--s5); grid-template-columns: 1fr; margin-top: var(--s6); }
.cards > article {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius); padding: var(--s6);
}
.section--alt .cards > article { background: var(--paper); }
.cards > article h3 { font-size: var(--fs-20); margin-bottom: var(--s2); }
.cards > article .mark { width: 40px; height: 40px; margin-bottom: var(--s4); color: var(--berry); }
.cards > article p:last-child { margin-bottom: 0; }

/* ----- dark band ----- */
.band--dark { background: var(--ink); color: var(--paper); }
.band--dark :is(h1,h2,h3,h4,p,li,a,strong,em,small,dt,dd,span) { color: inherit; }
.band--dark .eyebrow { color: var(--gold); background: var(--ink); }
.band--dark a { color: inherit; text-decoration: underline; text-underline-offset: 3px; }
.band--dark a:hover { color: inherit; text-decoration-thickness: 2px; }
.band--dark .btn { background: var(--berry); color: #ffffff; border-color: var(--berry); }
.band--dark .btn:hover { background: var(--berry-deep); color: #ffffff; }
.band--dark .btn--ghost { background: var(--ink); color: var(--paper); border-color: var(--paper); }
.band--dark .btn--ghost:hover { background: var(--ink); color: var(--paper); border-color: var(--gold); }

/* ----- menu lists (styled via parent; items carry no class) ----- */
.menu-block { margin-bottom: var(--s8); }
.menu-block > h3 {
  display: flex; align-items: baseline; gap: var(--s4);
  font-size: var(--fs-26); margin-bottom: var(--s5);
}
.menu-block > h3::after { content: ""; flex: 1; height: 2px; background: var(--line); }
.menu-list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--s5); }
.menu-list > li { display: grid; gap: var(--s1); }
.menu-list > li > .item-name { font-weight: 700; font-size: var(--fs-20); font-family: var(--font-display); }
.menu-list > li > .item-desc { color: var(--ink-soft); margin: 0; max-width: 60ch; }
.menu-cols { display: grid; gap: var(--s7); grid-template-columns: 1fr; }

.tag {
  display: inline-block; font-size: var(--fs-13); font-weight: 700;
  font-family: var(--font-body); letter-spacing: 0.04em;
  background: var(--paper-2); color: var(--ink);
  border: 1px solid var(--line); border-radius: 999px;
  padding: var(--s1) var(--s3); margin-left: var(--s2);
}
.note {
  background: var(--paper-2); border-left: 4px solid var(--gold);
  padding: var(--s4) var(--s5); border-radius: var(--radius-sm);
  color: var(--ink-soft); margin-top: var(--s6);
}
.note strong { color: var(--ink); }

/* ----- forms (demo, not yet connected) ----- */
.formwrap { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius); padding: var(--s7); }
.form-grid { display: grid; gap: var(--s5); grid-template-columns: 1fr; }
.form-grid > div { display: grid; gap: var(--s2); }
.form-grid label { font-weight: 600; }
.form-grid :is(input, select, textarea) {
  font-family: var(--font-body); font-size: var(--fs-16); color: var(--ink);
  background: var(--paper); border: 1px solid var(--ink-soft);
  border-radius: var(--radius-sm); padding: var(--s3) var(--s4); width: 100%;
}
.form-grid textarea { min-height: 7rem; resize: vertical; }
.form-note { font-size: var(--fs-13); color: var(--ink-soft); margin-top: var(--s4); }

/* ----- stat / quote row ----- */
.statline { display: grid; gap: var(--s5); grid-template-columns: 1fr; margin-top: var(--s6); }
.statline > div { border-top: 3px solid var(--berry); padding-top: var(--s3); }
.statline .big { font-family: var(--font-display); font-weight: 900; font-size: var(--fs-34); display: block; }

.callout { display: grid; gap: var(--s5); grid-template-columns: 1fr; align-items: center; margin-top: var(--s6); }
.mt6 { margin-top: var(--s6); }
.map { width: 100%; border: 0; border-radius: var(--radius); min-height: 360px; display: block; margin-top: var(--s6); filter: saturate(0.92) sepia(0.06); }
.visit-grid { display: grid; gap: var(--s7); grid-template-columns: 1fr; }
@media (min-width: 860px) { .visit-grid { grid-template-columns: 1fr 1fr; } }

/* ----- footer ----- */
.site-footer { background: var(--ink); color: var(--paper); margin-top: var(--s8); }
.site-footer .container { padding-block: var(--s8) var(--s6); }
.site-footer :is(h1,h2,h3,h4,p,li,a,strong,small,span,dt,dd) { color: inherit; }
.footer-grid { display: grid; gap: var(--s7); grid-template-columns: 1fr; }
.footer-grid h3 { font-family: var(--font-body); font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; font-size: var(--fs-13); margin-bottom: var(--s4); color: var(--gold); background: var(--ink); }
.footer-grid ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--s2); }
.site-footer a { color: inherit; text-decoration: none; }
.site-footer a:hover { color: inherit; text-decoration: underline; text-underline-offset: 3px; }
.footer-brand { font-family: var(--font-display); font-weight: 900; font-size: var(--fs-26); margin-bottom: var(--s3); }
.footer-brand span { font-style: italic; font-weight: 500; }
.footer-bottom { border-top: 1px solid rgba(251,244,230,0.22); margin-top: var(--s7); padding-top: var(--s5); display: flex; flex-wrap: wrap; gap: var(--s4); justify-content: space-between; }
.footer-bottom small { opacity: 0.85; }

/* decorative line-art helpers */
.artrow { display: flex; gap: var(--s5); align-items: center; color: var(--berry); margin-bottom: var(--s5); }
.artrow svg { width: 48px; height: 48px; flex: none; }

/* ====== responsive ====== */
@media (min-width: 640px) {
  .form-grid { grid-template-columns: 1fr 1fr; }
  .form-grid > .full { grid-column: 1 / -1; }
  .statline { grid-template-columns: 1fr 1fr; }
  .menu-cols { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 860px) {
  .site-header { padding-inline: var(--s6); }
  .masthead .container { grid-template-columns: 1.35fr 0.9fr; }
  .split { grid-template-columns: 1.1fr 0.9fr; }
  .split--even { grid-template-columns: 1fr 1fr; }
  .cards { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
  .callout { grid-template-columns: 1.3fr 0.7fr; }
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }
  .statline { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto; }
  .btn { transition: none; }
}
