/* ================================================================
   LEGACY INSPECTIONS — v3
   Tesla meets Texas ranch. Cinematic. Confident. Modern luxury.
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  --black:#030303;--ink:#0a0a09;--char:#141312;--slate:#1c1b19;
  --cream:#f4ead2;--bone:#cfc4aa;--muted:#8f897b;
  --gold:#c9a961;--gold-deep:#8e7135;--gold-bright:#e8c478;
  --line:rgba(201,169,97,.15);
  --glass:rgba(10,10,9,.65);--glass-border:rgba(201,169,97,.12);
  --display:'Cormorant Garamond',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);font-size:16px;line-height:1.6;color:var(--bone);background:var(--black);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:color .3s var(--ease)}
a:hover{color:var(--gold-bright)}
ul{list-style:none}
strong{color:var(--cream)}

.container{width:min(1200px,calc(100% - 48px));margin:0 auto}

/* ---- Type scale ---- */
.eyebrow{font-family:var(--display);font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:1rem}
.accent{color:var(--gold)}

h1{font-family:var(--display);font-size:clamp(3rem,7vw,5.5rem);font-weight:300;line-height:1;letter-spacing:-.03em;color:var(--cream)}
h2{font-family:var(--display);font-size:clamp(2rem,4.5vw,3.4rem);font-weight:300;line-height:1.08;letter-spacing:-.02em;color:var(--cream)}
h3{font-family:var(--display);font-size:1.4rem;font-weight:500;line-height:1.15;letter-spacing:-.01em;color:var(--cream)}
h4{font-family:var(--sans);font-size:.88rem;font-weight:600;letter-spacing:.04em;color:var(--cream)}

p{margin-bottom:1rem}p:last-child{margin-bottom:0}
.lead{font-size:1.15rem;line-height:1.65;color:var(--cream)}
.body-lg{font-size:1.05rem;line-height:1.7}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:1rem 2rem;border:1px solid var(--gold);cursor:pointer;transition:all .4s var(--ease);text-decoration:none;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);z-index:0}
.btn span{position:relative;z-index:1}
.btn-primary{background:var(--gold);color:var(--black)}
.btn-primary:hover{background:var(--gold-bright);color:var(--black);transform:translateY(-1px);box-shadow:0 8px 32px rgba(201,169,97,.25)}
.btn-outline{background:transparent;color:var(--gold)}
.btn-outline:hover{color:var(--black)}.btn-outline:hover::after{transform:scaleX(1)}

/* ---- Fade-in animation (applied via JS IntersectionObserver) ---- */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}

/* ================================================================
   GLASS CARD SYSTEM
   ================================================================ */
.glass{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease)}
.glass:hover{border-color:rgba(201,169,97,.3);transform:translateY(-4px);box-shadow:0 24px 64px rgba(0,0,0,.4)}
.glass::before{content:'';position:absolute;top:0;left:0;width:48px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);pointer-events:none}

/* ================================================================
   NAV
   ================================================================ */
.vet-banner{background:var(--char);text-align:center;font-size:.75rem;padding:.55rem 24px;color:var(--bone);border-bottom:1px solid var(--line)}
.vet-banner strong{color:var(--gold)}.vet-banner a{margin-left:.5rem;font-weight:600}.vet-banner .star{color:var(--gold)}

