/* ============================================================
   THE DUCTWORK FIELD GUIDE — editorial design direction
   airductcleaningservices.co  ·  v2 prototype (throwaway)
   ------------------------------------------------------------
   Premium editorial / city-guide aesthetic.
   Type: Fraunces (display serif) + Newsreader (body serif)
         + Spline Sans Mono (labels / data / NAP)
   ============================================================ */

:root {
  /* — paper & ink — */
  --paper:        #f3eee3;   /* warm bone background           */
  --paper-deep:   #ebe3d4;   /* slightly deeper card paper     */
  --ink:          #17140e;   /* near-black warm ink            */
  --ink-soft:     #4a443a;   /* secondary text                 */
  --ink-faint:    #8a8275;   /* captions / meta                */

  /* — brand: verdigris patina + clay — */
  --verdigris:    #2e5249;   /* primary (deep patina green)    */
  --verdigris-lo: #3f6c60;
  --clay:         #c0683a;   /* warm accent (oxidised copper)  */
  --clay-lo:      #d98a5e;
  --gold:         #b89150;   /* hairline / star accent         */

  --rule:         #cbc1ac;   /* hairline rules on paper        */
  --rule-ink:     rgba(243,238,227,.22);

  /* — type — */
  --display: "Fraunces", Georgia, serif;
  --body:    "Newsreader", Georgia, serif;
  --mono:    "Spline Sans Mono", ui-monospace, monospace;

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: 18px;
  line-height: 1.62;
  font-optical-sizing: auto;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
h1,h2,h3,h4 { margin: 0; font-family: var(--display); font-weight: 460; line-height: 1.02; letter-spacing: -.01em; }

/* paper grain — gives the picsum imagery + flats a printed feel */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: .045; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- layout primitives ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
.rule { height: 1px; background: var(--rule); border: 0; margin: 0; }
.rule--ink { background: var(--rule-ink); }

/* kicker / editorial label */
.kicker {
  font-family: var(--mono);
  font-size: 12px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--clay); font-weight: 500;
  display: inline-flex; align-items: center; gap: .7em;
}
.kicker::before {
  content: ""; width: 26px; height: 1px; background: currentColor; opacity: .8;
}
.kicker--center { justify-content: center; }
.kicker--plain::before { display: none; }

/* ============================================================
   MASTHEAD / NAV
   ============================================================ */
.masthead {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in oklab, var(--paper) 86%, transparent);
  backdrop-filter: blur(10px) saturate(1.1);
  border-bottom: 1px solid var(--rule);
}
.masthead__bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; height: 72px;
}
.brand {
  display: flex; align-items: baseline; gap: 12px;
  font-family: var(--display); font-size: 21px; letter-spacing: -.01em;
}
.brand b { font-weight: 560; }
.brand .brand__mark {
  width: 30px; height: 30px; flex: 0 0 30px; align-self: center;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 30%, var(--clay-lo), var(--clay) 38%, var(--verdigris) 100%);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15), 0 1px 0 rgba(255,255,255,.4);
  position: relative;
}
.brand .brand__mark::after {
  content:""; position:absolute; inset: 7px;
  border: 1.5px solid rgba(243,238,227,.85); border-radius: 50%;
  border-right-color: transparent; border-bottom-color: transparent;
  transform: rotate(35deg);
}
.brand small {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--ink-faint); display: block;
}
.nav { display: flex; align-items: center; gap: 30px; }
.nav a {
  font-family: var(--mono); font-size: 12.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ink-soft);
  position: relative; padding: 6px 0;
}
.nav a::after {
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background: var(--clay); transition: width .35s var(--ease);
}
.nav a:hover { color: var(--ink); }
.nav a:hover::after { width: 100%; }
.nav__cta {
  font-family: var(--mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase;
  background: var(--ink); color: var(--paper);
  padding: 11px 18px; border-radius: 2px;
  transition: background .25s var(--ease), transform .25s var(--ease);
}
.nav__cta:hover { background: var(--verdigris); transform: translateY(-1px); }
.nav__menu-btn { display: none; }

/* ============================================================
   DUOTONE IMAGE TREATMENT  (brand identity)
   ============================================================ */
.duo { position: relative; overflow: hidden; background: var(--verdigris); }
.duo img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) contrast(1.08) brightness(1.02);
  mix-blend-mode: luminosity;
  transition: transform 1.1s var(--ease);
}
.duo::after { /* tint wash */
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--verdigris) 30%, transparent),
    color-mix(in oklab, var(--ink) 60%, transparent));
  mix-blend-mode: multiply;
}
.duo--clay { background: var(--clay); }
.duo--clay::after {
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--clay) 25%, transparent),
    color-mix(in oklab, var(--ink) 55%, transparent));
}
.duo--soft img { mix-blend-mode: normal; opacity: .94; filter: grayscale(.55) contrast(1.04) sepia(.12); }
a:hover > .duo img, .card:hover .duo img, .feat:hover .duo img { transform: scale(1.05); }

