/* Signature Air — design tokens + components
   Navy + warm copper, cream surface. Premium residential HVAC.
*/
:root{
  /* Type scale — fluid */
  --text-xs:clamp(.75rem,.7rem + .25vw,.875rem);
  --text-sm:clamp(.875rem,.8rem + .35vw,1rem);
  --text-base:clamp(1rem,.95rem + .25vw,1.125rem);
  --text-lg:clamp(1.125rem,1rem + .75vw,1.5rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --text-2xl:clamp(2rem,1.3rem + 2.5vw,3.25rem);
  --text-3xl:clamp(2.5rem,1rem + 4vw,4.5rem);

  /* Spacing — 4px base */
  --space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;
  --space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;
  --space-20:5rem;--space-24:6rem;--space-32:8rem;

  /* Colors — navy + copper on cream */
  --color-bg:#FBF8F3;            /* warm cream */
  --color-surface:#FFFFFF;
  --color-surface-2:#F5EFE5;     /* subtle sand */
  --color-surface-offset:#EFE7D9;
  --color-border:rgba(15,37,68,.12);
  --color-divider:rgba(15,37,68,.08);

  --color-text:#0F2544;          /* deep navy */
  --color-text-muted:#4A5A74;
  --color-text-faint:#8697AD;
  --color-text-inverse:#FBF8F3;

  --color-navy:#0F2544;
  --color-navy-2:#16314F;        /* slightly lifted navy */
  --color-navy-3:#1F3E63;

  --color-accent:#C07A2C;        /* copper/gold */
  --color-accent-hover:#A9661E;
  --color-accent-soft:#E0B77B;
  --color-accent-highlight:#F5E3C8;

  --color-success:#1F7A4A;
  --color-warning:#B7671F;

  /* Radius */
  --radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;

  /* Shadow — warm tone */
  --shadow-sm:0 1px 2px rgba(15,37,68,.06);
  --shadow-md:0 4px 16px rgba(15,37,68,.08);
  --shadow-lg:0 18px 48px rgba(15,37,68,.14);

  /* Widths */
  --content-narrow:640px;--content-default:1040px;--content-wide:1240px;

  /* Fonts */
  --font-display:'Fraunces','Playfair Display',Georgia,serif;
  --font-body:'Inter','Helvetica Neue',system-ui,sans-serif;
  --font-script:'Dancing Script','Brush Script MT',cursive;
}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--space-5)}
@media(min-width:768px){.container{padding-inline:var(--space-10)}}
.container-narrow{max-width:var(--content-default)}
section{padding-block:clamp(var(--space-16),8vw,var(--space-32))}
section.tight{padding-block:clamp(var(--space-12),6vw,var(--space-20))}

/* ---------- Top bar ---------- */
.topbar{background:var(--color-navy);color:var(--color-text-inverse);font-size:var(--text-xs);text-align:center;padding:var(--space-2) var(--space-4);letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.topbar strong{color:var(--color-accent-soft);font-weight:600}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(251,248,243,.94);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--color-border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);padding:var(--space-4) 0}
.logo{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--color-navy);flex-shrink:0}
.logo svg{width:56px;height:56px;flex-shrink:0}
.logo img.brand-logo{height:84px;width:auto;flex-shrink:0;display:block}
.footer img.brand-logo,.footer-logo-wrap img.brand-logo{height:130px;width:auto;display:block;margin-bottom:var(--space-5);background:transparent;padding:0;border-radius:0;box-shadow:none}
@media(max-width:640px){.logo img.brand-logo{height:68px}.footer img.brand-logo,.footer-logo-wrap img.brand-logo{height:108px}}
.logo-word{display:flex;flex-direction:column;line-height:1;gap:3px;white-space:nowrap}
.logo-word .sa{font-family:var(--font-script);font-size:1.95rem;font-weight:700;color:var(--color-accent);letter-spacing:-.01em;line-height:1}
.logo-word .tag{font-family:var(--font-body);font-size:.58rem;letter-spacing:.2em;color:var(--color-navy);text-transform:uppercase;font-weight:600}
@media(max-width:480px){.logo svg{width:48px;height:48px}.logo-word .sa{font-size:1.4rem}.logo-word .tag{display:none}}
.nav{display:none;gap:var(--space-6)}
@media(min-width:1024px){.nav{display:flex;align-items:center}}
.nav a{font-size:var(--text-sm);color:var(--color-text);font-weight:500;position:relative;padding:var(--space-2) 0;white-space:nowrap}
.nav a:hover{color:var(--color-accent)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--color-accent);border-radius:2px}
.nav-dropdown{position:relative}
.nav-dropdown-panel{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3);min-width:260px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:all 200ms}
.nav-dropdown:hover .nav-dropdown-panel,.nav-dropdown:focus-within .nav-dropdown-panel{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown-panel a{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);white-space:nowrap}
.nav-dropdown-panel a:hover{background:var(--color-surface-2);color:var(--color-accent)}
.header-cta{display:flex;align-items:center;gap:var(--space-3)}
@media(max-width:767px){.header-cta .btn{display:none}}
.phone-link{display:none;color:var(--color-navy);font-weight:600;font-size:var(--text-sm);white-space:nowrap}
.phone-link:hover{color:var(--color-accent)}
.phone-link svg{width:16px;height:16px;display:inline-block;vertical-align:-3px;margin-right:6px}
@media(min-width:768px){.phone-link{display:inline-flex;align-items:center}}
.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}
@media(min-width:1024px){.menu-btn{display:none}}

