/* ============================================================
   Auto Savers — heritage-warm
   Burgundy (#712326, from the logo) leads. Navy anchors.
   Warm paper tones. Fraunces display + Inter body.
   ============================================================ */

:root{
  --burgundy:#712326;
  --burgundy-deep:#561a1d;
  --burgundy-line:#8a3538;
  --navy:#1f3050;
  --navy-deep:#152238;
  --white:#ffffff;
  --paper:#fbf7ef;        /* warm card white */
  --cream:#f5eee0;        /* warm section tint */
  --cream-deep:#ece2cf;
  --ink:#2a2018;          /* warm near-black */
  --ink-soft:#5f5547;     /* warm body grey */
  --ink-faint:#938778;
  --gold:#d99a2b;         /* heritage gold — stars */
  --hairline:#e6dcc8;
  --hairline-strong:#d8ccb4;
  --maxw:1180px;
  --maxw-narrow:760px;
  --radius:6px;
  --shadow:0 1px 2px rgba(42,32,24,.06), 0 12px 34px rgba(42,32,24,.10);
  --shadow-sm:0 1px 2px rgba(42,32,24,.06), 0 5px 16px rgba(42,32,24,.07);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink-soft);
  background:var(--white);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3{
  font-family:"Fraunces","Georgia",serif;
  font-optical-sizing:auto;
  color:var(--ink);
  line-height:1.08;
  font-weight:600;
  margin:0;
  letter-spacing:-.01em;
}
h1 em,h2 em,h3 em{font-style:italic;font-weight:500;color:var(--burgundy)}
p{margin:0}
img{max-width:100%;display:block}
a{color:var(--burgundy)}
a:hover{text-decoration:underline}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.wrap--narrow{max-width:var(--maxw-narrow)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--burgundy);color:#fff;padding:12px 18px;border-radius:0 0 var(--radius) 0;text-decoration:none}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--burgundy);outline-offset:3px;border-radius:2px}