.nav{position:sticky;top:0;z-index:100;padding:0 24px;transition:background .4s,backdrop-filter .4s}
.nav.scrolled{background:rgba(3,3,3,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:2rem;height:auto;padding:12px 0}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand-logo{height:128px;width:auto;transition:opacity .3s}
.nav-links{display:flex;flex-wrap:wrap;gap:1.8rem;margin-left:auto}
.nav-links a{font-family:var(--sans);font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(207,196,170,.7);transition:color .3s}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-link-secondary{opacity:.5;font-size:.68rem!important}
.nav-cta{flex-shrink:0;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.6rem 1rem;border:1px solid var(--gold);color:var(--gold);transition:all .3s var(--ease)}
.nav-cta:hover{background:var(--gold);color:var(--black)}
@media(max-width:1080px){.nav-inner{flex-wrap:wrap;height:auto;padding:.6rem 0}.nav-links{gap:1rem;width:100%;order:3}.nav-link-secondary{display:none}}

/* ================================================================
   HERO — full viewport cinematic
   ================================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:scale(1.05);transition:transform 8s linear}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,3,3,.3) 0%,rgba(3,3,3,.15) 30%,rgba(3,3,3,.5) 70%,rgba(3,3,3,.92) 100%);pointer-events:none}
.hero-content{position:relative;z-index:2;padding-bottom:clamp(80px,12vh,140px);max-width:800px}
.hero h1{margin-bottom:1.5rem;text-shadow:0 2px 40px rgba(0,0,0,.5)}
.hero .lead{max-width:520px;margin-bottom:2.5rem;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;align-items:center}
.hero-trust span{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,234,210,.7)}
.hero-trust .star{color:var(--gold);margin-right:.25rem}
.hero-trust-sep{width:1px;height:12px;background:rgba(201,169,97,.3)}

.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.5;animation:float 2.5s ease-in-out infinite}
.scroll-hint span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone)}
.scroll-hint svg{width:20px;height:20px;stroke:var(--gold);stroke-width:2;fill:none}
@keyframes float{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

@media(max-width:880px){
  .hero{min-height:90vh;align-items:flex-end}
  .hero-content{padding-bottom:60px}
  .hero-overlay{background:linear-gradient(180deg,rgba(3,3,3,.4) 0%,rgba(3,3,3,.85) 60%,rgba(3,3,3,.98) 100%)}
  .hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}
  .hero-trust-sep{display:none}
}

/* ================================================================
   SECTIONS — full viewport or large blocks
   ================================================================ */
.section{padding:clamp(80px,10vw,140px) 0;position:relative}
.section.alt{background:var(--ink)}
.section.dark{background:var(--char)}
.section-head{max-width:720px;margin:0 auto 4rem;text-align:center}
.section-head h2{margin-bottom:.75rem}
.section-head p{font-size:1.05rem;line-height:1.65}

/* ---- Photo Section (full-bleed image with text overlay) ---- */
.photo-section{position:relative;min-height:70vh;display:flex;align-items:center;overflow:hidden}
.photo-section-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.photo-section-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,3,3,.88) 0%,rgba(3,3,3,.6) 40%,rgba(3,3,3,.3) 100%)}
.photo-section-content{position:relative;z-index:2;max-width:560px}
.photo-section-content h2{margin-bottom:1rem}
.photo-section-content p{margin-bottom:1.5rem}

/* ---- Split (two-col) ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,96px);align-items:center}
.split--wide-left{grid-template-columns:1.2fr .8fr}
.split--wide-right{grid-template-columns:.8fr 1.2fr}
.split-copy{max-width:560px}
.split-copy h2{margin-bottom:1rem}
@media(max-width:900px){.split,.split--wide-left,.split--wide-right{grid-template-columns:1fr;gap:3rem}}

/* ---- Image Frame ---- */
.image-frame{overflow:hidden;border:1px solid var(--line);position:relative;background:var(--black)}
.image-frame::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);z-index:2}
.image-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.image-frame:hover img{transform:scale(1.03)}
.image-frame--portrait{aspect-ratio:3/4}
.image-frame--landscape{aspect-ratio:16/10}
.image-frame--map{aspect-ratio:16/9;max-height:440px}
@media(max-width:700px){.image-frame--portrait{aspect-ratio:4/5}}

/* ================================================================
   CARDS
   ================================================================ */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card-grid--2{grid-template-columns:repeat(2,1fr)}
.card-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.card-grid,.card-grid--4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.card-grid,.card-grid--2,.card-grid--4{grid-template-columns:1fr}}

.card{position:relative;padding:clamp(24px,3vw,36px);border:1px solid var(--line);background:linear-gradient(165deg,rgba(20,19,18,.8),rgba(10,10,9,.9));transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease)}
.card:hover{border-color:rgba(201,169,97,.35);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.35)}
.card::before{content:'';position:absolute;top:0;left:0;width:48px;height:2px;background:var(--gold)}
.card-num{font-family:var(--display);font-size:2rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.75rem;opacity:.6}
.card-key{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.6rem}
.card h3{margin-bottom:.5rem}
.card p{font-size:.92rem;line-height:1.55}