/* ============================================================
   HERO  (homepage)
   ============================================================ */
.hero { padding-top: clamp(40px, 6vw, 88px); padding-bottom: clamp(40px,5vw,72px); }
.hero__grid {
  display: grid; grid-template-columns: 1.05fr .95fr;
  gap: clamp(28px, 5vw, 64px); align-items: end;
}
.hero__title {
  font-size: clamp(48px, 8.4vw, 122px);
  line-height: .92; letter-spacing: -.025em; font-weight: 400;
}
.hero__title em {
  font-style: italic; font-weight: 320;
  color: var(--verdigris);
}
.hero__title .ln { display: block; overflow: hidden; }
.hero__title .ln > span {
  display: block;
  transform: translateY(110%);
  animation: rise .95s var(--ease) forwards;
}
.hero__title .ln:nth-child(2) > span { animation-delay: .08s; }
.hero__title .ln:nth-child(3) > span { animation-delay: .16s; }
@keyframes rise { to { transform: translateY(0); } }

.hero__lede {
  font-size: clamp(18px, 1.5vw, 21px); color: var(--ink-soft);
  max-width: 46ch; margin-top: 28px;
  animation: fade 1s var(--ease) .35s both;
}
.hero__lede .dropcap {
  float: left; font-family: var(--display); font-weight: 460;
  font-size: 3.1em; line-height: .72; padding: .06em .12em 0 0;
  color: var(--clay);
}
@keyframes fade { from { opacity:0; transform: translateY(10px);} to {opacity:1; transform:none;} }

.hero__media {
  position: relative; aspect-ratio: 4/5;
  border-radius: 3px; box-shadow: 0 32px 60px -34px rgba(23,20,14,.6);
  animation: fade 1.1s var(--ease) .25s both;
}
.hero__media .duo { width:100%; height:100%; border-radius: 3px; }
.hero__media-cap {
  position: absolute; left: 0; bottom: -2px; transform: translateY(100%);
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em;
  color: var(--ink-faint); padding-top: 10px;
}
.hero__badge {
  position: absolute; top: 18px; left: 18px; z-index: 3;
  background: var(--paper); color: var(--ink);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em;
  text-transform: uppercase; padding: 8px 12px; border-radius: 2px;
  box-shadow: 0 6px 18px -8px rgba(0,0,0,.4);
}
.hero__stamp {
  position: absolute; right: -26px; bottom: -26px; z-index: 4;
  width: 124px; height: 124px;
}
.hero__stamp svg { width: 100%; height: 100%; animation: spin 26s linear infinite; }
.hero__stamp .core {
  position:absolute; inset:0; display:grid; place-items:center;
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em; color: var(--clay);
  text-align:center; text-transform: uppercase; font-weight: 500;
}
@keyframes spin { to { transform: rotate(360deg);} }

