:root{
  --bg:#f1ebde;
  --bg-warm:#ece4d2;
  --paper:#f7f2e8;
  --ink:#15110b;
  --muted:#5a4d3d;
  --rule:#15110b;
  --accent:#9c2118;
  --gold:#c89351;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Source Serif 4', Georgia, serif;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit}
iframe{ width:100%; display:block; border:1px solid var(--ink); }

/* ======== NAV ======== */
.nav{
  position:sticky; top:0; z-index:50;
  background:var(--bg);
  border-bottom:1px solid var(--ink);
}
.nav__inner{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:0.6rem;
  padding:0.55rem 1rem;
  max-width:1200px; margin:0 auto;
}
.nav__brand{
  font-family:'DM Serif Text', 'IBM Plex Serif', Georgia, serif;
  font-size:1.05rem;
  text-decoration:none;
  letter-spacing:0.005em;
  line-height:1;
}
.nav__brand em{ color:var(--accent); font-style:italic; font-weight:400; }
.nav__pill{
  display:none;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  padding:0.32rem 0.55rem;
  border:1px solid var(--ink);
  white-space:nowrap;
}
.nav__pill::before{
  content:"";
  display:inline-block;
  width:0.5rem;height:0.5rem;
  background:var(--accent);
  margin-right:0.45rem;
  border-radius:50%;
  vertical-align: 0.05em;
}
.nav__call{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  text-decoration:none;
  padding:0.7rem 0.85rem;
  background:var(--ink);
  color:var(--bg);
  min-height:44px;
  display:inline-flex; align-items:center; gap:0.4rem;
  white-space:nowrap;
  line-height:1;
}
@media (min-width:720px){
  .nav__inner{ grid-template-columns: auto 1fr auto; padding:0.7rem 2rem; }
  .nav__brand{ font-size:1.4rem; }
  .nav__pill{ display:inline-block; justify-self:end; margin-right:1rem; }
}

/* ======== MASTHEAD ======== */
.masthead{
  padding: 1.4rem 1rem 0;
  max-width:1200px; margin:0 auto;
}
.masthead__rules{
  display:flex; flex-wrap:wrap;
  justify-content:space-between; gap:0.4rem 1rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.66rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  border-top:3px double var(--ink);
  border-bottom:1px solid var(--ink);
  padding:0.5rem 0;
  color:var(--muted);
}
.masthead__rules--tight{
  border-top:1px solid var(--ink);
  border-bottom:3px double var(--ink);
  justify-content:center;
  letter-spacing:0.22em;
  color:var(--ink);
}
.masthead__rules--tight span{ padding:0 0.5rem; }
.folio{
  font-family:'DM Serif Text', 'IBM Plex Serif', Georgia, serif;
  font-weight:400;
  font-size: clamp(2.3rem, 14vw, 8rem);
  line-height: 0.92;
  margin: 0.9rem 0 0.7rem;
  text-align:center;
  letter-spacing:-0.012em;
}
.folio em{
  color:var(--accent);
  font-style:italic;
  font-family:'DM Serif Text', serif;
  font-weight:400;
}

/* ======== HERO ======== */
.hero{
  display:grid;
  gap:1.4rem;
  padding: 1.6rem 1rem 2.2rem;
  max-width:1200px; margin:0 auto;
}
.hero__photo{
  margin:0;
  border:1px solid var(--ink);
  position:relative;
}
.hero__photo img{
  width:100%; aspect-ratio: 4/3; object-fit:cover;
  filter: contrast(1.04) saturate(0.88);
}
.hero__photo figcaption{
  position:absolute; left:0; bottom:0;
  background:var(--ink); color:var(--bg);
  font-family:'IBM Plex Mono', monospace;
  font-size:0.65rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  padding:0.5rem 0.7rem;
}
.dateline{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  margin:0 0 0.7rem;
  color:var(--muted);
}
.dateline::before{ content:"§ "; color:var(--accent); }
.hero__hed{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: clamp(2.2rem, 11vw, 4.8rem);
  line-height: 1.05;
  margin:0 0 1rem;
  letter-spacing:-0.012em;
}
.hero__hed .accent{
  color:var(--accent); font-style:italic;
}
.hero__sub{
  font-size:1.05rem;
  line-height:1.5;
  max-width: 38ch;
  margin: 0 0 1.4rem;
  color:var(--ink);
}
.hero__sub::first-letter{
  font-family:'DM Serif Text', serif;
  font-size:2.6em;
  float:left;
  line-height:0.9;
  padding: 0.1em 0.12em 0 0;
  color:var(--accent);
}

.cta-row{ display:flex; flex-wrap:wrap; gap:0.6rem; }
.btn{
  display:inline-flex; align-items:center; gap:0.45rem;
  padding: 0.95rem 1.15rem;
  min-height: 48px;
  text-decoration:none;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  border:1px solid var(--ink);
  line-height:1.0;
}
.btn--primary{ background:var(--ink); color:var(--bg); }
.btn--primary .num{
  font-family:'Source Serif 4', serif;
  font-size: 1.02rem; text-transform:none; letter-spacing:0.01em; font-weight:600;
}
.btn--ghost{ background:transparent; color:var(--ink); }

@media(min-width:880px){
  .hero{
    grid-template-columns: 1.05fr 1fr;
    gap: 2.2rem;
    align-items:center;
    padding: 2.4rem 2rem 3.2rem;
  }
  .hero__photo img{ aspect-ratio: 3/4; }
}

/* ======== STATS ======== */
.stats{
  display:grid;
  grid-template-columns: 1fr 1fr;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  background:var(--bg-warm);
  max-width:1200px; margin:0 auto;
}
.stat{
  padding: 1.4rem 1.1rem;
  border-right:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
}
.stat:nth-child(2n){ border-right:none; }
.stat:nth-last-child(-n+2){ border-bottom:none; }
.stat__num{
  display:block;
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: clamp(2rem, 8vw, 3rem);
  line-height:1;
  margin-bottom: 0.5rem;
  letter-spacing:-0.01em;
}
.stat__num em{ color:var(--accent); font-style:italic; }
.stat__sup{
  font-size:0.45em;
  color:var(--muted);
  font-style:italic;
  margin-left:0.1em;
  vertical-align: 0.55em;
}
.stat__label{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.66rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
}
@media(min-width:720px){
  .stats{ grid-template-columns: repeat(4, 1fr); }
  .stat{ border-bottom:none; }
  .stat:last-child{ border-right:none; }
}

/* ======== SECTIONS ======== */
.wrap{
  padding: 2.6rem 1rem 2.8rem;
  max-width:1200px; margin:0 auto;
}
.section-head{
  display:grid; gap:0.45rem; justify-items:center;
  border-bottom:1px solid var(--ink);
  padding-bottom: 1.1rem;
  margin-bottom: 1.8rem;
  text-align:center;
}
.section-head__kicker{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--accent);
}
.section-head__title{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: clamp(1.9rem, 6.5vw, 2.9rem);
  margin:0;
  text-transform:uppercase;
  letter-spacing:0.005em;
  line-height:1.05;
}
.section-head__sub{
  font-style:italic;
  color:var(--muted);
  margin: 0;
  font-size:0.98rem;
  max-width: 38ch;
}