/* Mobile menu overlay */
.mobile-nav{position:fixed;inset:0;background:var(--color-navy);color:var(--color-text-inverse);z-index:100;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);transform:translateX(100%);transition:transform 300ms cubic-bezier(.16,1,.3,1);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav .close{align-self:flex-end;color:var(--color-text-inverse);font-size:1.5rem}
.mobile-nav a{color:var(--color-text-inverse);font-size:var(--text-lg);font-family:var(--font-display);padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-nav a:hover{color:var(--color-accent-soft)}
.mobile-nav h4{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent-soft);font-size:var(--text-xs);margin-top:var(--space-4);margin-bottom:var(--space-2);font-weight:600}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.9rem 1.6rem;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;line-height:1.1;letter-spacing:.01em;min-height:48px;text-align:center;white-space:nowrap}
.btn-primary{background:var(--color-accent);color:#fff;box-shadow:0 2px 0 rgba(168,99,28,.4),0 10px 24px rgba(192,122,44,.28)}
.btn-primary:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 2px 0 rgba(168,99,28,.5),0 14px 28px rgba(192,122,44,.36)}
.btn-outline{background:transparent;color:var(--color-navy);border:1.5px solid var(--color-navy)}
.btn-outline:hover{background:var(--color-navy);color:#fff}
.btn-ghost{background:transparent;color:var(--color-text-inverse);border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-lg{padding:1.05rem 1.9rem;min-height:54px;font-size:1rem}

/* ---------- Hero ---------- */
.hero{position:relative;padding:var(--space-16) 0 var(--space-16);overflow:hidden;isolation:isolate;color:var(--color-text-inverse);background:var(--color-navy)}
.hero-bg{position:absolute;inset:0;z-index:-1}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.42}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,37,68,.65) 0%,rgba(15,37,68,.82) 65%,var(--color-navy) 100%)}
.hero-inner{position:relative;max-width:820px;padding-block:var(--space-12) var(--space-8)}
.hero-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,auto);gap:var(--space-10);align-items:center}
.hero-logo{display:flex;align-items:center;justify-content:center;padding:var(--space-4)}
.hero-logo img{max-width:100%;width:clamp(360px,40vw,640px);height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,.35))}
@media (max-width:960px){
  .hero-layout{grid-template-columns:1fr;gap:var(--space-6)}
  .hero-logo{order:-1;padding:0}
  .hero-logo img{width:clamp(280px,65vw,440px)}
}
.hero-eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent-soft);font-weight:600;margin-bottom:var(--space-5)}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:var(--color-accent-soft)}
.hero h1{font-size:var(--text-3xl);font-weight:500;line-height:1.05;margin-bottom:var(--space-5);color:var(--color-accent-soft);letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--color-accent-soft)}
.hero-sub{font-size:var(--text-lg);color:rgba(255,255,255,.88);max-width:640px;margin-bottom:var(--space-4);font-weight:400;line-height:1.4}
.hero-copy{font-size:var(--text-base);color:rgba(255,255,255,.75);max-width:640px;margin-bottom:var(--space-8)}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-10)}
.hero-tag{display:inline-block;font-family:var(--font-script);font-weight:600;color:var(--color-accent-soft);font-size:2.1rem;line-height:1;margin-bottom:var(--space-6);opacity:.95}

