/* =====================================================================
   Good Jake's Restaurant — shared stylesheet
   ONE file styles the whole site. Change a value here and every page
   updates. The look is controlled from the :root block right below —
   that's the first place to edit colors, fonts and spacing.

   A note on how text color works in this file: inside dark panels we set
   the color ONCE on the panel and let headings/paragraphs inherit it, so
   the same markup stays readable on the cream canvas and on dark panels.
   We only re-declare a color when we want a true accent, and when we do
   we always restate that panel's background in the same rule so contrast
   stays correct.
   ===================================================================== */

/* ---- Design tokens (edit these to re-skin the whole site) ---------- */
:root{
  --brick:#8a2b1c;        /* main red — buttons, links, accent headings */
  --brick-deep:#681f12;   /* darker red, used on hover */
  --cream:#f7efe1;        /* page background */
  --cream-2:#fbf6ec;      /* lighter surface — header bar, callouts */
  --paper:#fffaf0;        /* card surface on the cream canvas */
  --char:#2a2320;         /* charcoal — body text and dark panels */
  --char-2:#241d1a;       /* deeper charcoal — the opening panel */
  --ink:#1a1411;          /* darkest — top ribbon and footer */
  --green:#1f3d28;        /* deep herb green — the specials board */
  --gold:#e0a32b;         /* warm gold — accents on DARK panels only */
  --gold-ink:#8a5a12;     /* darker gold — for gold text on cream */
  --muted:#5b4f47;        /* soft brown — secondary copy on cream */
  --line:rgba(42,35,32,.16);

  --display:'Zilla Slab',Georgia,'Times New Roman',serif;
  --body:'Source Sans 3',-apple-system,Segoe UI,Roboto,sans-serif;
  --hand:'Caveat','Comic Sans MS',cursive;

  --r:16px;
  --r-sm:9px;
  --maxw:1160px;
  --shadow:0 18px 44px -28px rgba(40,20,10,.6);
}

/* ---- Reset / base ------------------------------------------------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background-color:var(--cream);
  color:var(--char);
  font-family:var(--body);
  font-size:1.125rem;          /* 18px base — comfortable for every age */
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img,iframe,svg{max-width:100%}
iframe{display:block}

/* Headings only carry typeface + size here — never a color — so they
   inherit the right color from whatever panel they sit in. */
h1,h2,h3{font-family:var(--display);line-height:1.08;margin:0 0 .5rem;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,6vw,4rem)}
h2{font-size:clamp(1.75rem,3.6vw,2.7rem)}
h3{font-size:1.375rem;line-height:1.2}
p{margin:0 0 1rem}
.prose{max-width:70ch}
.lede{font-size:1.375rem;line-height:1.5;max-width:60ch}

a{color:var(--brick);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--brick-deep)}
:focus-visible{outline:3px solid var(--gold-ink);outline-offset:2px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}
.eyebrow{font-family:var(--body);font-weight:700;font-size:.875rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-ink);margin:0 0 1rem;display:inline-block}