/* ================================================================
   STAT STRIP
   ================================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--black)}
.stat{text-align:center;padding:clamp(24px,4vw,48px) 16px;border-right:1px solid var(--line);position:relative}
.stat:last-child{border-right:none}
.stat-value{display:block;font-family:var(--display);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;color:var(--gold);letter-spacing:-.03em;line-height:1;margin-bottom:.4rem}
.stat-label{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
@media(max-width:700px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}.stat:nth-child(-n+2){border-bottom:1px solid var(--line)}}

/* ================================================================
   PROCESS STEPS
   ================================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{padding:28px 24px;border:1px solid var(--line);background:rgba(20,19,18,.5);position:relative}
.step::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,var(--gold),transparent 60%)}
.step-num{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;display:block}
.step h4{margin-bottom:.35rem}
.step p{font-size:.85rem;line-height:1.5;margin:0}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.steps{grid-template-columns:1fr}}

/* ================================================================
   SERVICE CARDS
   ================================================================ */
.svc-card{display:flex;flex-direction:column;border:1px solid var(--line);background:var(--ink);overflow:hidden;transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease)}
.svc-card:hover{border-color:rgba(201,169,97,.35);transform:translateY(-4px);box-shadow:0 24px 64px rgba(0,0,0,.4)}
.svc-card:hover .svc-img{transform:scale(1.06)}
.svc-media{position:relative;overflow:hidden;background:var(--black)}
.svc-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(3,3,3,.6) 100%);pointer-events:none}
.svc-img{width:100%;aspect-ratio:16/9;max-height:200px;object-fit:cover;transition:transform .8s var(--ease)}
.svc-tag{position:absolute;top:12px;left:12px;background:rgba(3,3,3,.85);backdrop-filter:blur(8px);color:var(--gold);font-size:.6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--glass-border);z-index:2}
.svc-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex-grow:1}
.svc-body h3{font-size:1.2rem;margin-bottom:.4rem}
.svc-lede{font-size:.85rem;line-height:1.5;color:var(--bone);margin-bottom:1rem}
.svc-facts{display:flex;flex-direction:column;gap:4px;padding-top:10px;border-top:1px solid var(--line);margin-bottom:12px}
.svc-fact{display:grid;grid-template-columns:80px 1fr;gap:4px;font-size:.78rem}
.svc-fact-k{color:var(--gold);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.62rem}
.svc-fact-v{color:var(--cream)}
.svc-cta{margin-top:auto;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);padding-top:12px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;transition:color .3s}
.svc-cta:hover{color:var(--gold-bright)}

/* ================================================================
   AREA CHIPS
   ================================================================ */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.25rem}
.chip{font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(3,3,3,.5);border:1px solid var(--line);padding:8px 14px;transition:all .3s var(--ease)}
.chip:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,169,97,.06)}

/* ================================================================
   FAQ
   ================================================================ */
.faq-list{max-width:820px;margin:0 auto}
.faq{border-bottom:1px solid var(--line)}
.faq summary{font-family:var(--display);font-size:1.1rem;font-weight:500;color:var(--cream);padding:1.25rem 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none;transition:color .3s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--gold)}
.faq summary::after{content:'+';font-size:1.3rem;color:var(--gold);flex-shrink:0;margin-left:1rem;transition:transform .3s var(--ease)}
.faq[open] summary::after{content:'−';transform:rotate(180deg)}
.faq-body{padding:0 0 1.5rem;font-size:.95rem;line-height:1.65}

/* ================================================================
   CTA BAND
   ================================================================ */
.cta-band{padding:clamp(80px,10vw,140px) 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(201,169,97,.08),transparent 65%);pointer-events:none}
.cta-band h2{margin-bottom:.75rem}
.cta-band p{font-size:1.05rem;max-width:520px;margin:0 auto 2.5rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}

/* ================================================================
   FOOTER
   ================================================================ */