/* ---------- stars / kickers ---------- */
.stars{color:var(--gold);letter-spacing:2px}
.stars--gold{color:var(--gold)}
.kicker{font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--burgundy);margin-bottom:14px}
.kicker--cream{color:rgba(255,255,255,.72)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:"Inter",sans-serif;font-weight:600;font-size:1rem;
  padding:13px 24px;border-radius:var(--radius);
  text-decoration:none;border:1.5px solid transparent;cursor:pointer;
  transition:background-color .15s ease, color .15s ease, border-color .15s ease, transform .05s ease;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn--lg{padding:16px 28px;font-size:1.05rem}
.btn--xl{padding:18px 30px;font-size:1.1rem}
.btn-ic{font-size:1.15em;line-height:1}
.btn-stack{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2;text-align:left}
.btn-stack small{font-size:.72rem;font-weight:500;opacity:.82;letter-spacing:.02em}
.btn-stack strong{font-size:1.05rem;font-weight:700}

.btn--burgundy{background:var(--burgundy);color:#fff;border-color:var(--burgundy)}
.btn--burgundy:hover{background:var(--burgundy-deep);border-color:var(--burgundy-deep);color:#fff}
.btn--cream{background:var(--cream);color:var(--burgundy);border-color:var(--cream)}
.btn--cream:hover{background:#fff;color:var(--burgundy-deep)}
.btn--cream-outline{background:transparent;color:#fff;border-color:rgba(245,238,224,.5)}
.btn--cream-outline:hover{background:rgba(245,238,224,.12);color:#fff;border-color:var(--cream)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--hairline-strong)}
.btn--ghost:hover{border-color:var(--ink);background:var(--cream)}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,247,239,.96);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--hairline);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:16px}
.brand{display:inline-flex;align-items:center}
.brand img{height:42px;width:auto}

.nav{display:flex;align-items:center}
.nav-menu{list-style:none;display:flex;align-items:center;gap:30px;margin:0;padding:0}
.nav-menu a{color:var(--ink);font-weight:500;font-size:.98rem;text-decoration:none}
.nav-menu a:hover{color:var(--burgundy)}
.nav-menu__cta a{color:#fff}
.nav-menu__cta a:hover{color:#fff}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center}
.nav-toggle__bars,.nav-toggle__bars::before,.nav-toggle__bars::after{content:"";display:block;width:24px;height:2px;background:var(--ink);transition:transform .2s ease, opacity .2s ease}
.nav-toggle__bars{position:relative}
.nav-toggle__bars::before{position:absolute;top:-7px}
.nav-toggle__bars::after{position:absolute;top:7px}
.nav-toggle[aria-expanded="true"] .nav-toggle__bars{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::before{transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::after{transform:translateY(-7px) rotate(-45deg)}

/* ============ HERO (split panel + photo) ============ */
.hero{position:relative;display:grid;grid-template-columns:1.05fr .95fr;min-height:min(78vh,640px)}
.hero-panel{background:var(--burgundy);color:#fff;display:flex;align-items:center;
  background-image:radial-gradient(120% 80% at 0% 0%, rgba(255,255,255,.06), transparent 55%)}
.hero-panel__inner{max-width:560px;margin-left:auto;padding:64px clamp(32px,5vw,72px) 64px clamp(24px,6vw,90px)}
.hero-eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.66);margin-bottom:34px}
.hero-title{font-size:clamp(2.5rem,4.6vw,4rem);color:#fff;font-weight:600;line-height:1.02;margin-bottom:20px}
.hero-title em{color:var(--gold);font-style:italic;font-weight:500}
.hero-sub{font-size:1.12rem;color:rgba(255,255,255,.84);margin-bottom:26px;max-width:42ch}
.hero-rating{display:flex;align-items:center;gap:10px;color:#fff;font-size:1rem;margin-bottom:34px}
.hero-rating .stars{font-size:1.15rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}

.hero-photo{position:relative;background:var(--burgundy-deep)}
.hero-photo>img:first-child{width:100%;height:100%;object-fit:cover;object-position:center}

.hero-seal{
  position:absolute;left:-72px;bottom:-34px;width:156px;height:auto;z-index:5;
  transform:rotate(-7deg);
  filter:drop-shadow(0 8px 18px rgba(42,32,24,.28));
}
@media (max-width:880px){
  .hero{grid-template-columns:1fr;min-height:0}
  .hero-panel__inner{margin:0 auto;max-width:640px;padding:52px 24px 60px;text-align:left}
  .hero-photo{aspect-ratio:16/10;order:2}
  .hero-seal{left:auto;right:16px;bottom:auto;top:16px;width:104px}
}

/* ============ MARQUEE ============ */
.marquee{background:var(--navy);color:#fff;overflow:hidden;border-top:3px solid var(--burgundy)}
.marquee__track{
  display:flex;align-items:center;gap:0;white-space:nowrap;width:max-content;
  padding:13px 0;
  font-family:"Fraunces",serif;font-weight:500;font-size:1.05rem;letter-spacing:.01em;
  animation:marquee 38s linear infinite;
}
.marquee__track span{padding:0 22px}
.marquee__sep{color:var(--gold);padding:0 2px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;justify-content:center;width:auto;flex-wrap:wrap;white-space:normal}}

/* ============ SECTIONS ============ */
.section{padding:88px 0}
.section--cream{background:var(--cream);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.section-head{margin-bottom:48px;max-width:62ch}
.section-head--center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,4vw,2.9rem)}
.lead{margin-top:18px;font-size:1.14rem;color:var(--ink-soft)}
.lead--cream{color:rgba(255,255,255,.82)}
h2{font-size:clamp(2rem,4vw,2.9rem)}

/* ============ REVIEWS ============ */
.reviews-layout{display:grid;grid-template-columns:230px 1fr;gap:40px;align-items:center}
@media (max-width:820px){.reviews-layout{grid-template-columns:1fr;gap:28px}}
.reviews-badge{text-align:center}
@media (max-width:820px){.reviews-badge{display:flex;flex-direction:column;align-items:center}}
.reviews-badge__word{font-family:"Fraunces",serif;font-size:1.7rem;color:var(--ink);font-weight:600}
.reviews-badge__stars{color:var(--gold);font-size:1.7rem;letter-spacing:3px;margin:4px 0 8px}
.reviews-badge__count{font-size:.95rem;color:var(--ink-soft)}
.reviews-badge__count strong{color:var(--ink)}
.reviews-badge__google{height:24px;width:auto;margin:14px auto 18px;display:block}
.reviews-badge__cta{width:100%}
@media (max-width:820px){.reviews-badge__cta{width:auto}}

.reviews-main{min-width:0}
.reviews-carousel{position:relative;display:flex;align-items:center;gap:8px;min-width:0}
.reviews-note{margin-top:16px;font-size:.9rem;color:var(--ink-faint)}
.reviews-note a{font-weight:600;color:var(--burgundy)}
.reviews-track{list-style:none;margin:0;padding:6px 2px 16px;display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--hairline-strong) transparent}
.reviews-track::-webkit-scrollbar{height:8px}
.reviews-track::-webkit-scrollbar-thumb{background:var(--hairline-strong);border-radius:8px}
.reviews-track::-webkit-scrollbar-track{background:transparent}
.gcard{scroll-snap-align:start;flex:0 0 300px;max-width:300px;background:var(--paper);border:1px solid var(--hairline);border-radius:var(--radius);padding:22px 22px 24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}
@media (max-width:480px){.gcard{flex-basis:84vw;max-width:84vw}}
.gcard__top{display:flex;align-items:center;gap:12px}
.gcard__avatar{flex:0 0 auto;width:42px;height:42px;border-radius:50%;background:var(--av,var(--burgundy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.05rem}
.gcard__id{flex:1 1 auto;min-width:0}
.gcard__name{font-weight:600;color:var(--ink);font-size:.98rem;line-height:1.2}
.gcard__src{font-size:.8rem;color:var(--ink-faint)}
.gcard__g{flex:0 0 auto;font-family:Arial,sans-serif;font-weight:700;font-size:1.15rem;color:#4285F4}
.gcard__stars{display:flex;align-items:center;gap:8px}
.gcard__stars .stars{font-size:1.05rem;letter-spacing:1px}
.verified{width:16px;height:16px}
.gcard__text{font-family:"Fraunces",serif;font-size:1.12rem;line-height:1.4;color:var(--ink)}
.rev-arrow{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--paper);border:1px solid var(--hairline-strong);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:opacity .15s ease, background-color .15s ease}
.rev-arrow svg{width:22px;height:22px}
.rev-arrow:hover{background:var(--cream)}
.rev-arrow.is-disabled{opacity:.3;pointer-events:none}
@media (max-width:560px){.rev-arrow{display:none}}

/* ============ SERVICES ============ */
.svc-list{list-style:none;margin:0 0 48px;padding:0;display:grid;gap:32px 44px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.svc-item{display:flex;gap:18px;align-items:flex-start}
.svc-icon{flex:0 0 auto;width:54px;height:54px;border-radius:50%;background:var(--paper);border:1.5px solid var(--burgundy);color:var(--burgundy);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.svc-icon svg{width:26px;height:26px}
.svc-body h3{font-size:1.3rem;font-weight:600;color:var(--ink);margin-bottom:5px}
.svc-body p{font-size:.98rem;color:var(--ink-soft)}
.svc-all{border-top:1px solid var(--hairline-strong);padding-top:30px}
.svc-all__label{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--burgundy);margin-bottom:16px}
.svc-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:10px}
.svc-tags li{background:var(--paper);border:1px solid var(--hairline-strong);border-radius:100px;padding:7px 16px;font-size:.92rem;font-weight:500;color:var(--ink)}
.svc-note{margin-top:22px;font-size:1rem;color:var(--ink-soft)}

/* ============ HOW IT WORKS (burgundy field) ============ */
.how{background:var(--burgundy);color:#fff;padding:88px 0;
  background-image:radial-gradient(120% 70% at 50% 0%, rgba(255,255,255,.05), transparent 60%)}
.how__head{margin-bottom:54px}
.how h2{color:#fff}
.how h2 em{color:var(--gold)}
.steps{list-style:none;margin:0;padding:0;display:grid;gap:34px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));counter-reset:none}
.step{padding-top:18px;border-top:2px solid rgba(255,255,255,.25);position:relative}
.step__num{font-family:"Fraunces",serif;font-size:2.6rem;font-weight:600;color:var(--gold);line-height:1;display:block;margin-bottom:14px}
.step h3{color:#fff;font-size:1.4rem;margin-bottom:8px}
.step p{color:rgba(255,255,255,.82);font-size:1rem}
.step p a{color:#fff;font-weight:600}

/* ============ ABOUT (editorial) ============ */
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center}
@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:48px}}
.about-photo{position:relative;margin:0}
.about-photo>img:first-child{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.about-seal{position:absolute;right:-22px;bottom:-26px;width:150px;height:auto;transform:rotate(6deg);filter:drop-shadow(0 8px 18px rgba(42,32,24,.25))}
@media (max-width:880px){.about-seal{width:116px;right:8px;bottom:-24px}}
.about-copy h2{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:20px}
.about-copy p{font-size:1.08rem;color:var(--ink-soft);margin-bottom:16px}
.about-points{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.about-points li{position:relative;padding-left:30px;color:var(--ink);font-weight:500}
.about-points li::before{content:"✦";position:absolute;left:0;top:0;color:var(--burgundy)}

/* ============ MEET THE FAMILY ============ */
.team{display:grid;gap:28px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.member{margin:0;background:var(--paper);border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.member__photo{aspect-ratio:4/5;background:var(--cream-deep);overflow:hidden}
.member__photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.member figcaption{padding:20px 22px 24px}
.member h3{font-size:1.4rem;font-weight:600}
.member .role{color:var(--burgundy);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin:5px 0 12px}
.member .bio{font-size:.96rem;color:var(--ink-soft)}

/* ============ FAQ ============ */
.faq{display:flex;flex-direction:column;border-top:1px solid var(--hairline-strong)}
.faq-item{border-bottom:1px solid var(--hairline-strong)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 44px 22px 0;position:relative;font-family:"Fraunces",serif;font-size:1.3rem;color:var(--ink);font-weight:600}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:"Inter",sans-serif;font-size:1.5rem;color:var(--burgundy);line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-body{padding:0 44px 24px 0}
.faq-body p{color:var(--ink-soft)}

/* ============ CONTACT BAND (navy) ============ */
.contact-band{background:var(--navy);color:#fff}
.contact-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:32px;padding:64px 24px}
.contact-copy{max-width:34ch}
.contact-copy h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.5rem)}
.contact-copy p{margin-top:12px;color:rgba(255,255,255,.78);font-size:1.06rem}
.contact-actions{display:flex;flex-wrap:wrap;gap:16px}

/* ============ VISIT ============ */
.visit-grid{display:grid;gap:40px;grid-template-columns:1fr}
@media (min-width:820px){.visit-grid{grid-template-columns:.85fr 1.15fr;align-items:start}}
.visit-info{display:grid;gap:26px;grid-template-columns:1fr 1fr}
@media (max-width:480px){.visit-info{grid-template-columns:1fr}}
.info-label{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--burgundy);margin-bottom:6px}
.info-val{color:var(--ink);font-size:1.05rem;line-height:1.5}
.info-muted{color:var(--ink-faint);font-size:.92rem;margin-top:2px}
.info-link{font-weight:600;color:var(--burgundy)}
.info-link:hover{color:var(--burgundy-deep)}
.map{border:1px solid var(--hairline-strong);border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;width:100%;box-shadow:var(--shadow)}
.map iframe{width:100%;height:100%;border:0;display:block}

/* ============ FOOTER ============ */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.8);padding:58px 0 28px}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:32px}
.footer-logo{height:46px;width:auto;filter:brightness(0) invert(1);opacity:.95}
.footer-tag{margin-top:16px;font-size:.9rem;color:rgba(255,255,255,.66);max-width:34ch}
.footer-contact{font-size:.98rem;line-height:1.9;text-align:right}
.footer-contact a{color:#fff;font-weight:500}
.footer-fb{display:inline-block;margin-top:10px;color:#fff;font-weight:600}
.footer-copy{text-align:center;margin-top:42px;padding-top:22px;border-top:1px solid rgba(255,255,255,.14);font-size:.82rem;color:rgba(255,255,255,.5)}
@media (max-width:600px){.footer-inner{flex-direction:column}.footer-contact{text-align:left}}

/* ============ MOBILE STICKY CALL BAR ============ */
.call-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--burgundy);color:#fff;text-align:center;text-decoration:none;padding:15px 16px;font-weight:600;font-size:1.02rem;box-shadow:0 -2px 12px rgba(0,0,0,.18)}
.call-bar:hover{background:var(--burgundy-deep);text-decoration:none}
.call-bar__icon{margin-right:6px}

/* ============ RESPONSIVE ============ */
@media (max-width:760px){
  body{font-size:16px}
  .section,.how{padding:62px 0}
  .contact-inner{padding:50px 24px}
  .contact-actions{width:100%}
  .contact-actions .btn{width:100%}
  .nav-toggle{display:inline-flex}
  .nav-menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);border-bottom:1px solid var(--hairline);box-shadow:var(--shadow);max-height:0;overflow:hidden}
  .nav-menu.is-open{max-height:90vh;padding:8px 0}
  .nav-menu li{padding:0 24px}
  .nav-menu a{display:block;padding:14px 0;border-bottom:1px solid var(--hairline)}
  .nav-menu li:last-child a{border-bottom:0}
  .nav-menu__cta{padding:12px 24px}
  .nav-menu__cta a{display:block;text-align:center}
  .call-bar{display:block}
  .site-footer{padding-bottom:84px}
}

@media (prefers-reduced-motion:reduce){*{transition:none !important}.reviews-track{scroll-behavior:auto}}