/* ---------- Trust bar ---------- */
.trustbar{background:var(--color-navy-2);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);padding:var(--space-4) 0;color:rgba(255,255,255,.85)}
.trustbar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
@media(min-width:640px){.trustbar-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.trustbar-grid{grid-template-columns:repeat(5,1fr)}}
.trust-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;font-weight:500;justify-content:center}
.trust-item svg{width:18px;height:18px;color:var(--color-accent-soft);flex-shrink:0}

/* ---------- Section chrome ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent);font-weight:600;margin-bottom:var(--space-3)}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--color-accent)}
h2.section-title{font-size:var(--text-2xl);font-weight:500;margin-bottom:var(--space-4);color:var(--color-navy);letter-spacing:-.015em}
.section-intro{font-size:var(--text-lg);color:var(--color-text-muted);max-width:62ch;margin-bottom:var(--space-12);line-height:1.5}

/* ---------- Services grid ---------- */
.services-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}
@media(min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}}
.service-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);min-height:220px;position:relative;overflow:hidden}
.service-card:hover{border-color:var(--color-accent);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.service-card h3{font-family:var(--font-display);font-size:1.35rem;font-weight:500;color:var(--color-navy);line-height:1.2}
.service-card p{font-size:var(--text-sm);color:var(--color-text-muted);flex:1}
.service-card .arrow{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-accent);font-weight:600;font-size:var(--text-sm);margin-top:auto}
.service-card:hover .arrow{gap:var(--space-3)}
.service-card .icon{width:44px;height:44px;color:var(--color-accent);margin-bottom:var(--space-2)}

/* Features alternating split */
.feature-split{display:grid;grid-template-columns:1fr;gap:var(--space-10);align-items:center}
@media(min-width:960px){.feature-split{grid-template-columns:1.05fr 1fr;gap:var(--space-16)}.feature-split.reverse{grid-template-columns:1fr 1.05fr}.feature-split.reverse .feature-text{order:2}}
.feature-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.feature-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.feature-text h2{font-size:var(--text-2xl);font-weight:500;color:var(--color-navy);margin-bottom:var(--space-4);letter-spacing:-.015em}
.feature-text p{font-size:var(--text-base);color:var(--color-text-muted);margin-bottom:var(--space-4)}
.feature-list{list-style:none;margin:var(--space-5) 0 var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}
.feature-list li{position:relative;padding-left:var(--space-8);font-size:var(--text-base);color:var(--color-text)}
.feature-list li::before{content:"";position:absolute;left:0;top:10px;width:18px;height:2px;background:var(--color-accent)}
.feature-list li strong{color:var(--color-navy);font-weight:600}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:768px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.steps{grid-template-columns:repeat(4,1fr);gap:var(--space-8)}}
.step{position:relative;padding-top:var(--space-8);border-top:2px solid var(--color-navy)}
.step-num{position:absolute;top:-16px;left:0;background:var(--color-bg);padding:0 var(--space-3) 0 0;font-family:var(--font-display);font-size:1.5rem;color:var(--color-accent);font-weight:500}
.step h3{font-family:var(--font-display);font-size:1.25rem;color:var(--color-navy);margin-bottom:var(--space-2);font-weight:500}
.step p{font-size:var(--text-sm);color:var(--color-text-muted)}

/* ---------- Care Club card ---------- */
.care-card{background:var(--color-navy);color:#fff;border-radius:var(--radius-xl);padding:clamp(var(--space-8),5vw,var(--space-16));display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:center;position:relative;overflow:hidden}
@media(min-width:960px){.care-card{grid-template-columns:1.1fr 1fr}}
.care-card::before{content:"";position:absolute;top:-80px;right:-80px;width:320px;height:320px;background:radial-gradient(closest-side,rgba(192,122,44,.22),transparent);pointer-events:none}
.care-card h2{font-size:var(--text-2xl);color:#fff;font-weight:500;margin-bottom:var(--space-4)}
.care-card h2 em{color:var(--color-accent-soft);font-style:italic}
.care-card .price{font-family:var(--font-display);font-size:3rem;color:var(--color-accent-soft);margin-bottom:var(--space-2);font-weight:500;line-height:1}
.care-card .price span{font-size:var(--text-sm);color:rgba(255,255,255,.7);margin-left:var(--space-2);font-family:var(--font-body);letter-spacing:.05em;text-transform:uppercase}
.care-card ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);margin-block:var(--space-6)}
.care-card li{padding-left:var(--space-8);position:relative;font-size:var(--text-base);color:rgba(255,255,255,.88)}
.care-card li::before{content:"✓";position:absolute;left:0;top:0;color:var(--color-accent-soft);font-weight:700;font-size:1.1rem}

