/* ===================================================================
   Certified Restaurant — shared design system (enterprise site)
   Palette: Bistro Green / Brass Gold / Warm Cream
   Component classes available to all pages:
   layout:   .wrap  .section .section-alt .section-tight  .center
   header:   .site-header .nav .logo .nav-links .has-sub .submenu .nav-cta .nav-toggle
   type:     .eyebrow .h1 .h2 .h3 .lead  .prose
   buttons:  .btn .btn-primary .btn-ghost .btn-gold  .btn-lg
   hero:     .page-hero  (inner pages)   .home-hero
   grids:    .grid-2 .grid-3 .grid-4   .card .feature .svc-card
   bits:     .eyebrow-c .pill .tag .strip .stat .quote .cta-band .breadcrumb
   footer:   .site-footer .foot-grid .foot-bottom
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap');
:root{
  --green:#1A1A1C; --green-2:#2E2E33; --green-3:#0E0E10;
  --gold:#EFAE1A; --gold-d:#8A5E00;
  --fresh:#22A85A;
  --cream:#F5F5F3; --white:#fff;
  --ink:#1C1C1E; --slate:#5C5C62; --line:#E7E7E3;
  --serif:"Space Grotesk","Inter","Helvetica Neue",Arial,sans-serif;
  --sans:"Inter","Helvetica Neue",Helvetica,Arial,sans-serif;
  --shadow:0 20px 50px rgba(16,16,20,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4,.serif{font-family:var(--serif);font-weight:600;letter-spacing:-.3px;line-height:1.12}
.center{text-align:center}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(250,246,236,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:70px}
.logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo svg{width:38px;height:38px}
.logo .wm{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--green);letter-spacing:-.2px;white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:26px;margin-left:auto}
.nav-links>a,.has-sub>a{font-size:15px;font-weight:500;color:var(--ink);padding:8px 0;position:relative;white-space:nowrap}
.nav-links>a:hover,.has-sub>a:hover{color:var(--green)}
.has-sub{position:relative}
.has-sub>a::after{content:"";display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:6px;vertical-align:middle;opacity:.6}
.submenu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:var(--white);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:10px;min-width:280px;opacity:0;visibility:hidden;transition:.16s}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(4px)}
.submenu a{display:block;padding:10px 14px;border-radius:8px;font-size:14.5px;color:var(--ink)}
.submenu a:hover{background:var(--cream);color:var(--green)}
.nav-cta{margin-left:6px}
.nav-login{font-size:14px;font-weight:600;color:var(--green);white-space:nowrap}
.nav-login:hover{color:var(--gold-d)}
.nav-toggle{display:none;background:none;border:1.5px solid var(--line);border-radius:8px;padding:8px 10px;cursor:pointer;color:var(--green);font-size:14px;font-weight:600}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:var(--sans);font-weight:600;font-size:15px;padding:13px 24px;border-radius:7px;cursor:pointer;border:1.5px solid transparent;transition:.15s;white-space:nowrap}
.btn-lg{padding:16px 32px;font-size:16px}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-primary:hover{background:var(--green-2);border-color:var(--green-2)}
.btn-gold{background:var(--gold);color:var(--green-3);border-color:var(--gold)}
.btn-gold:hover{background:#f4c23e}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}

/* ---------- Typography helpers ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--gold-d);font-weight:700;font-size:13px;letter-spacing:1.6px;text-transform:uppercase}
.eyebrow-c{display:block;text-align:center;color:var(--gold-d);font-weight:700;font-size:13px;letter-spacing:1.6px;text-transform:uppercase;margin-bottom:14px}
.h1{font-size:clamp(38px,5.6vw,62px);color:var(--green)}
.h2{font-size:clamp(29px,3.6vw,44px);color:var(--green)}
.h3{font-size:22px;color:var(--green)}
.lead{font-size:19px;color:var(--slate)}
.lead-c{font-size:19px;color:var(--slate);text-align:center;max-width:660px;margin:0 auto 48px}

/* ---------- Sections ---------- */
.section{padding:80px 0}
.section-tight{padding:56px 0}
.section-alt{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(rgba(18,18,20,.84),rgba(18,18,20,.93)),url(/img/page-hero.jpg) center/cover;color:#fff;padding:72px 0 64px}
.page-hero .eyebrow{color:var(--gold)}
.page-hero h1{color:#fff;font-size:clamp(34px,5vw,56px);margin:14px 0 16px}
.page-hero p{color:#dad4c8;font-size:19px;max-width:640px}
.breadcrumb{font-size:13px;color:#a89f90;margin-bottom:6px}
.breadcrumb a{color:#dad4c8}

/* ---------- Grids & cards ---------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.card{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:30px}
.feature .ic,.svc-card .ic{width:46px;height:46px;border-radius:11px;background:var(--cream);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feature .ic svg,.svc-card .ic svg{width:24px;height:24px;stroke:var(--green);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.feature h3,.svc-card h3{font-size:19px;margin-bottom:8px}
.feature p,.svc-card p{color:var(--slate);font-size:15px}
.svc-card{display:block;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:28px;transition:.15s}
.svc-card:hover{border-color:var(--gold);box-shadow:var(--shadow);transform:translateY(-2px)}
.svc-card .more{display:inline-block;margin-top:12px;color:var(--gold-d);font-weight:700;font-size:14px}

/* ---------- Pills / tags ---------- */
.pill{display:inline-block;background:#efe7d8;color:var(--green);font-weight:700;font-size:13px;padding:6px 13px;border-radius:100px}
.tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:100px;background:var(--gold);color:var(--green-3)}

/* ---------- Trust strip ---------- */
.strip{background:var(--white);color:var(--ink);padding:36px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.strip .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:22px;text-align:center}
.stat .n{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--green)}
.stat .n .u{font-size:15px;font-weight:600;color:var(--gold-d)}
.stat .l{font-size:13px;color:var(--slate);margin-top:3px}

/* ---------- Quote / testimonial ---------- */
.quote{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:28px}
.quote p{font-size:16px;color:var(--ink);font-style:italic;margin-bottom:16px}
.quote .who{font-weight:700;font-size:14px;color:var(--green)}
.quote .who span{display:block;font-weight:500;color:var(--slate);font-style:normal}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(rgba(18,18,20,.82),rgba(18,18,20,.9)),url(/img/cta.jpg) center/cover;color:#fff;text-align:center;padding:64px 24px;border-radius:0}
.cta-band h2{color:#fff;font-size:clamp(28px,3.4vw,40px);margin-bottom:12px}
.cta-band p{color:#dad4c8;font-size:19px;max-width:560px;margin:0 auto 26px}

/* ---------- Prose (articles) ---------- */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:28px;margin:36px 0 12px}
.prose h3{font-size:21px;margin:28px 0 8px}
.prose p{font-size:17px;color:#33392f;margin-bottom:16px}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{font-size:17px;color:#33392f;margin-bottom:10px}
.prose a{color:var(--gold-d);font-weight:600;text-decoration:underline}
.prose .lede{font-size:20px;color:var(--slate)}

/* ---------- Check list ---------- */
.checks{list-style:none}
.checks li{position:relative;padding:9px 0 9px 30px;font-size:16px;border-top:1px solid var(--line)}
.checks li:first-child{border-top:none}
.checks li::before{content:"";position:absolute;left:0;top:13px;width:16px;height:9px;border-left:2.5px solid var(--fresh);border-bottom:2.5px solid var(--fresh);transform:rotate(-45deg)}

/* ---------- Footer ---------- */
.site-footer{background:#EEEDE7;color:var(--slate);padding:56px 0 28px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.foot-grid h4{color:var(--green);font-family:var(--sans);font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px}
.foot-grid a{display:block;color:var(--slate);font-size:14.5px;padding:5px 0}
.foot-grid a:hover{color:var(--gold-d)}
.foot-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.foot-logo svg{width:34px;height:34px}
.foot-logo .wm{font-family:var(--serif);font-size:18px;color:var(--green)}
.foot-blurb{font-size:14px;color:var(--slate);max-width:280px}
.foot-bottom{border-top:1px solid var(--line);margin-top:36px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--slate)}
.foot-bottom a{color:var(--slate)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .grid-3{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:760px){
  .nav-links{position:fixed;top:70px;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:10px 24px 20px;display:none;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links>a,.has-sub{width:100%;border-top:1px solid var(--line);padding:6px 0}
  .has-sub>a::after{float:right;margin-top:8px}
  .submenu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;padding:0 0 8px 12px;min-width:0;display:none}
  .has-sub.open .submenu{display:block}
  .nav-toggle{display:inline-block}
  .nav-cta{padding:9px 15px;font-size:13.5px}
  .nav-login{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .section{padding:56px 0}
  .strip .wrap{gap:18px}
}
@media(max-width:430px){ .logo .wm{display:none} }

/* ---------- National locations directory ---------- */
.region-h{font-size:13px;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold-d);font-weight:700;margin:44px 0 20px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.region-h:first-child{margin-top:0}
.states-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:26px 28px}
.state-block h3{font-size:16px;margin-bottom:7px}
.state-block h3 a{color:var(--green)}
.state-block h3 a:hover{color:var(--gold-d)}
.state-block .ct{color:var(--slate);font-weight:500;font-size:13px}
.city-list a{display:block;color:var(--slate);font-size:13.5px;padding:3px 0}
.city-list a:hover{color:var(--green)}
.cities-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:780px;margin:0 auto}
.city-chip{background:var(--white);border:1px solid var(--line);border-radius:100px;padding:8px 16px;font-size:14px;font-weight:500;color:var(--green)}
.city-chip:hover{border-color:var(--gold);color:var(--gold-d)}

/* ---------- Elevation: type, motion, micro-interactions, mobile CTA ---------- */
h1,h2,h3,h4,.serif{letter-spacing:-1.1px}
.h1,.h2{font-weight:700}
.h1,.page-hero h1{line-height:1.03}
.nav-links>a::before,.has-sub>a::before{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .22s ease}
.nav-links>a:hover::before,.has-sub>a:hover::before{width:100%}
.svc-card,.btn,.card{transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .15s ease}
.btn-primary:hover,.btn-gold:hover{transform:translateY(-1px)}
.will-reveal{opacity:0}
.will-reveal.in{animation:revealUp .7s cubic-bezier(.2,.7,.2,1) both}
@keyframes revealUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.mcta{display:none}
@media(prefers-reduced-motion:reduce){.will-reveal{opacity:1!important}.will-reveal.in{animation:none}}
@media(max-width:760px){
  .mcta{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:200;gap:12px;align-items:center;justify-content:space-between;background:var(--green);border-radius:12px;padding:11px 14px 11px 16px;box-shadow:0 12px 30px rgba(0,0,0,.28)}
  .mcta span{color:#fff;font-size:13.5px;font-weight:600;line-height:1.2}
  .mcta a{flex-shrink:0;background:var(--gold);color:var(--green-3);font-weight:700;font-size:14px;padding:10px 16px;border-radius:8px}
  body.has-mcta{padding-bottom:80px}
}
