/* =====================================================================
   DOG ET AL — shared design system
   Extracted from the original homepage and extended for a 3-page site.
   Brand tokens are unchanged. New components are grouped at the bottom.
   ===================================================================== */

:root{
  --red:#E2231A; --red-deep:#B81910; --ink:#171311; --cream:#FBF7F0;
  --line:#E8DFD0; --muted:#6E655B; --gold:#E0A82E; --white:#fff;
  --shadow:0 18px 40px -26px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream);font-size:17px;line-height:1.5}
a{color:inherit}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px;line-height:.98;text-transform:uppercase;margin:0}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

/* checkered signature divider — echoes the red-checkered baskets */
.checker{height:12px;background:
  conic-gradient(var(--red) 90deg,transparent 90deg 180deg,var(--red) 180deg 270deg,transparent 270deg) 0 0/12px 12px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px;padding:0 26px;border-radius:10px;
  font-family:'Anton',sans-serif;letter-spacing:1px;text-transform:uppercase;font-size:18px;text-decoration:none;border:2px solid transparent;cursor:pointer;transition:.14s}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--cream)}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px}

/* header */
header{position:sticky;top:0;z-index:100;background:var(--ink);color:#fff}
.bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 20px;max-width:1100px;margin:0 auto}
.logo{display:inline-flex;align-items:center;text-decoration:none;line-height:0}
.logo img{height:42px;width:auto;display:block}
nav.main{display:flex;align-items:center;gap:24px}
nav.main a.lnk{font-weight:700;font-size:15px;text-decoration:none;color:#fff;text-transform:uppercase;letter-spacing:.04em}
nav.main a.lnk:hover{color:var(--gold)}
nav.main a.lnk[aria-current="page"]{color:var(--gold);text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:2px}
.call{font-weight:700;text-decoration:none;color:#fff;font-size:15px;white-space:nowrap}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:26px;cursor:pointer;min-height:44px;min-width:44px}

/* seasonal / promo ribbon — editable strip under the header.
   Change the text or delete the whole .promo element to remove it. */
.promo{background:var(--gold);color:var(--ink);text-align:center;font-weight:700;font-size:15px;padding:9px 20px}
.promo a{font-weight:800;text-decoration:underline;text-underline-offset:3px}

/* hero */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;padding:54px 20px 60px;max-width:1100px;margin:0 auto}
.eyebrow{font-weight:800;letter-spacing:.18em;text-transform:uppercase;font-size:13px;color:var(--gold);margin-bottom:14px}
.hero h1{font-size:clamp(54px,9vw,104px);color:#fff}
.hero h1 em{font-style:normal;color:var(--red);display:block}
.hero p.lead{font-size:19px;color:#E9E2D8;margin:18px 0 26px;max-width:42ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.hero-photo{position:relative;border-radius:16px;min-height:340px;overflow:hidden;background:
  radial-gradient(120% 120% at 70% 20%,#3a2f29 0%,#241c18 60%);border:1px solid #3a2f29;display:flex;align-items:center;justify-content:center;text-align:center;box-shadow:var(--shadow)}
.hero-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.hero-photo .ph-tag{position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:5px 9px;border-radius:6px}
.hero-photo .ph-label{font-family:'Anton',sans-serif;font-size:26px;color:#6b5d52;text-transform:uppercase;padding:0 20px}

/* info bar */
.info{background:var(--red);color:#fff}
.info .wrap{display:flex;flex-wrap:wrap;gap:8px 34px;padding:14px 20px;align-items:center;justify-content:center;text-align:center}
.info a,.info span{font-weight:700;font-size:15px;text-decoration:none;color:#fff}
.info .edit{background:rgba(0,0,0,.2);padding:2px 8px;border-radius:5px;font-weight:600}

/* sections */
section{padding:62px 0}
.sec-head{text-align:center;margin-bottom:38px}
.sec-head .kicker{font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:13px;color:var(--red);margin-bottom:8px}
.sec-head h2{font-size:clamp(34px,5.5vw,52px)}
.sec-head p{color:var(--muted);max-width:54ch;margin:12px auto 0}

/* menu preview cards (homepage) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card .pic{aspect-ratio:4/3;background:linear-gradient(135deg,#F4D9A6,#E9B04E);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card .pic.alt{background:linear-gradient(135deg,#E7B7A0,#C8553B)}
.card .pic img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.card .pic .ph-label{font-family:'Anton',sans-serif;color:rgba(0,0,0,.32);font-size:22px;text-transform:uppercase;text-align:center;padding:0 14px}
.card .pic .ph-tag{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.45);color:#fff;font-size:10px;letter-spacing:.05em;text-transform:uppercase;padding:4px 8px;border-radius:5px}
.card .body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.card h3{font-size:22px}
.card .price{font-family:'Anton',sans-serif;font-size:22px;color:var(--red)}
.card .desc{color:var(--muted);font-size:15px}
.menu-foot{text-align:center;margin-top:34px}
.combo{display:inline-block;margin-top:14px;background:var(--gold);color:var(--ink);font-weight:700;padding:8px 16px;border-radius:999px;font-size:15px}

/* catering */
.catering{background:var(--ink);color:#fff}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.catering h2{font-size:clamp(34px,5.5vw,54px);color:#fff}
.catering h2 em{font-style:normal;color:var(--red)}
.catering p{color:#E9E2D8;margin:16px 0}
.catering .sec-head{text-align:center}
.catering .sec-head p{max-width:54ch;margin-left:auto;margin-right:auto}
.cat-list{list-style:none;padding:0;margin:18px 0;display:grid;gap:10px}
.cat-list li{padding-left:28px;position:relative;color:#F3EEE6}
.cat-list li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:12px;background:var(--red);border-radius:3px}
.cat-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.cat-card{background:#241c18;border:1px solid #3a2f29;border-radius:16px;padding:26px;box-shadow:var(--shadow)}
.cat-card .big{font-family:'Anton',sans-serif;font-size:40px;color:var(--gold);line-height:1}
.cat-card a.line{display:block;color:#fff;font-weight:700;text-decoration:none;margin-top:6px;font-size:18px}

/* why */
.why .cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}
.why .item{text-align:center;padding:8px}
.why .item .n{font-family:'Anton',sans-serif;font-size:30px;color:var(--red)}
.why .item h3{font-size:20px;margin:8px 0 6px}
.why .item p{color:var(--muted);font-size:15px;margin:0}

/* order band */
.band{background:var(--red);color:#fff;text-align:center}
.band h2{font-size:clamp(32px,5vw,50px);color:#fff}
.band p{margin:12px 0 24px;font-size:18px;color:#fff}

/* footer / location */
footer{background:var(--ink);color:#D8CFC2}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:30px;padding:54px 20px 30px;max-width:1100px;margin:0 auto}
footer .logo{margin-bottom:12px}
footer .logo img{height:54px}
footer h4{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:18px;margin:0 0 12px}
footer a{color:#D8CFC2;text-decoration:none;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.map{border:0;width:100%;height:200px;border-radius:12px;margin-top:8px;filter:grayscale(.2)}
.socials{display:flex;gap:14px;margin-top:6px}
.socials a{font-weight:700;color:#fff}
.legal{border-top:1px solid #2c241f;text-align:center;padding:18px;font-size:13px;color:#8a7f72}

/* sticky mobile order bar */
.mobile-order{display:none;position:fixed;left:0;right:0;bottom:0;z-index:120;padding:10px 14px;background:rgba(23,19,17,.96);backdrop-filter:blur(6px);border-top:1px solid #2c241f}
.mobile-order .btn{width:100%}

/* =====================================================================
   NEW: full menu page
   ===================================================================== */
.page-head{background:var(--ink);color:#fff;text-align:center;padding:48px 20px 44px}
.page-head .eyebrow{margin-bottom:12px}
.page-head h1{font-size:clamp(44px,8vw,80px);color:#fff}
.page-head h1 em{font-style:normal;color:var(--red)}
.page-head p{color:#E9E2D8;max-width:56ch;margin:14px auto 0}

.menu-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:10px}
.menu-photos .shot{aspect-ratio:4/3;border-radius:14px;overflow:hidden;position:relative;background:linear-gradient(135deg,#F4D9A6,#E9B04E);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.menu-photos .shot.alt{background:linear-gradient(135deg,#E7B7A0,#C8553B)}
.menu-photos .shot img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.menu-photos .shot .ph-label{font-family:'Anton',sans-serif;color:rgba(0,0,0,.32);font-size:18px;text-transform:uppercase;text-align:center;padding:0 12px}
.menu-photos .shot .ph-tag{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.45);color:#fff;font-size:10px;letter-spacing:.05em;text-transform:uppercase;padding:4px 8px;border-radius:5px}

.menu-section{margin-top:46px}
.menu-section > h2{font-size:clamp(28px,4.5vw,40px);color:var(--ink);display:flex;align-items:center;gap:14px}
.menu-section > h2::after{content:"";flex:1;height:3px;background:
  conic-gradient(var(--red) 90deg,transparent 90deg 180deg,var(--red) 180deg 270deg,transparent 270deg) 0 0/8px 8px}
.menu-note{color:var(--muted);font-size:15px;margin:6px 0 18px}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:6px 40px}
@media(max-width:760px){.menu-list{grid-template-columns:1fr}}
.mitem{display:grid;grid-template-columns:1fr auto;gap:4px 12px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--line)}
.mitem .nm{font-weight:700;font-size:17px}
.mitem .pr{font-family:'Anton',sans-serif;font-size:20px;color:var(--red);white-space:nowrap}
.mitem .ds{grid-column:1 / -1;color:var(--muted);font-size:14.5px;margin-top:2px}
.mitem .tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--red-deep);background:#FBE3DF;border-radius:5px;padding:2px 7px;margin-left:8px;vertical-align:middle}

.toppings{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;margin-top:28px;box-shadow:var(--shadow)}
.toppings h3{font-size:22px;margin-bottom:6px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.chip{background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:14px;font-weight:600}
.chip.paid{background:#FBE3DF;border-color:#f3c8c2;color:var(--red-deep)}

/* =====================================================================
   NEW: catering page + request form
   ===================================================================== */
.cat-hero{background:var(--ink);color:#fff}
.cat-hero .hero-grid{padding:50px 20px 54px}
.cat-hero h1{font-size:clamp(46px,8vw,86px);color:#fff}
.cat-hero h1 em{font-style:normal;color:var(--red);display:block}
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}
.pkg{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.pkg.feature{border:2px solid var(--red);position:relative}
.pkg.feature::before{content:"Most Popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.pkg h3{font-size:24px;color:var(--ink)}
.pkg .who{color:var(--muted);font-size:14px;margin:6px 0 14px}
.pkg ul{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:9px}
.pkg ul li{padding-left:24px;position:relative;font-size:15px}
.pkg ul li::before{content:"";position:absolute;left:0;top:7px;width:10px;height:10px;background:var(--gold);border-radius:3px}
.pkg .foot{margin-top:auto}
.pkg .price{font-family:'Anton',sans-serif;font-size:32px;color:var(--red);line-height:1;margin:2px 0 14px}
.pkg .price small{font-family:'Inter',sans-serif;font-size:14px;color:var(--muted);font-weight:600}
.pkg.mobile{background:var(--ink);border-color:var(--ink);color:#fff;position:relative}
.pkg.mobile::before{content:"On-Site Catering";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--ink);font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:999px;white-space:nowrap}
.pkg.mobile h3{color:#fff}
.pkg.mobile .who{color:var(--gold)}
.pkg.mobile ul li{color:#F3EEE6}
.pkg.mobile ul li::before{background:var(--gold)}
.pkg.mobile .price{color:var(--gold)}
.pkg.mobile .price small{color:#B7ACA0}
.pkg-note{text-align:center;color:var(--muted);font-size:14.5px;margin-top:24px}

.form-wrap{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:30px;max-width:760px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.field label{font-weight:700;font-size:14px}
.field .req{color:var(--red)}
.field input,.field select,.field textarea{font-family:inherit;font-size:16px;color:var(--ink);background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:12px 14px;min-height:48px}
.field textarea{min-height:104px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:3px solid var(--gold);outline-offset:1px;border-color:var(--gold)}
.form-actions{margin-top:22px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.form-hint{color:var(--muted);font-size:13.5px;margin-top:14px}
.form-fallback{color:var(--muted);font-size:14px;margin-top:10px}

@media(max-width:760px){
  .pkg-grid{grid-template-columns:1fr}
  .menu-photos{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
}

/* =====================================================================
   NEW: Our Story / Careers / Merch
   ===================================================================== */
.story-row{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-bottom:46px}
.story-row h2{font-size:clamp(28px,4.5vw,42px);margin-bottom:14px}
.story-row h2 em{font-style:normal;color:var(--red)}
.story-row p{color:#4a463f;font-size:16.5px;margin-bottom:12px;max-width:52ch}
.story-img{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--ink)}
.story-img.tall{aspect-ratio:3/4}
.story-img img{width:100%;height:100%;object-fit:cover;display:block}
.story-row.flip .story-img{order:-1}

.perk-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.perk{background:#fff;border:1px solid var(--line);border-top:4px solid var(--red);border-radius:14px;padding:24px 20px;text-align:center;box-shadow:var(--shadow)}
.perk .big{font-family:'Anton',sans-serif;font-size:30px;color:var(--red);line-height:1}
.perk h3{font-size:18px;margin:10px 0 4px}
.perk p{color:var(--muted);font-size:14px;margin:0}

.merch-note{max-width:620px;margin:0 auto;text-align:center}
.merch-note .mark{height:120px;width:auto;margin:0 auto 22px;display:block}

@media(max-width:820px){.perk-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){
  .story-row{grid-template-columns:1fr;gap:22px;margin-bottom:38px}
  .story-row.flip .story-img{order:0}
}

/* =====================================================================
   responsive (shared)
   ===================================================================== */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;padding:40px 20px 46px}
  .hero-photo{min-height:240px}
  .cards{grid-template-columns:1fr 1fr}
  .cat-grid,.foot-grid{grid-template-columns:1fr}
}
@media(max-width:680px){
  nav.main{position:fixed;inset:60px 0 auto 0;background:var(--ink);flex-direction:column;gap:0;padding:10px 0 16px;border-top:1px solid #2c241f;transform:translateY(-130%);transition:transform .25s;max-height:calc(100vh - 60px);overflow:auto}
  nav.main.open{transform:translateY(0)}
  nav.main a.lnk{width:100%;padding:14px 24px;min-height:48px;display:flex;align-items:center}
  nav.main .call{padding:14px 24px}
  nav.main .btn{margin:8px 24px 0}
  .menu-toggle{display:block}
  .cards,.why .cards3,.menu-photos{grid-template-columns:1fr}
  .mobile-order{display:block}
  body{padding-bottom:76px}
  section{padding:48px 0}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