/* search affordance */
.searchbar {
  margin-top: 34px; display: flex; gap: 0; max-width: 520px;
  border: 1.5px solid var(--ink); border-radius: 2px; overflow: hidden;
  background: var(--paper);
  animation: fade 1s var(--ease) .5s both;
}
.searchbar input {
  flex: 1; border: 0; background: transparent; padding: 15px 18px;
  font-family: var(--body); font-size: 16px; color: var(--ink); outline: none;
}
.searchbar input::placeholder { color: var(--ink-faint); }
.searchbar button {
  background: var(--ink); color: var(--paper); border: 0;
  padding: 0 22px; font-family: var(--mono); font-size: 12px;
  letter-spacing: .12em; text-transform: uppercase;
  transition: background .25s var(--ease);
}
.searchbar button:hover { background: var(--clay); }

/* marquee strip of stats / trust */
.tickline {
  border-block: 1px solid var(--rule); padding: 18px 0; margin-top: clamp(40px,5vw,72px);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.tick { display: flex; flex-direction: column; gap: 4px; }
.tick b { font-family: var(--display); font-size: clamp(26px,3vw,40px); font-weight: 480; letter-spacing: -.02em; }
.tick span { font-family: var(--mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-faint); }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec { padding-block: clamp(56px, 7vw, 104px); }
.sec__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 40px; flex-wrap: wrap;
}
.sec__title { font-size: clamp(30px, 4vw, 52px); letter-spacing: -.02em; max-width: 16ch; }
.sec__title em { font-style: italic; color: var(--verdigris); }
.sec__aside { max-width: 38ch; color: var(--ink-soft); font-size: 16.5px; }
.link-more {
  font-family: var(--mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink); border-bottom: 1px solid var(--clay); padding-bottom: 3px;
  display: inline-flex; gap: 8px; align-items: center;
}
.link-more:hover { color: var(--clay); }

/* ============================================================
   FEATURED SERVICES — editorial tiles
   ============================================================ */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--rule); border: 1px solid var(--rule); }
.svc {
  position: relative; background: var(--paper); padding: 0; overflow: hidden;
  display: flex; flex-direction: column;
}
.svc__media { aspect-ratio: 16/11; position: relative; }
.svc__media .duo { width:100%; height:100%; }
.svc__no {
  position:absolute; top: 14px; left: 16px; z-index: 3;
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--paper);
}
.svc__body { padding: 22px 24px 26px; flex: 1; display:flex; flex-direction:column; }
.svc__name { font-size: clamp(20px,1.8vw,26px); letter-spacing: -.01em; }
.svc__desc { color: var(--ink-soft); font-size: 15.5px; margin-top: 8px; flex:1; }
.svc__tag { margin-top: 16px; font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--clay); }
.svc:hover .svc__name { color: var(--verdigris); }

/* ============================================================
   FEATURED BUSINESSES — "the registry" editorial entries
   ============================================================ */
.feat-list { display: grid; gap: 2px; background: var(--rule); border-block: 1px solid var(--rule); }
.feat {
  display: grid; grid-template-columns: 92px 220px 1fr auto;
  gap: clamp(16px,2.4vw,40px); align-items: center;
  background: var(--paper); padding: 22px var(--gutter);
  margin-inline: calc(var(--gutter) * -1);
  transition: background .3s var(--ease);
}
.feat:hover { background: var(--paper-deep); }
.feat__no { font-family: var(--display); font-size: 40px; font-weight: 360; color: var(--rule); letter-spacing: -.02em; }
.feat:hover .feat__no { color: var(--clay); }
.feat__media { aspect-ratio: 5/4; border-radius: 2px; }
.feat__media .duo { width:100%; height:100%; border-radius:2px; }
.feat__main { min-width: 0; }
.feat__name { font-size: clamp(22px,2.2vw,30px); letter-spacing: -.01em; }
.feat__meta { font-family: var(--mono); font-size: 12px; letter-spacing: .06em; color: var(--ink-faint); margin-top: 6px; text-transform: uppercase; }
.feat__svcs { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 6px; }
.pill {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
  border: 1px solid var(--rule); color: var(--ink-soft);
  padding: 4px 9px; border-radius: 999px; background: var(--paper);
}
.feat__rate { text-align: right; }
.feat__rate .num { font-family: var(--display); font-size: 32px; font-weight: 460; letter-spacing: -.02em; }
.feat__rate .stars { color: var(--gold); font-size: 13px; letter-spacing: 1px; }
.feat__rate .cnt { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); letter-spacing: .06em; }
.feat__go {
  font-family: var(--mono); font-size: 11px; letter-spacing:.1em; text-transform:uppercase;
  color: var(--clay); display:inline-flex; gap:6px; align-items:center; margin-top: 8px; justify-content:flex-end;
  opacity:0; transition: opacity .3s var(--ease);
}
.feat:hover .feat__go { opacity: 1; }