/* ---------- Testimonials ---------- */
.testimonials{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:768px){.testimonials{grid-template-columns:repeat(3,1fr)}}
.testimonial{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4);position:relative}
.testimonial .stars{color:var(--color-accent);letter-spacing:2px;font-size:1rem}
.testimonial blockquote{font-family:var(--font-display);font-size:1.15rem;line-height:1.4;color:var(--color-navy);font-weight:400;font-style:italic}
.testimonial cite{font-style:normal;font-size:var(--text-sm);color:var(--color-text-muted)}
.testimonial cite strong{display:block;color:var(--color-navy);font-weight:600;font-style:normal;margin-bottom:2px}
.sample-banner{display:inline-block;background:var(--color-accent-highlight);color:var(--color-warning);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);margin-bottom:var(--space-4)}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:var(--space-2);max-width:820px}
.faq{border-bottom:1px solid var(--color-border);background:transparent}
.faq summary{list-style:none;cursor:pointer;padding:var(--space-5) 0;font-family:var(--font-display);font-size:1.2rem;font-weight:500;color:var(--color-navy);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--color-accent);transition:transform 200ms;line-height:1;flex-shrink:0}
.faq[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 var(--space-6) 0;color:var(--color-text-muted);font-size:var(--text-base);max-width:none}

/* ---------- CTA band ---------- */
.cta-band{background:var(--color-navy);color:#fff;padding-block:var(--space-16)}
.cta-band-inner{text-align:center;max-width:680px;margin-inline:auto}
.cta-band h2{color:#fff;font-size:var(--text-2xl);margin-bottom:var(--space-4);font-weight:500}
.cta-band p{color:rgba(255,255,255,.78);margin-inline:auto;margin-bottom:var(--space-8);font-size:var(--text-lg)}
.cta-band .hero-cta{justify-content:center}

/* ---------- Footer ---------- */
.footer{background:var(--color-navy);color:rgba(255,255,255,.8);padding-block:var(--space-16) var(--space-12);font-size:var(--text-sm)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-10);margin-bottom:var(--space-12)}
@media(min-width:768px){.footer-grid{grid-template-columns:1.3fr 1fr 1fr 1fr;gap:var(--space-8)}}
.footer h4{font-family:var(--font-body);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent-soft);margin-bottom:var(--space-5);font-weight:600}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}
.footer a{color:rgba(255,255,255,.78)}
.footer a:hover{color:var(--color-accent-soft)}
.footer .brand-block{display:flex;flex-direction:column;gap:var(--space-4)}
.footer .brand-block p{max-width:36ch}
.footer .nap{color:rgba(255,255,255,.9);line-height:1.7}
.footer .nap a{color:var(--color-accent-soft);font-weight:600}
.footer-legal{border-top:1px solid rgba(255,255,255,.08);padding-top:var(--space-6);display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;color:rgba(255,255,255,.55);font-size:var(--text-xs)}
.footer-logo-wrap{display:flex;align-items:center;gap:var(--space-3);color:#fff;margin-bottom:var(--space-4)}
.footer-logo-wrap .logo-word .sa{color:var(--color-accent-soft)}
.footer-logo-wrap .logo-word .tag{color:rgba(255,255,255,.55)}
.footer-logo-wrap svg{color:var(--color-accent-soft)}

/* ---------- Mobile sticky call bar ---------- */
.sticky-call{position:fixed;left:0;right:0;bottom:0;background:var(--color-navy);padding:var(--space-3);display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);z-index:40;box-shadow:0 -8px 24px rgba(15,37,68,.2);border-top:1px solid rgba(255,255,255,.1)}
.sticky-call a{min-height:48px}
@media(min-width:768px){.sticky-call{display:none}}
body{padding-bottom:80px}
@media(min-width:768px){body{padding-bottom:0}}

