/*  Ballard Computer Solutions — site stylesheet
    Palette sampled from the logo; see README. Generated for Cloudflare Pages.  */

/* ==========================================================================
   BALLARD COMPUTER SOLUTIONS — homepage preview
   Self-contained for review. Production build: external CSS + critical-inline.
   Palette sampled from the real logo; UI shades derived from those hues.
   ========================================================================== */

:root{
  /* --- verified brand colors (sampled from logo) --- */
  --red:        #A2222F;
  --ink:        #1B1B1B;
  --charcoal:   #4E4E4E;
  --white:      #FFFFFF;
  /* --- derived UI shades (for sign-off) --- */
  --red-dark:   #7E1A24;
  --red-tint:   #FBEDEE;
  --grey:       #8A8A8A;
  --grey-line:  #E4E1DC;
  --grey-soft:  #F4F2EF;
  --paper:      #FBFAF8;   /* warm off-white page background */

  --font-head: 'Bitter', Georgia, 'Times New Roman', serif;
  --font-body: 'Source Sans 3', system-ui, -apple-system, Segoe UI, sans-serif;

  --wrap: 1140px;
  --radius: 10px;
  --shadow: 0 2px 4px rgba(27,27,27,.06), 0 8px 24px rgba(27,27,27,.07);
  --shadow-lg: 0 6px 16px rgba(27,27,27,.10), 0 18px 48px rgba(27,27,27,.12);
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;          /* 17px base — comfortable for older readers */
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--red);text-decoration-thickness:1px;text-underline-offset:2px;}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.18;margin:0 0 .5em;color:var(--ink);font-weight:600;}
h2{font-size:clamp(1.7rem,4.2vw,2.5rem);}
h3{font-size:clamp(1.2rem,2.6vw,1.45rem);}
p{margin:0 0 1rem;}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px;}
section{padding:clamp(2.75rem,7vw,5rem) 0;}

/* --- accessibility --- */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.7rem 1.1rem;z-index:200;border-radius:0 0 8px 0;}
.skip:focus{left:0;}
a:focus-visible,button:focus-visible,summary:focus-visible,
.btn:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:4px;}

/* --- buttons --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:700;font-size:1.05rem;
  padding:.95rem 1.55rem;border-radius:var(--radius);
  text-decoration:none;border:2px solid transparent;cursor:pointer;
  min-height:54px;transition:transform .08s ease,background .15s ease,box-shadow .15s ease;
}
.btn:active{transform:translateY(1px);}
.btn-call{background:var(--red);color:#fff;box-shadow:var(--shadow);}
.btn-call:hover{background:var(--red-dark);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:#fff;}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.65);}
.btn-ghost-light:hover{background:#fff;color:var(--ink);border-color:#fff;}
.btn svg{width:20px;height:20px;flex:none;}

.eyebrow{
  font-weight:700;text-transform:uppercase;letter-spacing:.09em;
  font-size:.82rem;color:var(--red);margin:0 0 .6rem;
}
.center{text-align:center;}
.lede{font-size:1.15rem;color:var(--charcoal);max-width:60ch;}
.center .lede{margin-left:auto;margin-right:auto;}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;background:#fff;
  border-bottom:1px solid var(--grey-line);
  box-shadow:0 1px 0 rgba(27,27,27,.04);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 20px;max-width:var(--wrap);margin:0 auto;}
.logo img{height:56px;width:auto;}
.header-actions{display:flex;align-items:center;gap:.75rem;}
.header-phone{
  display:inline-flex;align-items:center;gap:.5rem;font-weight:700;
  font-size:1.18rem;color:var(--ink);text-decoration:none;white-space:nowrap;
}
.header-phone svg{width:22px;height:22px;color:var(--red);}
.header-phone span small{display:block;font-size:.72rem;font-weight:600;color:var(--grey);letter-spacing:.04em;text-transform:uppercase;}

/* nav — disclosure menu on mobile, inline on desktop */
.nav details{position:relative;}
.nav summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;gap:.4rem;
  font-weight:700;padding:.7rem .85rem;border:2px solid var(--grey-line);
  border-radius:8px;background:#fff;
}
.nav summary::-webkit-details-marker{display:none;}
.nav summary svg{width:20px;height:20px;}
.nav ul{
  list-style:none;margin:0;padding:.4rem;position:absolute;right:0;top:calc(100% + 8px);
  background:#fff;border:1px solid var(--grey-line);border-radius:10px;
  box-shadow:var(--shadow-lg);min-width:230px;
}
.nav li a{
  display:block;padding:.6rem .8rem;color:var(--ink);text-decoration:none;
  font-weight:600;border-radius:6px;
}
.nav li a:hover{background:var(--red-tint);color:var(--red-dark);}