footer{background:var(--ink);border-top:1px solid var(--line);padding:5rem 0 2rem;font-size:.88rem}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:3rem;margin-bottom:3rem}
.footer-col h4{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;font-weight:600}
.footer-col ul{display:flex;flex-direction:column;gap:.55rem}
.footer-col a{color:var(--bone);font-size:.85rem;transition:color .3s}.footer-col a:hover{color:var(--gold)}
.footer-tag{color:var(--gold);font-family:var(--display);font-style:italic;margin-bottom:.75rem;font-size:1rem}
.footer-brand,.footer-newsletter{display:flex;flex-direction:column}
.trec-notice{padding:1.5rem 0;border-top:1px solid var(--line);text-align:center;font-size:13pt;line-height:1.6}
.trec-notice strong{display:block;color:var(--gold);font-size:.78rem;letter-spacing:.08em;margin-bottom:.5rem;font-weight:600}
.trec-cpn-link{color:var(--cream);font-size:13pt;border-bottom:1px solid var(--gold-deep)}.trec-cpn-link:hover{color:var(--gold);border-color:var(--gold)}
.trec-sep{color:var(--muted);margin:0 .5rem}
.footer-bottom{border-top:1px solid var(--line);padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;font-size:.75rem;color:var(--muted)}
.footer-bottom .star{color:var(--gold)}.footer-bottom a{color:var(--muted)}
.newsletter-form{display:flex;gap:6px;margin-top:.75rem}
.newsletter-form input[type="email"]{flex:1;padding:10px 14px;background:var(--black);border:1px solid var(--line);color:var(--cream);font-family:var(--sans);font-size:.85rem}
.newsletter-form input::placeholder{color:var(--muted)}
.newsletter-form button{padding:10px 18px;background:var(--gold);color:var(--black);border:1px solid var(--gold);font-family:var(--sans);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .3s}
.newsletter-form button:hover{background:var(--gold-bright)}
@media(max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.trec-notice{text-align:left}.trec-cpn-link{display:block;margin:.3rem 0}.trec-sep{display:none}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column}}

/* ================================================================
   PAGE-LEVEL COMPAT (remaining pages that use old classes)
   ================================================================ */
.container-narrow{max-width:820px;margin:0 auto;padding:0 24px}
.page-header{padding:clamp(100px,12vw,160px) 0 clamp(48px,6vw,80px);background:var(--ink);border-bottom:1px solid var(--line)}
.page-header h1{margin-bottom:.75rem}.page-header p{max-width:600px;font-size:1.05rem}
.breadcrumb{font-size:.75rem;color:var(--muted);margin-bottom:1rem}.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--gold)}.breadcrumb .sep{margin:0 .4rem}
.jump-nav{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.5rem}
.jump-nav a{border:1px solid var(--line);padding:8px 14px;font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:rgba(3,3,3,.4);transition:all .3s var(--ease)}
.jump-nav a:hover{border-color:var(--gold);background:rgba(201,169,97,.08)}

.gold-callout{margin:1.5rem 0;padding:1.25rem 1.5rem;border-left:3px solid var(--gold);background:rgba(201,169,97,.06);font-size:.95rem;line-height:1.6;color:var(--cream)}
.gold-callout strong{color:var(--gold)}
.pull-quote{margin:0 auto;padding:2rem 2.5rem;border-left:3px solid var(--gold);background:var(--ink);max-width:800px;position:relative}
.pull-quote::before{content:'"';position:absolute;top:-8px;left:14px;font-family:var(--display);font-size:4rem;color:var(--gold);opacity:.4;line-height:1}
.pull-quote p{font-family:var(--display);font-size:clamp(1.15rem,2vw,1.35rem);font-style:italic;line-height:1.45;color:var(--cream);margin:0 0 .75rem}
.pull-quote footer{font-family:var(--display);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}