/* ---------- Page header (non-home) ---------- */
.pghead{background:var(--color-navy);color:#fff;padding:var(--space-16) 0 var(--space-20);position:relative;isolation:isolate;overflow:hidden}
.pghead::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(192,122,44,.14),transparent 55%);z-index:-1}
.pghead .breadcrumb{font-size:var(--text-xs);color:rgba(255,255,255,.65);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-5);font-weight:500}
.pghead .breadcrumb a{color:var(--color-accent-soft)}
.pghead h1{font-size:var(--text-3xl);color:#fff;font-weight:500;margin-bottom:var(--space-4);letter-spacing:-.02em;max-width:18ch}
.pghead .lead{font-size:var(--text-lg);color:rgba(255,255,255,.85);max-width:56ch;margin-bottom:var(--space-6);line-height:1.45}
.pghead .hero-cta{margin-top:var(--space-5)}

/* ---------- Two-col prose (service/city body) ---------- */
.body-section{display:grid;grid-template-columns:1fr;gap:var(--space-10)}
@media(min-width:1024px){.body-section{grid-template-columns:2fr 1fr;gap:var(--space-16)}}
.prose h2{font-size:var(--text-xl);color:var(--color-navy);margin-top:var(--space-10);margin-bottom:var(--space-4);font-weight:500;letter-spacing:-.01em}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--font-display);font-size:1.3rem;color:var(--color-navy);margin-top:var(--space-6);margin-bottom:var(--space-3);font-weight:500}
.prose p{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-4);max-width:68ch}
.prose ul,.prose ol{margin:var(--space-4) 0 var(--space-5) var(--space-6);color:var(--color-text)}
.prose ul li,.prose ol li{margin-bottom:var(--space-2)}
.prose a{color:var(--color-accent);font-weight:500;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.prose a:hover{color:var(--color-accent-hover)}
.prose strong{color:var(--color-navy);font-weight:600}

.sidebar{position:sticky;top:var(--space-20);align-self:start;display:flex;flex-direction:column;gap:var(--space-6)}
.sidebar-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}
.sidebar-card h3{font-family:var(--font-display);font-size:1.25rem;color:var(--color-navy);margin-bottom:var(--space-3);font-weight:500}
.sidebar-card p{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4)}
.sidebar-card.dark{background:var(--color-navy);color:#fff}
.sidebar-card.dark h3{color:#fff}
.sidebar-card.dark p{color:rgba(255,255,255,.8)}
.sidebar-card.dark .phone-big{color:var(--color-accent-soft)}
.phone-big{display:block;font-family:var(--font-display);font-size:1.9rem;font-weight:500;color:var(--color-accent);margin-bottom:var(--space-3);letter-spacing:-.01em}

/* Price range callout */
.price-callout{background:var(--color-surface-2);border:1px solid var(--color-accent);border-left-width:4px;padding:var(--space-6);border-radius:var(--radius-md);margin:var(--space-6) 0}
.price-callout .label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent);font-weight:600;margin-bottom:var(--space-2)}
.price-callout .range{font-family:var(--font-display);font-size:1.8rem;color:var(--color-navy);font-weight:500}
.price-callout p{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}

/* Internal link cluster */
.related-areas{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-4)}
.related-areas a{padding:var(--space-2) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-navy);font-weight:500;text-decoration:none}
.related-areas a:hover{background:var(--color-navy);color:#fff;border-color:var(--color-navy)}

/* Map wrap */
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-md);margin:var(--space-6) 0}
.map-wrap iframe{display:block;width:100%;height:360px;border:0}

/* Contact form */
.form-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:clamp(var(--space-6),3vw,var(--space-10))}
.form-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}
@media(min-width:640px){.form-grid.two{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:var(--space-2)}
.field label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--color-navy)}
.field input,.field select,.field textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.9rem 1rem;font-size:var(--text-base);color:var(--color-text);min-height:48px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px rgba(192,122,44,.18)}
.field textarea{min-height:120px;resize:vertical}