/* ============================================================
   BROWSE BY STATE — editorial atlas
   ============================================================ */
.atlas { background: var(--verdigris); color: var(--paper); }
.atlas .kicker { color: var(--clay-lo); }
.atlas .sec__title { color: var(--paper); }
.atlas .sec__aside { color: rgba(243,238,227,.74); }
.atlas .rule { background: var(--rule-ink); }
.state-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--rule-ink); border: 1px solid var(--rule-ink); }
.state {
  background: var(--verdigris); padding: 22px 22px 26px;
  display:flex; flex-direction: column; gap: 6px;
  transition: background .3s var(--ease);
  position: relative;
}
.state:hover { background: var(--verdigris-lo); }
.state__name { font-family: var(--display); font-size: 23px; font-weight: 440; }
.state__count { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: rgba(243,238,227,.6); }
.state__cities { font-size: 14px; color: rgba(243,238,227,.78); margin-top: 4px; line-height: 1.5; }
.state__arrow { position:absolute; top: 22px; right: 22px; opacity:0; transform: translateX(-6px); transition: all .3s var(--ease); color: var(--clay-lo); }
.state:hover .state__arrow { opacity:1; transform:none; }

/* ============================================================
   TRUST / EDITORIAL MANIFESTO band
   ============================================================ */
.manifesto { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,5vw,72px); align-items: center; }
.manifesto__media { aspect-ratio: 1/1; border-radius: 3px; box-shadow: 0 30px 60px -36px rgba(23,20,14,.55); }
.manifesto__media .duo { width:100%; height:100%; border-radius: 3px; }
.manifesto__title { font-size: clamp(28px,3.4vw,46px); letter-spacing:-.02em; }
.manifesto__title em { font-style: italic; color: var(--clay); }
.manifesto__body { color: var(--ink-soft); margin-top: 18px; font-size: 17px; max-width: 50ch; }
.badge-row { display:flex; flex-wrap:wrap; gap: 10px; margin-top: 26px; }
.badge {
  display:inline-flex; align-items:center; gap: 9px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  border: 1px solid var(--rule); padding: 9px 13px; border-radius: 2px; color: var(--ink-soft);
  background: var(--paper);
}
.badge svg { color: var(--verdigris); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { background: var(--ink); color: var(--paper); padding-block: clamp(48px,6vw,80px); }
.foot__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.foot__lede { font-family: var(--display); font-size: clamp(24px,2.6vw,34px); font-weight: 380; max-width: 18ch; line-height: 1.06; }
.foot__lede em { font-style: italic; color: var(--clay-lo); }
.foot h5 { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: rgba(243,238,227,.5); margin: 0 0 16px; }
.foot ul { list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.foot ul a { color: rgba(243,238,227,.82); font-size: 15px; }
.foot ul a:hover { color: var(--clay-lo); }
.foot__bottom { display:flex; justify-content: space-between; flex-wrap:wrap; gap: 16px; margin-top: clamp(36px,5vw,64px); padding-top: 24px; border-top: 1px solid var(--rule-ink); font-family: var(--mono); font-size: 11px; letter-spacing: .08em; color: rgba(243,238,227,.5); text-transform: uppercase; }

/* ============================================================
   CITY PAGE
   ============================================================ */
.crumb { font-family: var(--mono); font-size: 11.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); padding-top: 26px; display:flex; gap: 10px; flex-wrap:wrap; }
.crumb a:hover { color: var(--clay); }
.crumb span { color: var(--rule); }

.cityhero { padding-top: 22px; padding-bottom: clamp(36px,5vw,60px); }
.cityhero__grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px,5vw,64px); align-items:end; }
.cityhero__title { font-size: clamp(44px,7vw,96px); line-height:.94; letter-spacing:-.025em; }
.cityhero__title em { font-style: italic; color: var(--verdigris); }
.cityhero__lede { color: var(--ink-soft); font-size: 18px; max-width: 48ch; margin-top: 22px; }
.cityhero__lede .dropcap { float:left; font-family:var(--display); font-size:3em; line-height:.72; padding:.05em .1em 0 0; color: var(--clay); font-weight:460; }
.cityhero__media { aspect-ratio: 5/6; border-radius:3px; box-shadow: 0 30px 60px -36px rgba(23,20,14,.5); }
.cityhero__media .duo { width:100%; height:100%; border-radius:3px; }