.ornament{text-align:center;padding:2rem 0;color:var(--gold);opacity:.5}
.page-header-star{display:none}
.has-banner .page-header{padding-top:clamp(80px,10vw,120px)}
.area-grid,.service-area-cities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:2rem}
.area-card,.sa-city-card{background:var(--black);border:1px solid var(--line);padding:24px 20px;text-decoration:none;display:block;transition:all .35s var(--ease);position:relative;overflow:hidden}
.area-card::before,.sa-city-card::before{content:'';position:absolute;top:0;left:0;width:48px;height:2px;background:var(--gold);transition:width .35s var(--ease)}
.area-card:hover,.sa-city-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 16px 48px rgba(0,0,0,.3)}.area-card:hover::before,.sa-city-card:hover::before{width:100%}
.sa-city-num{font-size:.65rem;font-weight:600;letter-spacing:.22em;color:var(--gold);display:block;margin-bottom:.35rem}
.sa-city-card h3,.area-card h3{font-family:var(--display);font-size:1.25rem;color:var(--cream);margin:0 0 .4rem;font-weight:500}
.sa-city-card p,.area-card p{margin:0;color:var(--bone);font-size:.82rem;line-height:1.5}

.market-snap{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:1.5rem}
.snap-item{padding:18px 14px;border-left:2px solid var(--gold);background:var(--char)}
.snap-item strong{display:block;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem;font-weight:600}
.snap-item span{display:block;color:var(--cream);font-size:.9rem;line-height:1.4}

.priority-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px;margin-top:1.5rem}
.priority-card{padding:24px 20px;background:var(--black);border:1px solid var(--line);position:relative;transition:border-color .35s var(--ease),transform .35s var(--ease)}
.priority-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.priority-card::before{content:'';position:absolute;top:0;left:0;width:40px;height:2px;background:var(--gold)}
.priority-card h3{font-size:1.1rem;color:var(--cream);margin-bottom:.5rem;font-weight:500;line-height:1.25}
.priority-card p{font-size:.9rem;margin:0;line-height:1.6}

.page-header-with-map .page-header-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center}
.page-header-map{max-width:300px;margin-left:auto}
.page-header-text{max-width:600px}
.texas-mini-map{width:100%;height:auto}
.map-city-label-large{font-family:var(--display);font-size:20px;fill:var(--gold);font-weight:500;letter-spacing:.08em;text-transform:uppercase}
@media(max-width:880px){.page-header-with-map .page-header-grid{grid-template-columns:1fr}.page-header-map{max-width:220px;margin:0 auto}}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.25rem}
.contact-icon{width:28px;height:28px;color:var(--gold);margin-bottom:.4rem}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr}}

.satellite-map-wrapper{margin:2.5rem auto;max-width:1100px;border:1px solid var(--line);overflow:hidden;position:relative}
.satellite-map-wrapper::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);z-index:2}
.satellite-map-wrapper img{width:100%;height:auto;max-height:480px;object-fit:cover}
.satellite-map-caption{text-align:center;font-size:.82rem;color:var(--bone);padding:1rem;border-top:1px solid var(--line);background:var(--ink);font-style:italic}

.service-map-section{padding:clamp(72px,8vw,120px) 0;background:var(--ink);border-bottom:1px solid var(--line)}