/* ======== SERVICES ======== */
.services-list{
  list-style:none; padding:0; margin:0;
  display:grid;
  grid-template-columns: 1fr;
  border-top:1px solid var(--ink);
}
.services-list li{
  display:grid;
  grid-template-columns: 3rem 1fr;
  gap: 0.6rem 1rem;
  border-bottom:1px solid var(--ink);
  padding: 1.3rem 0.2rem;
}
.services-list .num{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.75rem;
  letter-spacing:0.14em;
  color:var(--accent);
  padding-top: 0.45rem;
}
.services-list h3{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: 1.45rem;
  text-transform:uppercase;
  margin: 0 0 0.45rem;
  letter-spacing: 0.01em;
  line-height:1.1;
}
.services-list p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
  font-size: 1rem;
}
@media(min-width:720px){
  .services-list{
    grid-template-columns: 1fr 1fr;
    column-gap: 2.4rem;
    border-bottom:1px solid var(--ink);
  }
  .services-list li{ padding: 1.5rem 0; }
  .services-list li:nth-last-child(-n+2){ border-bottom:none; }
}

/* ======== REVIEWS ======== */
.reviews-grid{
  display:grid; gap:1.2rem;
}
.review{
  background:var(--paper);
  border:1px solid var(--ink);
  padding: 1.4rem 1.2rem 1.1rem;
  display:flex; flex-direction:column;
  position:relative;
}
.review::before{
  content:"“";
  position:absolute; top:-0.55rem; left:0.7rem;
  font-family:'DM Serif Text', serif;
  font-size:3.4rem; line-height:1;
  color:var(--accent);
  background:var(--paper);
  padding: 0 0.25rem;
}
.review__pull{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: 1.25rem;
  line-height:1.3;
  margin: 0.4rem 0 1rem;
  letter-spacing:-0.005em;
}
.review__text{
  font-family:'Source Serif 4', serif;
  font-size: 0.96rem;
  line-height:1.55;
  color:var(--ink);
  margin: 0 0 1.2rem;
}
.review__byline{
  margin-top:auto;
  border-top: 1px solid var(--ink);
  padding-top: 0.6rem;
  display:flex; justify-content:space-between; align-items:baseline;
  gap:0.8rem;
  flex-wrap:wrap;
}
.review__author{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
}
.review__author::before{ content:"— "; color:var(--accent); }
.review__when{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.66rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.stars{ color:var(--accent); letter-spacing:0.06em; margin-right:0.4rem; }

@media(min-width:880px){
  .reviews-grid{ grid-template-columns: repeat(3, 1fr); }
}

/* ======== VISIT ======== */
.visit{ display:grid; gap:1.6rem; }
.visit__col h3{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size:1rem;
  text-transform:uppercase;
  letter-spacing:0.12em;
  margin: 0 0 0.5rem;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 0.4rem;
}
.visit__col p, .visit__col li{
  margin:0; line-height:1.55;
}
.visit__col p{ margin: 0 0 0.8rem; }
.visit__col a.tel-line{
  font-family:'DM Serif Text', serif;
  font-size: 1.6rem;
  text-decoration:none;
  display:inline-block;
  margin-top: 0.2rem;
  letter-spacing:-0.005em;
}
.hours{
  list-style:none; padding:0; margin:0;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.82rem;
}
.hours li{
  display:flex; justify-content:space-between;
  padding: 0.4rem 0;
  border-bottom: 1px dotted var(--ink);
  letter-spacing:0.04em;
}
.hours li:last-child{ border-bottom:none; }
.hours .closed{ color:var(--accent); font-style:italic; }
.visit__map{
  border:1px solid var(--ink);
  position:relative;
}
.visit__map iframe{ height: 320px; border:none; }
.visit__map figcaption{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.66rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  padding: 0.55rem 0.8rem;
  border-top: 1px solid var(--ink);
  background: var(--bg-warm);
  color:var(--muted);
}

@media(min-width:880px){
  .visit{ grid-template-columns: 1fr 1fr 1.3fr; gap:2rem; align-items:start; }
}

/* ======== FOOT CTA ======== */
.foot-cta{
  background:var(--ink);
  color:var(--bg);
  text-align:center;
  padding: 3.2rem 1.4rem 3.4rem;
  border-top:1px solid var(--ink);
}
.foot-cta__kicker{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom: 1rem;
  display:block;
}
.foot-cta h2{
  font-family:'DM Serif Text', serif;
  font-weight:400;
  font-size: clamp(2rem, 8vw, 3.6rem);
  line-height:1.05;
  margin: 0 auto 1.4rem;
  max-width: 18ch;
  letter-spacing:-0.01em;
}
.foot-cta h2 em{
  color:var(--gold);
  font-style:italic;
}
.foot-cta .btn{
  border-color:var(--bg);
  color:var(--ink);
  background:var(--bg);
}
.foot-cta__hint{
  margin-top:1.2rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.7rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: #b8a98e;
}

/* ======== FOOTER ======== */
footer{
  padding: 2rem 1rem 2.2rem;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.06em;
  line-height:1.7;
  color:var(--muted);
  text-align:center;
  border-top: 3px double var(--ink);
  margin-top: 0;
}
footer a{ color:var(--ink); text-decoration:underline; text-underline-offset:3px;}
footer .colophon{
  margin-top:0.6rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-size:0.66rem;
}

/* ======== HIGHLIGHT (inline-text bg) ======== */
.hi{
  color: var(--accent);
  font-style:italic;
}