/* filter bar */
.filters {
  position: sticky; top: 72px; z-index: 40;
  background: color-mix(in oklab, var(--paper) 90%, transparent);
  backdrop-filter: blur(8px);
  border-block: 1px solid var(--rule);
  display:flex; align-items:center; gap: 14px; flex-wrap: wrap;
  padding: 14px var(--gutter); margin-inline: calc(var(--gutter)*-1);
}
.filters__label { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); margin-right: 4px; }
.chip {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .06em; text-transform: uppercase;
  border: 1px solid var(--rule); padding: 8px 14px; border-radius: 999px;
  color: var(--ink-soft); background: var(--paper);
  transition: all .22s var(--ease);
}
.chip:hover { border-color: var(--ink); color: var(--ink); }
.chip[aria-pressed="true"] { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.filters__spacer { margin-left:auto; }
.filters select {
  font-family: var(--mono); font-size: 11.5px; letter-spacing:.06em; text-transform:uppercase;
  border: 1px solid var(--rule); background: var(--paper); color: var(--ink-soft);
  padding: 8px 12px; border-radius: 2px;
}

/* listing cards */
.listing { padding-top: clamp(36px,5vw,56px); padding-bottom: clamp(56px,7vw,96px); }
.cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px; background: var(--rule); border: 1px solid var(--rule); }
.card {
  background: var(--paper); display:grid; grid-template-columns: 150px 1fr;
  gap: 22px; padding: 22px;
  transition: background .3s var(--ease);
}
.card:hover { background: var(--paper-deep); }
.card__media { aspect-ratio: 4/5; border-radius:2px; position: relative; }
.card__media .duo { width:100%; height:100%; border-radius:2px; }
.card__rank { position:absolute; top:10px; left:10px; z-index:3; font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--paper); }
.card__top { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; }
.card__name { font-size: clamp(19px,1.7vw,24px); letter-spacing:-.01em; line-height:1.05; }
.card:hover .card__name { color: var(--verdigris); }
.card__rate { text-align:right; flex:0 0 auto; }
.card__rate .num { font-family:var(--display); font-size:24px; font-weight:460; }
.card__rate .stars { color: var(--gold); font-size: 11px; letter-spacing:1px; display:block; }
.card__rate .cnt { font-family:var(--mono); font-size:10px; color:var(--ink-faint); }
.card__meta { font-family:var(--mono); font-size: 11.5px; letter-spacing:.04em; color: var(--ink-faint); margin-top: 8px; }
.card__svcs { margin-top: 14px; display:flex; flex-wrap:wrap; gap:6px; }
.card__foot { margin-top: 16px; display:flex; align-items:center; gap: 16px; }
.card__call { font-family:var(--mono); font-size:12px; letter-spacing:.06em; color: var(--ink); border-bottom:1px solid var(--clay); padding-bottom:2px; }
.card__call:hover { color: var(--clay); }
.card__view { font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color: var(--ink-faint); margin-left:auto; }
.card:hover .card__view { color: var(--clay); }