.trec-disclosure-bar{background:var(--char);padding:2rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trec-disclosure-inner{max-width:820px;margin:0 auto;text-align:center}
.trec-disclosure-inner p{font-size:13pt;line-height:1.7;color:var(--bone)}
.trec-disclosure-inner a{color:var(--gold);border-bottom:1px solid var(--gold-deep)}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;margin-top:2rem}
.post-card{border:1px solid var(--line);background:var(--ink);overflow:hidden;transition:border-color .35s var(--ease),transform .35s var(--ease)}
.post-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.post-card a{text-decoration:none;color:inherit;display:block;padding:24px}
.post-card h3{font-family:var(--display);font-size:1.15rem;color:var(--cream);margin-bottom:.4rem;font-weight:500}
.post-card-cat{display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.post-card-excerpt,.post-card p{font-size:.85rem;color:var(--bone);line-height:1.5;margin:0}
.post-card-meta,.post-meta{font-size:.72rem;color:var(--muted);margin-top:.6rem}
.read-more{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:inline-block;margin-top:.6rem}
.post-header{padding:clamp(100px,12vw,160px) 0 clamp(48px,6vw,80px);background:var(--ink);border-bottom:1px solid var(--line)}
.post-cat{display:inline-block;font-size:.65rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.post-related{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line)}
.post-related h3{margin-bottom:1rem}
.post-body .lead{font-size:1.08rem;line-height:1.7;color:var(--cream);margin-bottom:1.5rem}
.post-callout{margin-top:2.5rem;padding:1.5rem;border:1px solid var(--gold-deep);background:rgba(201,169,97,.05)}
.post-callout strong{color:var(--gold);display:block;margin-bottom:.35rem}
.post-callout p{font-size:.92rem;margin:0}

.article-layout{display:grid;grid-template-columns:200px minmax(0,740px);gap:3rem;align-items:start;max-width:1040px;margin:0 auto}
.article-body{max-width:740px}
.article-body p{font-size:1.02rem;line-height:1.8;margin-bottom:1.1rem}
.article-body h2{margin-top:3rem;padding-top:1.2rem;border-top:1px solid var(--line);font-size:1.5rem}
.article-body h3{margin-top:2rem;font-size:1.2rem}
.article-body ul,.article-body ol{margin:1rem 0 1.5rem 1.2rem;list-style:disc}
.article-body li{font-size:.95rem;line-height:1.7;margin-bottom:.35rem}
.article-aside{position:sticky;top:100px}
.article-toc{border:1px solid var(--line);background:var(--ink);padding:18px}
.article-toc-title{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;display:block}
.article-toc ul{list-style:none;padding:0;margin:0}
.article-toc li{border-bottom:1px solid var(--line)}.article-toc li:last-child{border-bottom:none}
.article-toc a{display:block;padding:8px 0;font-size:.8rem;color:var(--bone);transition:color .3s}.article-toc a:hover{color:var(--gold)}
@media(max-width:980px){.article-layout{grid-template-columns:1fr;gap:1.5rem}.article-aside{position:static}}

.filter-pills,.blog-filter{display:flex;flex-wrap:wrap;gap:8px}
.filter-pill{font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:8px 14px;border:1px solid var(--line);color:var(--bone);background:transparent;cursor:pointer;transition:all .3s var(--ease)}
.filter-pill:hover,.filter-pill.active{border-color:var(--gold);color:var(--gold);background:rgba(201,169,97,.06)}
.blog-filters{padding:1.5rem 0}
.newsletter{padding:clamp(48px,6vw,80px) 0;background:var(--ink);border-bottom:1px solid var(--line);text-align:center}
.newsletter-inner{max-width:480px;margin:0 auto}

.discount{font-family:var(--display);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;color:var(--gold);letter-spacing:-.02em;line-height:1}
.discount-label{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
.vet-hero{padding:clamp(72px,8vw,120px) 0;background:var(--ink);border-bottom:1px solid var(--line)}
.vet-hero-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}
.vet-badge-card{border:1px solid var(--line);background:var(--black);padding:2rem;text-align:center;max-width:280px}
.vet-badge-card img{max-height:180px;margin:0 auto}
@media(max-width:800px){.vet-hero-grid{grid-template-columns:1fr}.vet-badge-card{margin:0 auto}}

.texas-service-map{width:100%;height:auto}
.map-city-link{cursor:pointer}
.map-city-star{fill:var(--gold);stroke:#e8c478;stroke-width:.8;transition:fill .2s}
.map-city-link:hover .map-city-star{fill:var(--gold-bright)}
.map-city-halo{fill:none;stroke:var(--gold);stroke-width:1;stroke-opacity:.18}
.map-city-label{font-family:var(--display);font-size:13px;fill:var(--cream);font-weight:500}
.map-region-label{font-family:var(--display);font-size:11px;letter-spacing:.3em;fill:var(--gold);font-weight:600}
.map-region-sub{font-family:var(--sans);font-size:8px;letter-spacing:.2em;fill:var(--bone);opacity:.7;text-transform:uppercase}
.map-compass{font-family:var(--display);font-size:12px;fill:var(--gold)}

@media print{.vet-banner,.nav,footer,.cta-band{display:none}body{background:#fff;color:#333}}

/* ---- Class aliases (old names → new v3 equivalents) ---- */
.area-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.25rem}
.area-chip{font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(3,3,3,.5);border:1px solid var(--line);padding:8px 14px;transition:all .3s var(--ease)}
.area-chip:hover{border-color:var(--gold);color:var(--gold)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.process-step{padding:28px 24px;border:1px solid var(--line);background:rgba(20,19,18,.5);position:relative}
.process-step::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,var(--gold),transparent 60%)}
.process-num{font-size:.62rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;display:block}
.process-step h4{margin-bottom:.35rem}.process-step p{font-size:.85rem;line-height:1.5;margin:0}
@media(max-width:900px){.process-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.process-grid{grid-template-columns:1fr}}
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--black)}
.stat-strip-item{text-align:center;padding:clamp(24px,4vw,48px) 16px;border-right:1px solid var(--line)}.stat-strip-item:last-child{border-right:none}
.stat-strip-item strong{display:block;font-family:var(--display);font-size:clamp(1.6rem,3.2vw,2.2rem);font-weight:300;color:var(--gold);letter-spacing:-.02em;line-height:1;margin-bottom:.35rem}
.stat-strip-item span{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
@media(max-width:700px){.stat-strip{grid-template-columns:1fr 1fr}.stat-strip-item:nth-child(2){border-right:none}.stat-strip-item:nth-child(-n+2){border-bottom:1px solid var(--line)}}
.split-media{position:relative}
.section.tight,.tight{padding:clamp(48px,5vw,72px) 0}

/* ---- FORCE service card grid (debugging layout collapse) ---- */
.card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
}
@media (max-width: 900px) {
  .card-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
  .card-grid { grid-template-columns: 1fr !important; }
}