/* ---- Buttons ------------------------------------------------------ */
.btn{display:inline-block;font-family:var(--display);font-weight:600;font-size:1rem;letter-spacing:.01em;text-decoration:none;cursor:pointer;padding:.75rem 1.5rem;border-radius:999px;border:2px solid transparent;color:var(--cream);background-color:var(--brick);transition:.15s ease}
.btn:hover{color:var(--cream);background-color:var(--brick-deep);transform:translateY(-1px)}
.btn-line{color:var(--brick);background-color:var(--cream);border-color:var(--brick)}
.btn-line:hover{color:var(--cream);background-color:var(--brick)}
.btn-gold{color:var(--char);background-color:var(--gold)}
.btn-gold:hover{color:var(--char);background-color:#cf9322}
.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

/* ---- Top utility ribbon ------------------------------------------- */
.topbar{color:var(--cream);background-color:var(--ink);font-size:.875rem}
.topbar .wrap{display:flex;flex-wrap:wrap;gap:.25rem 1.5rem;justify-content:space-between;padding-top:.5rem;padding-bottom:.5rem}
.topbar b{color:var(--gold);background-color:var(--ink);font-weight:700}
.topbar a{color:var(--cream);background-color:var(--ink);text-decoration:none;font-weight:700}
.topbar a:hover{color:var(--gold);background-color:var(--ink)}

/* ---- Masthead + navigation --------------------------------------- */
.masthead{position:sticky;top:0;z-index:20;background-color:var(--cream-2);border-bottom:1px solid var(--line);box-shadow:0 6px 20px -18px rgba(0,0,0,.6)}
.masthead .wrap{display:flex;align-items:center;gap:1rem 2rem;flex-wrap:wrap;padding-top:.85rem;padding-bottom:.85rem}
.wordmark{font-family:var(--display);font-weight:700;font-size:1.75rem;line-height:1;color:var(--brick);text-decoration:none;letter-spacing:-.02em;white-space:nowrap}
.wordmark span{display:block;font-family:var(--body);font-weight:600;font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--char)}
.mainnav{margin-left:auto;display:flex;align-items:center;gap:.25rem 1.25rem;flex-wrap:wrap}
.mainnav a{color:var(--char);text-decoration:none;font-family:var(--display);font-weight:600;font-size:1rem;padding:.25rem 0;border-bottom:2px solid transparent}
.mainnav a:hover{color:var(--brick)}
.mainnav a[aria-current="page"]{color:var(--brick);border-bottom-color:var(--brick)}
.mainnav .btn{color:var(--cream);background-color:var(--brick)}
.mainnav .btn:hover{color:var(--cream);background-color:var(--brick-deep)}

/* ---- Section rhythm ---------------------------------------------- */
main section{padding-top:clamp(3rem,7vw,6rem);padding-bottom:clamp(3rem,7vw,6rem)}
.section-head{max-width:50ch;margin-bottom:2.5rem}

/* ---- Marquee (the opening statement) ----------------------------- */
.marquee{position:relative;overflow:hidden;color:var(--cream);background-color:var(--char-2)}
.marquee::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 12% 0%, rgba(181,64,42,.55), transparent 55%),radial-gradient(90% 80% at 100% 100%, rgba(224,163,43,.26), transparent 60%);pointer-events:none}
.marquee .wrap{position:relative;display:grid;grid-template-columns:1.4fr .9fr;gap:3rem;align-items:center}
.marquee h1{max-width:15ch}
.marquee .lede{max-width:46ch}
.marquee .eyebrow{color:var(--gold);background-color:var(--char-2)}

/* the "today" panel beside the headline */
.daycard{background-color:var(--brick);color:var(--cream);border-radius:var(--r);padding:1.75rem;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.25)}
.daycard h2{font-size:1.375rem}
.daycard dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:1rem 0 0;font-size:1rem}
.daycard dt{font-family:var(--display);font-weight:700}
.daycard dd{margin:0;text-align:right}
.daycard .shut{opacity:.82}
.daycard .scrawl{font-family:var(--hand);font-size:1.75rem;line-height:1.15;margin-top:1rem;color:var(--gold);background-color:var(--brick)}

/* ---- "Known for" list (auto-fit, unclassed children) ------------- */
.known-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}
.known-list>li{background-color:var(--paper);border:1px solid var(--line);border-left:5px solid var(--brick);border-radius:var(--r-sm);padding:1.5rem}
.known-list>li b{display:block;font-family:var(--display);font-size:1.375rem;color:var(--brick);background-color:var(--paper);margin-bottom:.25rem;font-weight:700}
.known-list>li:nth-child(2){border-left-color:var(--gold-ink)}
.known-list>li:nth-child(3){border-left-color:var(--green)}
.known-list>li:nth-child(4){border-left-color:var(--char)}

