:root{
  --oil-paper:#F4F1EA;
  --sign-red:#C5202E;
  --sign-red-dark:#A81824;
  --bay-light:#FBF9F4;
  --shop-floor:#1C2620;
  --canopy-green:#234034;
  --brick-tint:#E9E3D6;
  --hairline:rgba(28,38,32,.14);
  --nav-h:68px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{background-color:#F4F1EA;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background-color:#F4F1EA;
  color:var(--shop-floor);
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  font-size:1.0625rem;
  line-height:1.6;
  font-weight:400;
  padding-top:env(safe-area-inset-top,0px);
  overflow-x:hidden;
}
/* analog noise overlay — below nav z-index */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,.display{font-family:'Saira Condensed','Arial Narrow',sans-serif;line-height:1.02;letter-spacing:.01em}

/* ---------- TYPE SCALE (Plan §8) ---------- */
.eyebrow{font-size:.8125rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;font-family:'Hanken Grotesk',sans-serif;color:var(--sign-red-dark)}
h2.section-head{font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;font-size:2.75rem;letter-spacing:.005em;line-height:.98}
h3{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.01em}
.lead{font-size:1.25rem;line-height:1.55;color:#37433c}
.wrap{width:100%;max-width:1240px;margin:0 auto;padding:0 clamp(24px,6vw,120px)}
section{position:relative;z-index:2;padding:96px 0}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background-color:#F4F1EA;
  border-bottom:1px solid var(--hairline);
  transition:box-shadow .25s ease-out;
  padding:0 calc(env(safe-area-inset-right,0px)) 0 calc(env(safe-area-inset-left,0px));
}
.nav.scrolled{box-shadow:0 4px 18px -8px rgba(28,38,32,.22)}
.nav-inner{max-width:1240px;margin:0 auto;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,5vw,48px)}
.brand-mark{display:inline-flex;align-items:center;background:#fff;border:1.5px solid var(--shop-floor);border-radius:3px;padding:4px 9px 3px;line-height:1;box-shadow:0 1px 0 rgba(28,38,32,.12)}
.brand-mark span{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.25rem;letter-spacing:.04em;color:var(--sign-red);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.nl{position:relative;font-size:.95rem;font-weight:500;color:var(--shop-floor);padding:4px 0}
.nav-links a.nl::after{content:'';position:absolute;left:0;bottom:-2px;height:2px;width:100%;background:var(--sign-red);transform:scaleX(0);transform-origin:left;transition:transform .2s ease-out}
.nav-links a.nl:hover::after,.nav-links a.nl:focus-visible::after{transform:scaleX(1)}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:.95rem;color:var(--shop-floor)}
.nav-phone svg{width:15px;height:15px;fill:var(--sign-red)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:1rem;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:background-color .2s ease-out,transform .1s ease-out,color .2s ease-out,border-color .2s ease-out}
.btn-red{background:var(--sign-red);color:#fff;padding:11px 22px}
.btn-red:hover,.btn-red:focus-visible{background:var(--sign-red-dark);transform:translateY(-1px)}
.btn-red:active{transform:translateY(0)}
.btn-outline{background:transparent;color:var(--shop-floor);border-color:var(--shop-floor);padding:11px 22px}
.btn-outline:hover,.btn-outline:focus-visible{color:var(--sign-red);border-color:var(--sign-red);background:rgba(197,32,46,.05)}
.btn-lg{font-size:1.125rem;padding:15px 30px}
.nav-cta{display:inline-flex;align-items:center;gap:18px}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{width:26px;height:2.5px;background:var(--shop-floor);border-radius:2px;transition:transform .25s,opacity .2s}
:focus-visible{outline:2.5px solid var(--sign-red);outline-offset:3px;border-radius:2px}

/* ---------- SIGN PANEL (the Memorable Thing) ---------- */
.sign-panel{background:#fff;border:2px solid var(--shop-floor);border-radius:5px;color:var(--sign-red);box-shadow:0 2px 0 rgba(28,38,32,.16);transition:box-shadow .6s ease-out,filter .6s ease-out;filter:brightness(.965)}
.sign-panel.lit{box-shadow:0 0 0 rgba(197,32,46,0),0 2px 0 rgba(28,38,32,.16),0 0 34px -6px rgba(197,32,46,.55);filter:brightness(1.02)}

/* ---------- HERO ---------- */
.hero{padding-top:calc(var(--nav-h) + 72px);padding-bottom:80px;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:repeating-linear-gradient(118deg,transparent 0 78px,rgba(197,32,46,.05) 78px 80px)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero-word{display:inline-block;padding:clamp(10px,2vw,20px) clamp(18px,3vw,34px);margin-bottom:26px}
.hero-word .pk{font-family:'Saira Condensed',sans-serif;font-weight:800;text-transform:uppercase;font-size:clamp(3.5rem,11vw,8rem);line-height:.84;letter-spacing:.01em;display:block;color:var(--sign-red)}
.hero-word .sub{display:block;font-family:'Saira Condensed',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:clamp(.85rem,2.1vw,1.35rem);color:var(--shop-floor);margin-top:6px}
.hero-eyebrow{margin:0 0 18px}
.hero h1{font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.0;max-width:18ch;color:var(--shop-floor);margin-bottom:14px}
.hero h1 em{font-style:normal;color:var(--sign-red)}
.hero-desc{max-width:46ch;margin-bottom:30px;color:#37433c}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-fin{font-size:.85rem;color:#5a655d;margin-top:16px}
.hero-photo{position:relative}
.photo-frame{border:4px solid var(--canopy-green);border-radius:6px;overflow:hidden;box-shadow:0 18px 40px -22px rgba(28,38,32,.5);background:var(--canopy-green)}
.photo-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:1536/2048;transition:transform .25s ease-out}
a.photo-link:hover .photo-frame img,.photo-frame.zoom:hover img{transform:scale(1.02)}
.photo-cap{position:absolute;left:14px;bottom:14px;background:var(--shop-floor);color:var(--oil-paper);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:3px}

/* hero entrance */
.rise{opacity:0;transform:translateY(14px);transition:opacity .45s ease-out,transform .45s ease-out}
.rise.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ---------- STAT ROW ---------- */
.stats{background:var(--brick-tint);padding:64px 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.stat{text-align:center;padding:26px 18px;display:flex;flex-direction:column;align-items:center}
.stat .num{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:clamp(2.75rem,6vw,4.5rem);line-height:.9;color:var(--sign-red)}
.stat .lbl{display:block;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:var(--shop-floor);margin-top:14px}
.stat .sub{display:block;font-size:.85rem;color:#5a655d;margin-top:3px}

/* ---------- GREEN BAND ---------- */
.green-band{background:var(--canopy-green);color:var(--oil-paper);padding:90px 0}
.green-band .eyebrow{color:#a9c4b3}
.green-band h2.section-head{color:#fff}
.gb-intro{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:54px}
.gb-intro p{color:#d3e0d6;max-width:50ch}
.gb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.gb-item{border-top:3px solid var(--sign-red);padding-top:22px}
.gb-item .gb-no{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.1rem;color:#a9c4b3;letter-spacing:.1em}
.gb-item h3{color:#fff;margin:8px 0 12px;font-size:1.45rem}
.gb-item p{color:#cdddd2;font-size:1rem}

/* ---------- SERVICES PREVIEW ---------- */
.svc-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:46px}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px 56px}
.svc-group h3{font-size:1.35rem;color:var(--shop-floor);padding-bottom:12px;border-bottom:2px solid var(--shop-floor);margin-bottom:16px;display:flex;align-items:baseline;gap:10px}
.svc-group h3 .gn{font-size:.85rem;font-weight:600;color:var(--sign-red);font-family:'Hanken Grotesk',sans-serif;letter-spacing:.06em}
.svc-list{list-style:none}
.svc-list li{padding:7px 0 7px 22px;position:relative;border-bottom:1px solid var(--hairline);font-weight:500}
.svc-list li:last-child{border-bottom:none}
.svc-list li::before{content:'';position:absolute;left:0;top:15px;width:9px;height:9px;background:var(--sign-red);border-radius:1px;transform:rotate(45deg)}
.svc-list li span{display:block;font-weight:400;font-size:.9rem;color:#5a655d;line-height:1.4}
.see-all{display:inline-flex;align-items:center;gap:7px;font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:1.05rem;color:var(--sign-red);border-bottom:2px solid transparent;transition:border-color .2s,gap .2s}
.see-all:hover,.see-all:focus-visible{border-color:var(--sign-red);gap:12px}

/* ---------- REVIEWS ---------- */
.reviews{background:var(--bay-light)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:42px}
.rev{background:#fff;border:1px solid var(--hairline);border-left:4px solid var(--sign-red);border-radius:5px;padding:28px 26px;display:flex;flex-direction:column}
.rev .stars{color:var(--sign-red);font-size:1.05rem;letter-spacing:2px;margin-bottom:14px}
.rev blockquote{font-size:1.05rem;line-height:1.55;color:var(--shop-floor);flex:1}
.rev .attr{margin-top:18px;padding-top:14px;border-top:1px solid var(--hairline);font-size:.85rem;color:#5a655d}
.rev .attr strong{color:var(--shop-floor);font-weight:600;display:block;font-size:.92rem}
.rev-foot{margin-top:30px;font-weight:600;color:var(--shop-floor);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rev-foot .rf-red{color:var(--sign-red);font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:.02em}

/* ---------- CONTACT / CTA BAND ---------- */
.cta-band{background:var(--shop-floor);color:var(--oil-paper);padding:84px 0}
.cta-band .eyebrow{color:#e08e95}
.cta-band h2.section-head{color:#fff;margin:8px 0 18px}
.cta-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.cta-grid p.lead{color:#c5cdc7}
.cta-info{display:flex;flex-direction:column;gap:18px}
.cta-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:6px;padding:22px 24px}
.cta-card .ci-lbl{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#9fb0a6;font-weight:600;margin-bottom:8px}
.cta-card .ci-val{font-size:1.05rem;color:#fff;font-weight:500}
.cta-card a.ci-val:hover{color:#f0b8bd}
.hours-line{display:flex;justify-content:space-between;padding:5px 0;font-size:.98rem;color:#dfe6e1}
.hours-line.sat{color:#fff;font-weight:600}
.hours-line.sat .hday{color:var(--sign-red);font-family:'Saira Condensed',sans-serif;font-weight:700;letter-spacing:.03em}
.hours-line .hclosed{color:#8f9d94}
.status{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;margin-top:6px}
.status .dot{width:11px;height:11px;border-radius:50%;background:#8f9d94;flex:none;box-shadow:0 0 0 0 rgba(63,166,99,.5)}
.status.open .dot{background:#5fbf7e}
.status.open .dot{animation:pulse 2s ease-in-out infinite}
.status .lbl-txt{color:#dfe6e1}
.status.open .lbl-txt{color:#fff}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(95,191,126,.45)}50%{box-shadow:0 0 0 7px rgba(95,191,126,0)}}

/* ---------- FOOTER ---------- */
.footer{background:var(--canopy-green);color:#cdddd2;padding:72px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr 1.3fr 1.2fr;gap:36px}
.footer .brand-mark{margin-bottom:16px}
.foot-tag{font-size:.95rem;line-height:1.55;max-width:26ch;color:#bcd0c2}
.foot-h{font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;color:#fff;margin-bottom:16px}
.foot-nav a,.foot-link{display:block;padding:5px 0;font-size:.95rem;color:#cdddd2;transition:color .2s}
.foot-nav a:hover,.foot-link:hover{color:#fff}
.foot-hours .hours-line{color:#cdddd2;font-size:.92rem;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-hours .hours-line.sat{color:#fff}
.foot-hours .hours-line.sat .hday{color:#f0a0a7}
.foot-hours .status{margin-top:12px}
.foot-hours .status .lbl-txt{color:#cdddd2}
.foot-diff li{padding:7px 0;font-size:.95rem;color:#cdddd2;display:flex;align-items:center;gap:9px;list-style:none}
.foot-diff li::before{content:'';width:7px;height:7px;background:var(--sign-red);transform:rotate(45deg);flex:none}
.foot-addr{font-style:normal;font-size:.95rem;line-height:1.7;color:#cdddd2}
.foot-addr a:hover{color:#fff}
.legal{border-top:1px solid rgba(255,255,255,.13);margin-top:54px;padding:22px 0;font-size:.82rem;color:#9fb6a7;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px}
.legal a{color:#bcd0c2;text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:#fff}

/* ---------- STICKY MOBILE CALL BAR ---------- */
.call-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:990;background:var(--sign-red);
  padding:13px calc(16px + env(safe-area-inset-right,0px)) calc(13px + env(safe-area-inset-bottom,0px)) calc(16px + env(safe-area-inset-left,0px));
  box-shadow:0 -3px 16px -6px rgba(28,38,32,.4)}
.call-bar a{display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:1.18rem}
.call-bar svg{width:19px;height:19px;fill:#fff}

/* ---------- MOBILE DRAWER ---------- */
.drawer{position:fixed;inset:0;z-index:1001;background:var(--oil-paper);transform:translateX(100%);transition:transform .3s ease-out;display:flex;flex-direction:column;
  padding:calc(5rem + env(safe-area-inset-top,0px)) calc(28px + env(safe-area-inset-right,0px)) 28px calc(28px + env(safe-area-inset-left,0px))}
.drawer.open{transform:none}
.drawer-close{position:absolute;top:calc(20px + env(safe-area-inset-top,0px));right:24px;background:none;border:none;font-size:2rem;cursor:pointer;color:var(--shop-floor);line-height:1}
.drawer a.dl{font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;font-size:1.9rem;color:var(--shop-floor);padding:13px 0;border-bottom:1px solid var(--hairline)}
.drawer a.dl:hover{color:var(--sign-red)}
.drawer .drawer-cta{margin-top:26px;display:flex;flex-direction:column;gap:14px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  section{padding:64px 0}
  .hero{padding-top:calc(var(--nav-h) + 48px)}
  h2.section-head{font-size:2.3rem}
  .stats-grid{gap:16px}
}
@media(max-width:880px){
  .nav-links,.nav-phone{display:none}
  .nav-cta .btn-red{display:none}
  .hamburger{display:flex}
  .gb-intro{grid-template-columns:1fr;gap:20px}
}
@media(max-width:768px){
  section{padding:48px 0}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-photo{max-width:460px}
  .green-band{padding:56px 0}
  .gb-grid{grid-template-columns:1fr;gap:26px}
  .svc-grid{grid-template-columns:1fr;gap:34px}
  .rev-grid{grid-template-columns:1fr;gap:20px}
  .cta-grid{grid-template-columns:1fr;gap:34px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px 24px}
  .call-bar{display:block}
  body{padding-bottom:62px}
  h2.section-head{font-size:1.9rem}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr;gap:10px}
  .stat{padding:18px}
  .foot-grid{grid-template-columns:1fr}
  .hero h1{font-size:1.55rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rise{opacity:1;transform:none}
}