.svc-card {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

.svc-img {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  max-height: 200px !important;
  object-fit: cover !important;
  display: block !important;
}

.svc-media {
  position: relative !important;
  overflow: hidden !important;
  max-height: 200px !important;
}

.svc-fact {
  display: grid !important;
  grid-template-columns: 80px 1fr !important;
  gap: 8px !important;
}

/* ---- FORCE split grid ---- */
.split {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 64px !important;
}
@media (max-width: 900px) {
  .split { grid-template-columns: 1fr !important; gap: 32px !important; }
}

/* ---- FORCE steps grid ---- */
.steps {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}
@media (max-width: 900px) {
  .steps { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
  .steps { grid-template-columns: 1fr !important; }
}

/* ---- FORCE stats grid ---- */
.stats {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
}

/* ---- FORCE vertical stacking of page sections ---- */
main {
  display: block !important;
  width: 100% !important;
}
main > section,
main > div,
main > .hero,
main > .photo-section,
main > .cta-band,
main > .stats,
main > .stat-strip {
  display: block !important;
  width: 100% !important;
  float: none !important;
  position: relative !important;
}
main > section.hero,
main > section.photo-section {
  display: flex !important;
  width: 100% !important;
}
main > .stats,
main > .stat-strip {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  width: 100% !important;
}

/* ---- Fixed nav clearance ---- */
/* Nav is position:fixed, so page content needs top offset */

/* Hero sections account for this themselves, so pull them back */

/* Vet banner sits above nav when present */



/* ---- Fix blog filter buttons ---- */
.blog-filters {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding: 1.5rem 0 !important;
}
.blog-filter {
  display: inline-block !important;
  font-family: var(--display);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 8px 14px;
  border: 1px solid var(--line);
  color: var(--bone);
  background: transparent;
  cursor: pointer;
  transition: all .3s;
}
.blog-filter:hover, .blog-filter.active {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,169,97,.06);
}


/* ---- Social links ---- */
.footer-socials{display:flex;gap:12px;margin-top:1.25rem}
.social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line);color:var(--bone);transition:all .3s var(--ease)}
.social-link:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.social-link svg{width:18px;height:18px}

.nav-socials{display:flex;gap:6px;margin-left:auto}
.social-link--sm{width:28px;height:28px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .3s}
.social-link--sm:hover{border-color:var(--gold);color:var(--gold)}
.social-link--sm svg{width:14px;height:14px}
@media(max-width:1080px){.nav-socials{display:none}}