/* ============================================================
   LOCATION (DETAIL) PAGE
   ============================================================ */
.loc-hero { padding-top: 18px; padding-bottom: clamp(28px,4vw,44px); }
.loc-hero__grid { display:grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px,5vw,56px); align-items: stretch; }
.loc-hero__media { position: relative; border-radius: 3px; min-height: 380px; box-shadow: 0 28px 56px -34px rgba(23,20,14,.5); }
.loc-hero__media .duo { position:absolute; inset:0; border-radius: 3px; }
.loc-hero__tagbadge {
  position:absolute; top:16px; left:16px; z-index:3;
  background: var(--clay); color: var(--paper);
  font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  padding:8px 13px; border-radius:2px;
}
.loc-hero__info { display:flex; flex-direction: column; }
.loc-hero__name { font-size: clamp(34px,4.4vw,58px); line-height:.98; letter-spacing:-.025em; margin-top: 6px; }
.loc-hero__raterow { display:flex; align-items:baseline; gap:16px; margin-top:18px; padding-bottom: 18px; border-bottom: 1px solid var(--rule); }
.loc-hero__raterow .num { font-family:var(--display); font-size: 42px; font-weight:480; letter-spacing:-.02em; }
.loc-hero__raterow .stars { color: var(--gold); letter-spacing:1.5px; }
.loc-hero__raterow .cnt { font-family:var(--mono); font-size:12px; color:var(--ink-faint); letter-spacing:.06em; }

.nap { display:grid; gap: 12px; margin-top: 20px; }
.nap__row { display:grid; grid-template-columns: 18px 1fr; gap: 12px; align-items:start; }
.nap__row svg { color: var(--verdigris); margin-top: 3px; }
.nap__row .lbl { font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-faint); display:block; }
.nap__row .val { font-size: 16.5px; color: var(--ink); }
.nap__row a.val:hover { color: var(--clay); }