/* ---- Editorial alternating bands (copy + photo slot) ------------- */
.band .wrap{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.band .copy h2{color:var(--brick);background-color:var(--cream)}
.band.flip .copy{order:2}
.band.flip .plate{order:1}

/* Photo slots: warm panels where the client's real photos drop in.
   Styled to look finished in the demo, not empty. The dish name doubles
   as a caption once the photo is in place. */
.plate{position:relative;overflow:hidden;border-radius:var(--r);min-height:320px;display:flex;align-items:flex-end;color:var(--cream);background-color:var(--char);border:1px solid rgba(0,0,0,.25);box-shadow:var(--shadow)}
.plate::before{content:"";position:absolute;inset:0;background:linear-gradient(150deg, rgba(181,64,42,.5), transparent 55%),linear-gradient(0deg, rgba(0,0,0,.58), transparent 62%);pointer-events:none}
.plate .cap{position:relative;padding:1.5rem;width:100%}
.plate .cap b{display:block;font-family:var(--display);font-weight:700;font-size:1.75rem;line-height:1.05}
.plate .cap span{display:block;font-family:var(--hand);font-size:1.75rem;color:var(--gold);background-color:var(--char)}
.plate.tone-brick{background-color:var(--brick)}
.plate.tone-green{background-color:var(--green)}
.plate.tone-ink{background-color:var(--ink)}

/* ---- Specials board --------------------------------------------- */
.specials{color:var(--cream);background-color:var(--green)}
.specials .wrap{display:grid;grid-template-columns:auto 1fr;gap:2.5rem;align-items:center}
.specials .board-label{font-family:var(--hand);font-size:clamp(2.5rem,6vw,4rem);line-height:.95;color:var(--gold);background-color:var(--green)}
.specials .prose{max-width:54ch}

/* ---- Ratings strip ---------------------------------------------- */
.statrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1.25rem;margin-top:1.5rem}
.statrow>div{border:1px solid var(--line);border-top:5px solid var(--gold-ink);border-radius:var(--r-sm);padding:1.5rem;background-color:var(--paper)}
.statrow b{display:block;font-family:var(--display);font-size:2.5rem;line-height:1;color:var(--brick);background-color:var(--paper)}
.statrow span{font-size:.875rem;letter-spacing:.04em;text-transform:uppercase}

/* ---- Invitation / closing call-to-action ------------------------ */
.invite{color:var(--cream);background-color:var(--brick)}
.invite .eyebrow{color:var(--cream);background-color:var(--brick)}
.invite h2{max-width:18ch}
.invite .prose{max-width:52ch}
.invite .btn-line{color:var(--cream);background-color:var(--brick);border-color:var(--cream)}
.invite .btn-line:hover{color:var(--brick);background-color:var(--cream)}

/* ---- Generic content blocks (inner pages) ----------------------- */
.split{display:grid;grid-template-columns:1.3fr .9fr;gap:3rem;align-items:start}
.panel{background-color:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.75rem}
.panel.dark{color:var(--cream);background-color:var(--char-2)}
.panel.dark a{color:var(--gold);background-color:var(--char-2)}
.callout{border-left:5px solid var(--gold-ink);background-color:var(--cream-2);padding:1.25rem 1.5rem;border-radius:0 var(--r-sm) var(--r-sm) 0;margin:1.5rem 0}

/* ---- Menu listing ----------------------------------------------- */
.menu-nav{position:sticky;top:64px;z-index:10;background-color:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);padding:.6rem 1rem;margin-bottom:2.5rem;display:flex;gap:.5rem 1.25rem;flex-wrap:wrap;overflow-x:auto}
.menu-nav a{font-family:var(--display);font-weight:600;font-size:1rem;text-decoration:none;color:var(--char);white-space:nowrap}
.menu-nav a:hover{color:var(--brick)}
.menu-cats>section{border-top:2px solid var(--line);padding-top:2rem;margin-top:2.5rem}
.menu-cats>section:first-of-type{border-top:0;margin-top:0;padding-top:0}
.menu-cats h2{color:var(--brick);background-color:var(--cream)}
.menu-cats .cat-lead{max-width:64ch}
.dish-list{list-style:none;margin:1rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.6rem 2.5rem}
.dish-list>li{border-bottom:1px dashed var(--line);padding:.6rem 0}
.dish-list>li b{font-family:var(--display);font-weight:600}
.dish-list>li em{display:block;font-style:normal;font-size:.875rem;color:var(--muted);background-color:var(--cream)}