/* Misc */
.badge{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:4px 12px;border-radius:var(--radius-full);background:var(--color-accent-highlight);color:var(--color-warning)}
.badge.navy{background:var(--color-navy);color:var(--color-accent-soft)}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity 600ms cubic-bezier(.16,1,.3,1),transform 600ms cubic-bezier(.16,1,.3,1)}
.reveal.show{opacity:1;transform:translateY(0)}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-8);margin-top:var(--space-10)}
.team-card{text-align:center;background:#fff;border:1px solid rgba(15,37,68,.08);border-radius:16px;padding:var(--space-6) var(--space-5) var(--space-7);box-shadow:0 2px 6px rgba(15,37,68,.04);transition:transform 240ms cubic-bezier(.16,1,.3,1),box-shadow 240ms cubic-bezier(.16,1,.3,1)}
.team-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(15,37,68,.10)}
.team-photo-wrap{position:relative;width:220px;height:293px;margin:0 auto var(--space-5);border-radius:14px;overflow:hidden;border:4px solid var(--color-bg);box-shadow:0 8px 22px rgba(15,37,68,.16)}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.team-card h3{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-navy);margin:0 0 var(--space-1)}
.team-card .team-role{display:inline-block;font-size:var(--text-sm);color:var(--color-accent);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:var(--space-3)}
.team-card p{color:var(--color-text-muted);font-size:var(--text-base);margin:0}
@media (max-width:640px){.team-photo-wrap{width:180px;height:240px}}

/* ============ Reviews Page ============ */
.review-summary{display:grid;grid-template-columns:1fr;gap:var(--space-10);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:clamp(var(--space-8),4vw,var(--space-12));align-items:center}
@media(min-width:768px){.review-summary{grid-template-columns:240px 1fr;gap:var(--space-12)}}
.review-summary-score{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);border-right:none;padding-right:0}
@media(min-width:768px){.review-summary-score{border-right:1px solid var(--color-border);padding-right:var(--space-10)}}
.big-rating{font-family:var(--font-display);font-size:5rem;line-height:1;color:var(--color-navy);font-weight:500}
.stars-lg{font-size:1.4rem;letter-spacing:3px;color:var(--color-accent)}
.rating-caption{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}
.review-summary-breakdown{display:flex;flex-direction:column;gap:var(--space-3)}
.breakdown-row{display:grid;grid-template-columns:60px 1fr 40px;gap:var(--space-4);align-items:center;font-size:var(--text-sm);color:var(--color-text-muted)}
.breakdown-row span:last-child{text-align:right}
.bar{height:8px;background:var(--color-surface-2);border-radius:var(--radius-full);overflow:hidden}
.bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width 600ms cubic-bezier(.16,1,.3,1)}
.rating-tags{grid-column:1/-1;margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}
.rating-tags strong{color:var(--color-navy)}

/* Platform cards (Thumbtack/Google CTA) */
.review-platforms{display:grid;grid-template-columns:1fr;gap:var(--space-5);margin-top:var(--space-8)}
@media(min-width:700px){.review-platforms{grid-template-columns:1fr 1fr}}
.platform-card{display:grid;grid-template-columns:56px 1fr auto;gap:var(--space-4);align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);text-decoration:none;color:inherit;transition:transform 240ms cubic-bezier(.16,1,.3,1),box-shadow 240ms cubic-bezier(.16,1,.3,1),border-color 240ms cubic-bezier(.16,1,.3,1)}
.platform-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(15,37,68,.10);border-color:var(--color-accent)}
.platform-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-size:1.5rem;font-weight:600}
.platform-card h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-navy);margin:0 0 4px}
.platform-card p{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}
.platform-card .arrow{font-size:var(--text-sm);color:var(--color-accent);font-weight:600;white-space:nowrap}
@media(max-width:540px){.platform-card{grid-template-columns:56px 1fr}.platform-card .arrow{grid-column:1/-1;margin-top:var(--space-2)}}

/* Reviews grid — 2 columns on desktop for readability */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:860px){.reviews-grid{grid-template-columns:1fr 1fr}}

/* Owner reply block */
.owner-reply{margin-top:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-surface-2);border-left:3px solid var(--color-accent);border-radius:var(--radius-md)}
.owner-reply .reply-label{display:inline-block;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--color-accent);margin-bottom:var(--space-2)}
.owner-reply p{font-size:var(--text-sm);color:var(--color-text);line-height:1.55;margin:0;font-style:normal}