.cta-row { display:flex; flex-wrap:wrap; gap: 10px; margin-top: 26px; }
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase;
  padding: 14px 20px; border-radius:2px; border:1.5px solid var(--ink);
  transition: all .25s var(--ease);
}
.btn--primary { background: var(--ink); color: var(--paper); }
.btn--primary:hover { background: var(--verdigris); border-color: var(--verdigris); transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--clay { border-color: var(--clay); color: var(--clay); }
.btn--clay:hover { background: var(--clay); color: var(--paper); }

/* detail body grid */
.loc-body { padding-top: clamp(36px,5vw,56px); padding-bottom: clamp(56px,7vw,96px); }
.loc-cols { display:grid; grid-template-columns: 1fr 320px; gap: clamp(32px,5vw,72px); align-items:start; }
.prose h3 { font-size: clamp(24px,2.6vw,34px); letter-spacing:-.015em; margin-bottom: 14px; }
.prose h3 em { font-style:italic; color: var(--verdigris); }
.prose p { color: var(--ink-soft); margin: 0 0 18px; }
.prose .dropcap { float:left; font-family:var(--display); font-size:3.4em; line-height:.7; padding:.04em .12em 0 0; color: var(--clay); font-weight:460; }
.sec-divide { margin: 40px 0; }

.svc-checklist { display:grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--rule); border:1px solid var(--rule); }
.svc-check { background: var(--paper); padding: 16px 18px; display:flex; align-items:center; gap: 12px; transition: background .25s var(--ease); }
.svc-check:hover { background: var(--paper-deep); }
.svc-check svg { color: var(--verdigris); flex:0 0 auto; }
.svc-check b { font-family: var(--body); font-weight: 500; font-size: 16.5px; }
.svc-check span { display:block; font-family:var(--mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color: var(--ink-faint); margin-top:2px; }

/* serving / also-serving */
.serving { display:flex; flex-wrap:wrap; gap: 8px; margin-top: 14px; }
.serving a {
  font-family:var(--mono); font-size:11.5px; letter-spacing:.04em;
  border:1px solid var(--rule); padding:7px 13px; border-radius:999px; color: var(--ink-soft);
  transition: all .22s var(--ease); background: var(--paper);
}
.serving a:hover { border-color: var(--clay); color: var(--clay); }

/* sidebar */
.aside-card { border:1px solid var(--rule); border-radius: 3px; overflow:hidden; position: sticky; top: 92px; }
.aside-card__head { background: var(--verdigris); color: var(--paper); padding: 20px 22px; }
.aside-card__head .kicker { color: var(--clay-lo); }
.aside-card__head h4 { color: var(--paper); font-size: 24px; margin-top: 8px; }
.aside-card__body { padding: 22px; background: var(--paper); }
.hours { display:grid; gap: 0; }
.hours__row { display:flex; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid var(--rule); font-size: 15px; }
.hours__row:last-child { border-bottom: 0; }
.hours__row .d { font-family: var(--mono); font-size: 12px; letter-spacing:.06em; text-transform:uppercase; color: var(--ink-soft); }
.hours__row .t { color: var(--ink); }
.hours__row--now { color: var(--verdigris); font-weight: 600; }
.hours__row--now .d { color: var(--verdigris); }
.open-flag {
  display:inline-flex; align-items:center; gap:8px; margin-bottom: 14px;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color: var(--verdigris);
}
.open-flag .dot { width:8px; height:8px; border-radius:50%; background: var(--verdigris); box-shadow: 0 0 0 4px color-mix(in oklab, var(--verdigris) 20%, transparent); animation: pulse 2.2s var(--ease) infinite; }
@keyframes pulse { 50% { box-shadow: 0 0 0 7px color-mix(in oklab, var(--verdigris) 0%, transparent);} }

.trust-aside { margin-top: 20px; border:1px solid var(--rule); border-radius:3px; padding: 20px 22px; background: var(--paper-deep); }
.trust-aside h5 { font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-faint); margin:0 0 14px; }
.trust-aside .badge-row { margin-top: 0; }

/* responsive */
@media (max-width: 980px) {
  .hero__grid, .manifesto, .cityhero__grid, .loc-hero__grid, .loc-cols, .crumb { grid-template-columns: 1fr; }
  .loc-cols .aside-card { position: static; }
  .svc-grid, .state-grid { grid-template-columns: repeat(2,1fr); }
  .cards { grid-template-columns: 1fr; }
  .foot__grid { grid-template-columns: 1fr 1fr; }
  .feat { grid-template-columns: 60px 1fr; }
  .feat__media, .feat__rate { display:none; }
  .tickline { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .nav { display:none; }
  .nav__menu-btn { display:inline-flex; }
}
@media (max-width: 600px) {
  body { font-size: 17px; }
  .svc-grid, .state-grid, .svc-checklist { grid-template-columns: 1fr; }
  .foot__grid { grid-template-columns: 1fr; gap: 28px; }
  .card { grid-template-columns: 1fr; }
  .card__media { aspect-ratio: 16/10; }
  .hero__stamp { display:none; }
  .cta-row .btn { flex: 1 1 auto; justify-content:center; }
}

.nav__menu-btn {
  display:none; background: var(--ink); color: var(--paper); border:0;
  width: 42px; height: 42px; border-radius:2px; align-items:center; justify-content:center;
}
@media (max-width: 980px){ .nav__menu-btn { display:inline-flex; } }