/* ---- Ordering options ------------------------------------------- */
.order-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.order-list>li{border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;background-color:var(--paper);display:flex;flex-direction:column}
.order-list>li b{font-family:var(--display);font-size:1.375rem;color:var(--brick);background-color:var(--paper)}
.order-list>li em{font-style:normal;color:var(--muted);background-color:var(--paper);flex:1;margin:.35rem 0 1rem}

/* ---- Forms ------------------------------------------------------ */
.form-note{border-left:5px solid var(--brick);background-color:var(--cream-2);padding:1rem 1.25rem;border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:1.5rem;font-size:1rem}
form.demo{display:grid;gap:1.1rem;max-width:34rem}
form.demo>div{display:grid;gap:.35rem}
form.demo label{font-family:var(--display);font-weight:600;font-size:1rem}
form.demo input,form.demo textarea,form.demo select{font-family:var(--body);font-size:1rem;padding:.7rem .85rem;border:1.5px solid var(--line);border-radius:var(--r-sm);background-color:var(--paper);color:var(--char);width:100%}
form.demo input:focus,form.demo textarea:focus,form.demo select:focus{border-color:var(--brick);outline:none;box-shadow:0 0 0 3px rgba(138,43,28,.18)}
form.demo textarea{min-height:7rem;resize:vertical}

/* ---- Find-us facts list ----------------------------------------- */
.facts{list-style:none;margin:0;padding:0;display:grid;gap:1rem}
.facts>li{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start;border-bottom:1px solid var(--line);padding-bottom:1rem}
.facts>li b{font-family:var(--display);color:var(--brick);background-color:var(--cream)}
.map{width:100%;height:360px;border:0;border-radius:var(--r);box-shadow:var(--shadow)}

/* ---- Footer ----------------------------------------------------- */
.sitefoot{color:var(--cream);background-color:var(--ink);padding-top:3.5rem;padding-bottom:2rem}
.sitefoot .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.sitefoot .foot-mark{font-family:var(--display);font-weight:700;font-size:1.75rem;color:var(--gold);background-color:var(--ink);line-height:1;margin:0 0 .75rem}
.sitefoot .foot-t{font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);background-color:var(--ink);margin:0 0 .5rem}
.sitefoot a{color:var(--cream);background-color:var(--ink);text-decoration:none;border-bottom:1px solid rgba(247,239,225,.3)}
.sitefoot a:hover{color:var(--gold);background-color:var(--ink)}
.sitefoot .legal{margin-top:2.5rem;border-top:1px solid rgba(247,239,225,.2);padding-top:1.25rem;font-size:.875rem;text-align:center;color:var(--cream);background-color:var(--ink)}

/* ---- Skip link (keyboard accessibility) ------------------------- */
.skip{position:absolute;left:-9999px;top:0;background-color:var(--gold);color:var(--char);padding:.5rem 1rem;border-radius:0 0 var(--r-sm) 0;z-index:50;text-decoration:none}
.skip:focus{left:0}

/* =====================================================================
   Responsive — stack the multi-column layouts on tablets and phones
   ===================================================================== */
@media (max-width:880px){
  .marquee .wrap,.band .wrap,.split,.specials .wrap{grid-template-columns:1fr;gap:2rem}
  .sitefoot .cols{grid-template-columns:1fr 1fr}
  .band.flip .copy{order:0}
  .band.flip .plate{order:0}
  .menu-nav{top:0}
}
@media (max-width:560px){
  body{font-size:1.0625rem}
  .mainnav{margin-left:0;width:100%;gap:.75rem 1rem}
  .sitefoot .cols{grid-template-columns:1fr}
  .daycard dd{text-align:left}
}