@media(min-width:1000px){
  .nav summary{display:none;}
  .nav ul{position:static;display:flex;box-shadow:none;border:0;padding:0;gap:.15rem;background:none;min-width:0;}
  .nav li a{padding:.5rem .7rem;font-size:.97rem;}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:radial-gradient(120% 130% at 85% 0%, #3a2024 0%, #241417 45%, #1B1B1B 100%);
}
.hero::after{ /* subtle red swoosh nod to the logo */
  content:"";position:absolute;right:-12%;top:-30%;width:70%;height:160%;
  background:radial-gradient(closest-side, rgba(162,34,47,.55), transparent 70%);
  transform:rotate(-12deg);pointer-events:none;
}
.hero video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.16;pointer-events:none;
}
.hero .wrap{position:relative;z-index:2;padding-top:clamp(2.5rem,7vw,4.5rem);padding-bottom:clamp(2.5rem,7vw,4.5rem);}
.hero h1{
  color:#fff;font-size:clamp(2.05rem,5.6vw,3.4rem);font-weight:700;
  max-width:18ch;margin-bottom:.35em;
}
.hero .tagline{
  font-family:var(--font-head);font-style:normal;font-weight:600;
  color:#F0C5C9;font-size:1.05rem;letter-spacing:.02em;margin-bottom:.7rem;
}
.hero p.sub{font-size:1.18rem;color:#E7E2DF;max-width:54ch;margin-bottom:1.6rem;}
.hero-cta{display:flex;flex-wrap:wrap;gap:.85rem;}
.hero-rating{
  display:flex;align-items:center;gap:.6rem;margin-top:1.4rem;
  font-size:1rem;color:#E7E2DF;flex-wrap:wrap;
}
.stars{color:#F4B63F;letter-spacing:.06em;font-size:1.1rem;}
.hero-rating strong{color:#fff;}

/* ==========================================================================
   TRUST STRIP
   ========================================================================== */
.trust{background:var(--ink);color:#fff;padding:1.4rem 0;}
.trust ul{
  list-style:none;margin:0;padding:0;display:grid;gap:1rem 1.4rem;
  grid-template-columns:1fr;
}
.trust li{display:flex;align-items:flex-start;gap:.6rem;font-weight:600;font-size:.98rem;}
.trust svg{width:24px;height:24px;color:#F4B63F;flex:none;margin-top:1px;}
@media(min-width:640px){.trust ul{grid-template-columns:1fr 1fr;}}
@media(min-width:1000px){.trust ul{grid-template-columns:repeat(5,1fr);}}

/* ==========================================================================
   REVIEWS
   ========================================================================== */
.reviews{background:var(--paper);}
.rating-head{
  display:flex;flex-direction:column;align-items:center;gap:.3rem;
  margin-bottom:2rem;text-align:center;
}
.rating-big{font-family:var(--font-head);font-size:3rem;font-weight:700;line-height:1;}
.rating-head .stars{font-size:1.5rem;}
.rating-head p{margin:0;color:var(--charcoal);}
.review-grid{display:grid;gap:1.1rem;grid-template-columns:1fr;}
@media(min-width:640px){.review-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1000px){.review-grid{grid-template-columns:repeat(3,1fr);}}
.review-card{
  background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);
  padding:1.4rem 1.35rem;box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.review-card .stars{font-size:1.05rem;margin-bottom:.6rem;}
.review-card blockquote{margin:0 0 1rem;font-size:1.02rem;color:var(--ink);}
.reviewer{display:flex;align-items:center;gap:.7rem;margin-top:auto;}
.avatar{
  width:42px;height:42px;border-radius:50%;background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;
  font-family:var(--font-head);flex:none;
}
.reviewer b{display:block;font-size:.97rem;}
.reviewer small{color:var(--grey);}
.reviews-actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-top:2rem;}

/* ==========================================================================
   SERVICES
   ========================================================================== */
.services{background:#fff;}
.service-grid{display:grid;gap:1rem;grid-template-columns:1fr;}
@media(min-width:560px){.service-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){.service-grid{grid-template-columns:1fr 1fr 1fr;}}
.service-card{
  display:flex;gap:.9rem;align-items:flex-start;
  border:1px solid var(--grey-line);border-radius:var(--radius);
  padding:1.15rem 1.2rem;text-decoration:none;color:var(--ink);
  background:#fff;transition:border-color .15s,box-shadow .15s,transform .08s;
}
.service-card:hover{border-color:var(--red);box-shadow:var(--shadow);transform:translateY(-2px);}
.service-icon{
  width:46px;height:46px;border-radius:9px;background:var(--red-tint);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.service-icon svg{width:26px;height:26px;color:var(--red);}
.service-card h3{margin:0 0 .15rem;font-size:1.1rem;}
.service-card p{margin:0;font-size:.95rem;color:var(--charcoal);}
.service-card .more{display:inline-block;margin-top:.45rem;font-weight:700;font-size:.92rem;color:var(--red);}

/* ==========================================================================
   COMPARISON
   ========================================================================== */
.compare{background:var(--grey-soft);}
.compare-grid{display:grid;gap:1.1rem;grid-template-columns:1fr;}
@media(min-width:820px){.compare-grid{grid-template-columns:1fr 1fr;}}
.compare-col{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:1.5rem;}
.compare-col.ours{border-top:5px solid var(--red);}
.compare-col.theirs{border-top:5px solid var(--grey);}
.compare-col h3{display:flex;align-items:center;gap:.5rem;}
.compare-col ul{list-style:none;margin:0;padding:0;}
.compare-col li{display:flex;gap:.6rem;padding:.6rem 0;border-top:1px solid var(--grey-line);font-size:1rem;}
.compare-col li:first-of-type{border-top:0;}
.compare-col li svg{width:22px;height:22px;flex:none;margin-top:2px;}
.ours li svg{color:var(--red);}
.theirs li svg{color:var(--grey);}
.theirs{color:var(--charcoal);}

/* ==========================================================================
   SERVICE AREAS
   ========================================================================== */
.areas{background:#fff;}
.area-list{
  display:flex;flex-wrap:wrap;gap:.6rem;margin:1.4rem 0 0;padding:0;list-style:none;
}
.area-list a{
  display:inline-block;padding:.55rem .95rem;background:var(--paper);
  border:1px solid var(--grey-line);border-radius:999px;
  text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem;
}
.area-list a:hover{background:var(--red);color:#fff;border-color:var(--red);}

/* ==========================================================================
   ABOUT
   ========================================================================== */
.about{background:var(--ink);color:#fff;}
.about-flex{display:grid;gap:1.8rem;grid-template-columns:1fr;align-items:center;}
@media(min-width:820px){.about-flex{grid-template-columns:.8fr 1.2fr;}}
.about h2{color:#fff;}
.about p{color:#E7E2DF;}
.about-mark{
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(closest-side,#3a2024,#241417);
  border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center;
}
.about-mark .names{font-family:var(--font-head);font-weight:700;font-size:1.9rem;color:#fff;}
.about-mark .since{color:#F0C5C9;font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem;margin-top:.4rem;}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq{background:var(--paper);}
.faq-list{max-width:760px;margin:1.6rem auto 0;}
.faq-list details{
  background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);
  margin-bottom:.7rem;overflow:hidden;
}
.faq-list summary{
  list-style:none;cursor:pointer;padding:1.05rem 1.2rem;font-weight:700;
  font-family:var(--font-head);font-size:1.08rem;display:flex;
  justify-content:space-between;align-items:center;gap:1rem;
}
.faq-list summary::-webkit-details-marker{display:none;}
.faq-list summary::after{
  content:"+";font-size:1.6rem;color:var(--red);font-family:var(--font-body);
  line-height:1;flex:none;
}
.faq-list details[open] summary::after{content:"\2013";}
.faq-list .faq-body{padding:0 1.2rem 1.15rem;color:var(--charcoal);}
.faq-list .faq-body p{margin:0;}

/* ==========================================================================
   LOCATION
   ========================================================================== */
.location{background:#fff;}
.loc-grid{display:grid;gap:1.6rem;grid-template-columns:1fr;}
@media(min-width:820px){.loc-grid{grid-template-columns:1fr 1fr;}}
.loc-card{background:var(--paper);border:1px solid var(--grey-line);border-radius:var(--radius);padding:1.6rem;}
.loc-card h3{margin-top:0;}
.hours-table{width:100%;border-collapse:collapse;margin:.4rem 0 1.2rem;}
.hours-table th,.hours-table td{text-align:left;padding:.42rem 0;border-bottom:1px solid var(--grey-line);font-size:1rem;}
.hours-table th{font-weight:600;color:var(--charcoal);}
.hours-table td{font-weight:700;text-align:right;}
.hours-table .closed td{color:var(--grey);font-weight:600;}
.loc-map{border:0;width:100%;height:100%;min-height:320px;border-radius:var(--radius);}
.loc-meta a{font-weight:700;}

/* ==========================================================================
   FINAL CTA
   ========================================================================== */
.cta-band{
  background:radial-gradient(120% 160% at 80% 0%, #3a2024, #1B1B1B);
  color:#fff;text-align:center;
}
.cta-band h2{color:#fff;}
.cta-band p{color:#E7E2DF;max-width:50ch;margin-left:auto;margin-right:auto;}
.cta-band .hero-cta{justify-content:center;margin-top:1.4rem;}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:#141414;color:#C8C4C0;padding:3rem 0 6.5rem;font-size:.97rem;}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr;}
@media(min-width:680px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr;}}
.site-footer h4{color:#fff;font-size:1.05rem;margin:0 0 .8rem;}
.site-footer a{color:#C8C4C0;text-decoration:none;}
.site-footer a:hover{color:#fff;text-decoration:underline;}
.site-footer ul{list-style:none;margin:0;padding:0;}
.site-footer li{margin-bottom:.45rem;}
.footer-nap p{margin:.2rem 0;}
.footer-social{display:flex;gap:.6rem;margin-top:.8rem;}
.footer-social a{
  width:40px;height:40px;border-radius:8px;background:#262626;
  display:flex;align-items:center;justify-content:center;
}
.footer-social svg{width:20px;height:20px;color:#fff;}
.footer-bottom{
  border-top:1px solid #2a2a2a;margin-top:2.2rem;padding-top:1.4rem;
  font-size:.86rem;color:var(--grey);
}

/* ==========================================================================
   STICKY MOBILE CALL BAR
   ========================================================================== */
.call-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:120;
  background:var(--red);box-shadow:0 -4px 16px rgba(0,0,0,.22);
}
.call-bar a{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  padding:1rem;color:#fff;font-weight:700;font-size:1.18rem;text-decoration:none;
  min-height:60px;
}
.call-bar svg{width:24px;height:24px;}
@media(min-width:1000px){.call-bar{display:none;}.site-footer{padding-bottom:3rem;}}

/* ==========================================================================
   SERVICE PAGE — additions on top of shared foundation
   ========================================================================== */

/* breadcrumb */
.breadcrumb{font-size:.9rem;margin-bottom:1rem;}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.35rem;margin:0;padding:0;}
.breadcrumb li{display:flex;align-items:center;gap:.35rem;color:#E7E2DF;}
.breadcrumb a{color:#F0C5C9;text-decoration:none;font-weight:600;}
.breadcrumb a:hover{text-decoration:underline;}
.breadcrumb li[aria-current]{color:#fff;}
.breadcrumb .sep{color:rgba(255,255,255,.4);}

/* inner-page hero — shorter than the homepage hero */
.page-hero{
  position:relative;color:#fff;overflow:hidden;
  background:radial-gradient(120% 150% at 85% 0%, #3a2024 0%, #241417 45%, #1B1B1B 100%);
}
.page-hero::after{
  content:"";position:absolute;right:-12%;top:-40%;width:60%;height:170%;
  background:radial-gradient(closest-side, rgba(162,34,47,.45), transparent 70%);
  transform:rotate(-12deg);pointer-events:none;
}
.page-hero .wrap{position:relative;z-index:2;padding:clamp(1.8rem,5vw,3rem) 20px clamp(2.2rem,6vw,3.5rem);}
.page-hero h1{color:#fff;font-size:clamp(1.9rem,5vw,3rem);max-width:20ch;margin-bottom:.3em;}
.page-hero .promise{font-size:1.18rem;color:#E7E2DF;max-width:56ch;margin-bottom:1.5rem;}
.page-hero .hero-cta{display:flex;flex-wrap:wrap;gap:.85rem;}

/* "what this covers" checklist */
.covers{background:#fff;}
.covers-grid{display:grid;gap:.7rem 1.5rem;grid-template-columns:1fr;margin-top:1.6rem;padding:0;list-style:none;}
@media(min-width:680px){.covers-grid{grid-template-columns:1fr 1fr;}}
.covers-grid li{display:flex;gap:.7rem;align-items:flex-start;font-size:1.05rem;}
.covers-grid svg{width:24px;height:24px;color:var(--red);flex:none;margin-top:3px;}
.covers .note{
  margin-top:1.8rem;background:var(--red-tint);border-left:4px solid var(--red);
  border-radius:0 8px 8px 0;padding:1.1rem 1.3rem;
}
.covers .note p{margin:0;color:var(--ink);}

/* "how it works" steps */
.steps-sec{background:var(--grey-soft);}
.steps{counter-reset:step;display:grid;gap:1rem;grid-template-columns:1fr;margin-top:1.8rem;padding:0;list-style:none;}
@media(min-width:780px){.steps{grid-template-columns:repeat(5,1fr);}}
.steps li{
  background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);
  padding:1.3rem 1.15rem;position:relative;
}
.steps li::before{
  counter-increment:step;content:counter(step);
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:1.15rem;margin-bottom:.7rem;
}
.steps li h3{font-size:1.05rem;margin:0 0 .3rem;}
.steps li p{margin:0;font-size:.95rem;color:var(--charcoal);}

/* pricing / turnaround box */
.pricing{background:#fff;}
.pricing-box{
  background:var(--ink);color:#fff;border-radius:var(--radius);
  padding:clamp(1.6rem,4vw,2.4rem);display:grid;gap:1.5rem;
  grid-template-columns:1fr;align-items:center;
}
@media(min-width:760px){.pricing-box{grid-template-columns:auto 1fr;gap:2.4rem;}}
.price-figure{text-align:center;}
.price-figure .amount{font-family:var(--font-head);font-weight:700;font-size:clamp(2.4rem,7vw,3.4rem);line-height:1;color:#fff;}
.price-figure .label{display:block;color:#F0C5C9;font-weight:600;text-transform:uppercase;letter-spacing:.07em;font-size:.8rem;margin-top:.4rem;}
.pricing-box ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem;}
.pricing-box li{display:flex;gap:.6rem;align-items:flex-start;color:#E7E2DF;font-size:1.03rem;}
.pricing-box li svg{width:22px;height:22px;color:#F4B63F;flex:none;margin-top:2px;}
.pricing-box li strong{color:#fff;}

/* related services */
.related{background:var(--grey-soft);}
.related-grid{display:grid;gap:.9rem;grid-template-columns:1fr;margin-top:1.6rem;}
@media(min-width:620px){.related-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:920px){.related-grid{grid-template-columns:repeat(4,1fr);}}
.related-card{
  display:block;background:#fff;border:1px solid var(--grey-line);
  border-radius:var(--radius);padding:1.1rem 1.2rem;text-decoration:none;color:var(--ink);
  font-weight:700;transition:border-color .15s,transform .08s;
}
.related-card:hover{border-color:var(--red);transform:translateY(-2px);}
.related-card span{display:block;font-weight:400;font-size:.93rem;color:var(--charcoal);margin-top:.2rem;}
.related-areas{margin-top:1.4rem;}

/* ==========================================================================
   FORM PAGES — additions
   ========================================================================== */
.form-section{background:var(--paper);}
.form-layout{display:grid;gap:2rem;grid-template-columns:1fr;}
@media(min-width:900px){.form-layout{grid-template-columns:1.55fr 1fr;align-items:start;}}
.form-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:clamp(1.4rem,4vw,2.3rem);box-shadow:var(--shadow);}
.form-card h2{margin-top:0;}
.field{margin-bottom:1.15rem;}
.field label{display:block;font-weight:700;margin-bottom:.35rem;font-size:1rem;}
.field .req{color:var(--red);}
.field .hint{font-weight:400;color:var(--grey);font-size:.9rem;}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:1.05rem;padding:.8rem .9rem;
  border:2px solid var(--grey-line);border-radius:8px;background:#fff;color:var(--ink);
  min-height:54px;
}
.field textarea{min-height:140px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint);
}
.field-row{display:grid;gap:1.15rem;}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr;}}
.consent{
  display:flex;gap:.7rem;align-items:flex-start;background:var(--grey-soft);
  border-radius:8px;padding:1rem 1.1rem;margin-bottom:1.2rem;
  font-size:.85rem;color:var(--charcoal);line-height:1.5;
}
.consent input{width:24px;height:24px;flex:none;margin-top:1px;}
.honeypot{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-status{border-radius:8px;padding:1rem 1.1rem;margin-bottom:1.1rem;font-weight:600;}
.form-status[hidden]{display:none;}
.form-status.ok{background:#e8f3e8;border:1px solid #bcdcbc;color:#1f5b1f;}
.form-status.err{background:var(--red-tint);border:1px solid #e7b7bc;color:var(--red-dark);}
.form-card .btn{width:100%;}
.form-aside .aside-card{
  background:var(--ink);color:#fff;border-radius:var(--radius);
  padding:1.6rem;margin-bottom:1rem;
}
.form-aside .aside-card h3{color:#fff;margin-top:0;}
.form-aside .aside-card p{color:#E7E2DF;}
.form-aside .aside-card a{color:#F0C5C9;font-weight:700;}
.form-aside .btn-call{width:100%;margin-top:.3rem;}
.aside-hours{width:100%;border-collapse:collapse;margin-top:.5rem;}
.aside-hours th,.aside-hours td{padding:.32rem 0;font-size:.95rem;border-bottom:1px solid #2f2f2f;}
.aside-hours th{text-align:left;font-weight:600;color:#C8C4C0;}
.aside-hours td{text-align:right;font-weight:700;color:#fff;}
.aside-hours .cl td{color:var(--grey);font-weight:600;}

/* ===== service-area page additions ===== */
.ways{background:var(--grey-soft);}
.ways-grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-top:1.7rem;}
@media(min-width:760px){.ways-grid{grid-template-columns:repeat(3,1fr);}}
.way-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:1.5rem;border-top:5px solid var(--red);}
.way-card .way-ico{width:48px;height:48px;border-radius:10px;background:var(--red-tint);display:flex;align-items:center;justify-content:center;margin-bottom:.8rem;}
.way-card .way-ico svg{width:27px;height:27px;color:var(--red);}
.way-card h3{margin:0 0 .3rem;font-size:1.18rem;}
.way-card p{margin:0;color:var(--charcoal);font-size:.98rem;}
.area-intro{background:#fff;}
.area-intro .lede{max-width:70ch;}
.local-callout{background:var(--red-tint);border-left:4px solid var(--red);border-radius:0 8px 8px 0;padding:1.1rem 1.3rem;margin-top:1.6rem;}
.local-callout p{margin:0;}
/* ===== contact page additions ===== */
.contact-map{border:0;width:100%;min-height:300px;border-radius:var(--radius);margin-top:1rem;}
.contact-lines{list-style:none;margin:.4rem 0 0;padding:0;}
.contact-lines li{display:flex;gap:.6rem;align-items:flex-start;padding:.45rem 0;border-bottom:1px solid #2f2f2f;}
.contact-lines li:last-child{border-bottom:0;}
.contact-lines svg{width:21px;height:21px;color:#F4B63F;flex:none;margin-top:3px;}
.contact-lines .lbl{display:block;font-size:.8rem;color:var(--grey);text-transform:uppercase;letter-spacing:.05em;}
/* ===== hub + simple pages ===== */
.prose{max-width:72ch;}
.prose h2{margin-top:2rem;}
.hub-list{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;gap:.7rem;}
.post-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:1.1rem;}
.post-list li{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:1.3rem 1.4rem;}
.post-list h3{margin:0 0 .3rem;}
.post-list .meta{color:var(--grey);font-size:.9rem;margin:0 0 .5rem;}
.post-list a.more{font-weight:700;}
.sitemap-cols{display:grid;gap:1.6rem;grid-template-columns:1fr;margin-top:1.4rem;}
@media(min-width:680px){.sitemap-cols{grid-template-columns:1fr 1fr;}}
.sitemap-cols ul{list-style:none;padding:0;margin:.4rem 0 0;}
.sitemap-cols li{padding:.25rem 0;}
.notfound{text-align:center;padding:clamp(3rem,9vw,6rem) 0;}
.notfound .big{font-family:var(--font-head);font-size:clamp(3.5rem,12vw,6rem);color:var(--red);line-height:1;margin:0;}
.track-embed{background:var(--grey-soft);border:1px dashed var(--grey);border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center;color:var(--charcoal);margin-top:1.4rem;}
.prose-section{padding:clamp(2.5rem,7vw,4.5rem) 0;background:var(--paper);}
.prose-section .prose{max-width:72ch;}
.prose h2{font-size:clamp(1.4rem,3.2vw,1.9rem);margin:1.8rem 0 .6rem;}
.prose h3{margin:1.4rem 0 .4rem;}
.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}
